7 11牛客題(賦值 運算子優先順序)

2022-08-01 14:51:16 字數 1084 閱讀 7668

對以下程式,正確的輸出結果是(d) 123

4567

891011

1213

14#include

#define sub(x,y) x-y

#define access_before(element,offset,value) *sub(&element, offset) = value

intmain() ;

inti;

access_before(array[5], 4, 6);

printf("array: ");

for(i = 0; i < 10; ++i)

printf("\n");

return(0);

}

a array: 1 6 3 4 5 6 7 8 9 10

b array: 6 2 3 4 5 6 7 8 9 10

c 程式可以正確編譯連線,但是執行時會崩潰

d 程式語法錯誤,編譯不成功

分析:本題主要是考察巨集定義的替換,巨集替換在預編譯階段進行,不進行語法的檢查,當進行替換時,access_before(array[5],4,6)被替換成*(&array[5])-4=6 顯然這是不正確的,

在賦值表示式中,左值必須是乙個可修改的記憶體塊,而上述式子的左值是乙個字面值常量,這是編譯不能通過的。

運算子優先順序參考部落格:

運算子優先順序 C 運算子優先順序

c 運算子優先順序 優先順序運算子 描述方向1 scope resolution 範圍解析 left to right 2 suffix postfix increment and decrement 字首 字尾遞增和遞減 function call 函式呼叫 array subscripting ...

運算子優先順序 Python 運算子優先順序

python 運算子優先順序 運算子描述 lambda lambda表示式 or布林 或 and布林 與 not x 布林 非 in,not in 成員測試 is,is not 同一性測試 比較 按位或 按位異或 按位與 移位 加法與減法 乘法 除法與取餘 x,x 正負號 x 按位翻轉 指數 x.a...

運算子優先順序 PHP運算子優先順序

php運算子優先順序 結合方向 運算子附加資訊 非結合clone new clone 和 new左 array 非結合 遞增 遞減運算子 非結合 int float string array object bool 型別非結合 instanceof 型別右結合 邏輯操作符 左 算術運算子 左 算術運...