Edit

Share via


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.

Remarks

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's equivalent to:

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

which isn't likely to be what the programmer intended.

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

Code analysis name: MISPARENTHESIZED_CASTS

Example

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 ...
}