The C Standard defines octal constants as a 0 followed by octal digits (0 1 2 3 4 5 6 7). Programming errors can occur when decimal values are mistakenly specified as octal constants.
Noncompliant Code Example
In this noncompliant code example, a decimal constant is mistakenly prefaced with zeros so that all the constants are a fixed length:
i_array[0] = 2719; i_array[1] = 4435; i_array[2] = 0042;
Although it may appear that i_array[2]
is assigned the decimal value 42, it is actually assigned the decimal value 34.
Compliant Solution
To avoid using wrong values and to make the code more readable, do not preface constants with zeroes if the value is meant to be decimal:
i_array[0] = 2719; i_array[1] = 4435; i_array[2] = 42;
Risk Assessment
Misrepresenting decimal values as octal can lead to incorrect comparisons and assignments.
Rule | Severity | Likelihood | Remediation Cost | Priority | Level |
---|---|---|---|---|---|
DCL18-C | Low | Unlikely | Low | P3 | L3 |
Automated Detection
Tool | Version | Checker | Description |
CodeSonar | 8.1p0 | LANG.TYPE.OC | Octal constant |
LDRA tool suite | 9.7.1 | 83 S | Fully Implemented |
Parasoft C/C++test | 9.5 | CODSTA-117 MISRA2004-7_1_a | Fully implemented |
PRQA QA-C | Unable to render {include} The included page could not be found. | 0339 |
Related Guidelines
MISRA C:2012 | Rule 7.1 (required) |