Export (0) Print
Expand All
This topic has not yet been rated - Rate this topic

C6268

warning C6268: Incorrect order of operations: (<TYPE1>)(<TYPE2>)x + y. Possible missing parentheses in (<TYPE1>)((<TYPE2>)x + y)

This warning indicates that a complex cast expression might involve a precedence problem when performing pointer arithmetic. Because casts group more closely than binary operators, the result might not be what the programmer intended. In some cases, this defect causes incorrect behavior or a program crash.

In an expression such as:

(char *)p + offset

the offset is interpreted as an offset in characters; however, an expression such as:

(int *)(char *)p + offset

is equivalent to:

((int *)(char *)p) + offset

and so the offset is interpreted as an offset in integers. In other words, it is equivalent to:

(int *)((char *)p + (offset * sizeof(int)))

which is not likely to be what the programmer intended.

Depending on the relative sizes of the two types, this can lead to a buffer overrun.

The following code generates this warning:

void f(int *p, int offset_in_bytes)
{
    int *ptr;
    ptr = (int *)(char *)p + offset_in_bytes;
    // code ...
}

To correct this warning, use the following code:

void f(int *p, int offset_in_bytes)
{
    int *ptr;
    ptr = (int *)((char *)p + offset_in_bytes);
    // code ...
}
Did you find this helpful?
(1500 characters remaining)
Thank you for your feedback

Community Additions

ADD
Show:
© 2014 Microsoft. All rights reserved.