1、下面的程序並不見得會輸出 hello-std-out,你知道為什麼嗎?
#include<stdio.h>
#include<unistd.h>
intmain()
{
while(1)
{
fprintf(stdout,"hello-std-out");
fprintf(stderr,"hello-std-err");
sleep(1);
}
return 0;
}
參考答案:stdout和stderr是不是同設備描述符。stdout是塊設備,stderr則不是。對於塊設備,只有當下面幾種情況下才會被輸入,1)遇到回車,2)緩沖區滿,3)flush被調用。而stderr則不會。
2、下面,我們再來看一個交叉編譯的事情,下面的兩個文件可以編譯通過嗎?如果可以通過,結果是什麼?
file1.c
int arr[80];
file2.c
externint *arr;
intmain()
{
arr[1] = 100;
printf("%d\n", arr[1]);
return 0;
}
參考答案:該程序可以編譯通過,但運行時會出錯。為什麼呢?原因是,在另一個文件中用 extern int *arr來外部聲明一個數組並不能得到實際的期望值,因為他們的類型並不匹配。所以導致指針實際並沒有指向那個數組。注意:一個指向數組的指針,並不等於一個數組。修改:extern int arr[]。(參考:ISO C語言 6.5.4.2 節)
3、請說出下面的程序輸出是多少?並解釋為什麼?(注意,該程序並不會輸出 “b is 20″)
#include<stdio.h>
intmain()
{
int a=1;
switch(a)
{
int b=20;
case 1:
printf("b is %d\n",b);
break;
default:
printf("b is %d\n",b);
break;
}
return 0;
}
參考答案:該程序在編譯時,可能會出現一條warning: unreachable code at beginning ofswitch statement。我們以為進入switch後,變量b會被初始化,其實並不然,因為switch-case語句會把變量b的初始化直接就跳過了。所以,程序會輸出一個隨機的內存值。
4、請問下面的程序輸出什麼?
#include<stdio.h>
intmain()
{
int i;
i = 10;
printf("i : %d\n",i);
printf("sizeof(i++) is:%d\n",sizeof(i++));
printf("i : %d\n",i);
return 0;
}
參考答案:如果你覺得輸出分別是,10,4,11,那麼你就錯了,錯在了第三個,第一個是10沒有什麼問題,第二個是4,也沒有什麼問題,因為是32位機上一個int有4個字節。但是第三個為什麼輸出的不是11呢?居然還是10?原因是,sizeof不是一個函數,是一個操作符,其求i++的類型的size,這是一件可以在程序運行前(編譯時)完全的事情,所以,sizeof(i++)直接就被4給取代了,在運行時也就不會有了i++這個表達式。
5.請問下面的程序輸出是什麼?(絕對不是10)
#include
#definePrintInt(expr) printf("%s : %dn",#expr,(expr))
intmain()
{
int y = 100;
int *p;
p = malloc(sizeof(int));
*p = 10;
y = y/*p; /*dividing y by *p */;
PrintInt(y);
return 0;
}
參考答案:本題輸出的是100。為什麼呢?問題就出在 y = y/*p;上了,我們本來想的是 y / (*p) ,然而,我們沒有加入空格和括號,結果y/*p中的 /*被解釋成了注釋的開始。於是,這也是整個惡夢的開始。
6.請問下面的程序輸出什麼?(假設:輸入Hello, World)
#include<stdio.h>
intmain()
{
char dummy[80];
printf("Enter a string:\n");
scanf("%[^r]",dummy);
printf("%s\n",dummy);
return 0;
}