A basic understanding of the various environmental limits. The full list is in section 5.2.4.1 of the C specification. Here are a few;
127 parameters in one function definition
127 arguments in one function call
127 parameters in one macro definition
127 arguments in one macro invocation
4095 characters in a logical source line
4095 characters in a character string
literal or wide string literal (after
concatenation)
65535 bytes in an
object (in a hosted environment only)
15nesting levels for #includedfiles
1023 case labels for a switch
statement (excluding those for
anynested switch statements)
I was actually a bit surprised at the limit of 1023 case labels for a switch statement, I can forsee that being exceeded for generated code/lex/parsers fairly easially.
If these limits are exceeded, you have undefined behavior (crashes, security flaws, etc...).
Right, I know this is from the C specification, but C++ shares these basic supports.
2/ The memcpy function
copies n characters from the object pointed to by s2 into the object
pointed to by s1. If copying takes place between objects that overlap,
the behavior is undefined. Returns 3 The memcpy function returns the
value of s1.
2 The memmove function copies n characters from the object pointed to
by s2 into the object pointed to by s1. Copying takes place as if the
n characters from the object pointed to by s2 are first copied into a
temporary array of n characters that does not overlap the objects
pointed to by s1 and s2, and then the n characters from the temporary
array are copied into the object pointed to by s1. Returns
The order that function parameters are evaluated is unspecified behavior. (This won't make your program crash, explode, or order pizza... unlike undefined behavior.)
The only requirement is that all parameters must be fully evaluated before the function is called.
This:
// The simple obvious one.
callFunc(getA(),getB());
Can be equivalent to this:
int a = getA();
int b = getB();
callFunc(a,b);
Or this:
int b = getB();
int a = getA();
callFunc(a,b);
It can be either; it's up to the compiler. The result can matter, depending on the side effects.
Reading or writing to an object or array at an offset that is negative, or beyond the size of that object (stack/heap overflow)
Integer Overflows
Signed integer overflow
Evaluating an expression that is not mathematically defined
Left-shifting values by a negative amount (right shifts by negative amounts are implementation defined)
Shifting values by an amount greater than or equal to the number of bits in the number (e.g. int64_t i = 1; i <<= 72 is undefined)
Types, Cast and Const
Casting a numeric value into a value that can't be represented by the target type (either directly or via static_cast)
Using an automatic variable before it has been definitely assigned (e.g., int i; i++; cout << i;)
Using the value of any object of type other than volatile or sig_atomic_t at the receipt of a signal
Attempting to modify a string literal or any other const object during its lifetime
Concatenating a narrow with a wide string literal during preprocessing
Function and Template
Not returning a value from a value-returning function (directly or by flowing off from a try-block)
Multiple different definitions for the same entity (class, template, enumeration, inline function, static member function, etc.)
Infinite recursion in the instantiation of templates
Calling a function using different parameters or linkage to the parameters and linkage that the function is defined as using.
OOP
Cascading destructions of objects with static storage duration
The result of assigning to partially overlapping objects
Recursively re-entering a function during the initialization of its static objects
Making virtual function calls to pure virtual functions of an object from its constructor or destructor
Referring to nonstatic members of objects that have not been constructed or have already been destructed
Source file and Preprocessing
A non-empty source file that doesn't end with a newline, or ends with a backslash (prior to C++11)
A backslash followed by a character that is not part of the specified escape codes in a character or string constant (this is implementation-defined in C++11).
Exceeding implementation limits (number of nested blocks, number of functions in a program, available stack space ...)
Preprocessor numeric values that can't be represented by a long int
Preprocessing directive on the left side of a function-like macro definition
Dynamically generating the defined token in a #if expression
To be classified
Calling exit during the destruction of a program with static storage duration
A basic understanding of the various environmental limits. The full list is in section 5.2.4.1 of the C specification. Here are a few;
I was actually a bit surprised at the limit of 1023 case labels for a switch statement, I can forsee that being exceeded for generated code/lex/parsers fairly easially.
If these limits are exceeded, you have undefined behavior (crashes, security flaws, etc...).
Right, I know this is from the C specification, but C++ shares these basic supports.
The only type for which C++ guarantees a size is
char
. And the size is 1. The size of all other types is platform dependent.Using
memcpy
to copy between overlapping memory regions. For example:The behavior is undefined according to the C Standard, which is subsumed by the C++03 Standard.
7.21.2.1 The memcpy function
7.21.2.2 The memmove function
Variables may only be updated once in an expression (technically once between sequence points).
The order that function parameters are evaluated is unspecified behavior. (This won't make your program crash, explode, or order pizza... unlike undefined behavior.)
The only requirement is that all parameters must be fully evaluated before the function is called.
This:
Can be equivalent to this:
Or this:
It can be either; it's up to the compiler. The result can matter, depending on the side effects.
Pointer
NULL
pointermemcpy
to copy overlapping buffers.Buffer overflows
Integer Overflows
int64_t i = 1; i <<= 72
is undefined)Types, Cast and Const
int i; i++; cout << i;
)volatile
orsig_atomic_t
at the receipt of a signalFunction and Template
OOP
Source file and Preprocessing
long int
#if
expressionTo be classified