對以下程式,正確的輸出結果是(d) 123
4567
891011
1213
14#include
#define sub(x,y) x-y
#define access_before(element,offset,value) *sub(&element, offset) = value
int
main() ;
int
i;
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 型別右結合 邏輯操作符 左 算術運算子 左 算術運...