我試圖寫「現代」堆棧(帶有任何類型的數據)並且一次出錯。這是使用指針調用的函數的不正確參數數量。但是這在程序運行時不會造成任何問題。C:函數指針
所以這是測試的例子,工作絕對正確。
#include <stdio.h>
int add(int a1, int a2)
{
return a1 + a2;
}
int main(void)
{
int (*pointer)() = add;
printf("12 + 13 = %d\n", pointer(12, 13, 123, 13, 21,3, 125, 234, 523));
printf("12 + 14 = %d\n", pointer(12, 14, 123, 13, 21,3, 125, 234, 523));
printf("12 + 15 = %d\n", pointer(12, 15, 123, 13, 21,3, 125, 234, 523));
printf("12 + 16 = %d\n", pointer(12, 16, 123, 13, 21,3, 125, 234, 523));
printf("12 + 17 = %d\n", pointer(12, 17, 123, 13, 21,3, 125, 234, 523));
printf("12 + 18 = %d\n", pointer(12, 18, 123, 13, 21,3, 125, 234, 523));
printf("12 + 19 = %d\n", pointer(12, 19, 123, 13, 21,3, 125, 234, 523));
return 0;
}
據我瞭解,然後調用add函數,9個參數推入調用堆棧。但函數add()只使用其中的兩個。 爲什麼這樣的多次調用沒有像程序崩潰一樣的效果? (OS:在FreeBSD 9.1)
增加: 我改變代碼:
printf("12 + 13 = %d\n", pointer(12));
printf("12 + 13 = %d\n", pointer(13));
...
編譯標誌:(版本4.6)-Wall -O4 tst_call.c GCC不產生警告,但輸出不正確:
$ gcc -Wall -O4 tst_call.c
$ ./a.out
12 + 13 = -10236
12 + 14 = 12615693
12 + 15 = 12615694
12 + 16 = 12615695
12 + 17 = 12615696
12 + 18 = 12615697
12 + 19 = 12615698
gcc49(版本4.9)產生警告列表(警告: 'A2' 被用來在這個函數[-Wuninitialized]未初始化)。這裏輸出:
$ gcc49 -Wall -O4 tst_call.c
$ ./a.out
12 + 13 = 12
12 + 14 = 13
12 + 15 = 14
12 + 16 = 15
12 + 17 = 16
12 + 18 = 17
12 + 19 = 18
因爲C編譯器真的是寬容的,僅次於網頁瀏覽器 – UmNyobe
「所以這是一個測試示例,它的工作原理絕對正確。」 - 不完全針對每個編譯器:gnu g ++編譯器報告OP代碼的錯誤。 –
gun g ++是'C++'編譯器 – UmNyobe