2017年9月計算機二級c語言基礎(chǔ)試題
程序設(shè)計是給出解決特定問題程序的過程,是 軟件構(gòu)造活動中的重要組成部分。下面是小編收集的關(guān)于計算機二級c語言基礎(chǔ)試題,希望大家認真閱讀!
1.下面的代碼輸出什么?為什么?
void foo(void)
{
unsigned int a = 6;
int b = -20;
(a+b > 6)?puts(“>6”):puts(“<=6”);
}
答案:輸出值”>6”
解析:a+b在這里做了隱式的轉(zhuǎn)換,把int轉(zhuǎn)化為unsigned int.編譯器會把b當做一個很大的正數(shù).
2.下面的代碼有什么問題,為什么?
void foo(void)
{
char string[10], str1[10];
int i;
for (i = 0; i < 10; i++) {
str1[i] = 'a';
}
strcpy(string, str1);
printf("%s\n", string);
}
答案:運行到strcpy的時候可能會產(chǎn)生內(nèi)存異常
解析:吟哦日str1沒有\(zhòng)0結(jié)束標志,所以數(shù)組后面存儲的可能不是\0,而是隨機數(shù)據(jù),對于strcpy和printf這種需要\0判斷字符串結(jié)束的函數(shù)來說,出錯是必然的了.
道理雖是如此,但是這段代碼我在windows和Linux下測試的結(jié)果不一樣,Linux下可以正常輸出10個a,windows下會出錯,使用的.都是gcc的編譯器.
3.下面的代碼,i和j的值分別是多少?為什么?
static int j;
int k = 0;
void fun1(void)
{
static int i = 0;
i++;
}
void fun2(void)
{
j = 0;
j++;
}
int main(void)
{
for (k = 0; k < 10; k++) {
fun1();
fun2();
}
return 0;
}
答案:i=10,j=1
解析:由于被static修飾的局部變量存儲在靜態(tài)區(qū)內(nèi),所以即使這個函數(shù)運行結(jié)束,這個靜態(tài)變量還是不會被銷毀,函數(shù)下次運行時還能使用這個值,靜態(tài)變量只被初始化一次,函數(shù)下次運行會直接跳過初始化,進行++操作.而j每次都被賦0.
4.下面的代碼里,假設(shè)在32位系統(tǒng)下,各sizeof計算得結(jié)果分別是多少?
int *p = NULL;
sizeof(p)的值是
sizeof(*p)的值是
int a[100];
sizeof(a)的值是
sizeof(a[100])的值是
sizeof(&a)的值是
sizeof(&a[0])的值是
int b[100];
void fun(int b[100])
{
sizeof(b);
}
sizeof(b)的值是
答案:4,4,400,4,4,4,4
解析:沒什么好說的吧
5.下面代碼的結(jié)果是多少?為什么?
int main(void)
{
char a[1000];
int i;
for (i = 0; i < 1000; i++)
a[i] = -1-i;
printf("%d", strlen(a));
return 0;
}
答案:255
解析:基本上算是個”輪回”的問題,strlen遇到a[i]=0的時候就終止了,現(xiàn)在的問題變成循環(huán)多少次a[i]=0了,那么就使用補碼來計算到底多少次之后char會溢出為0,我的回答是一個輪回,也就是256次,那么strlen不包含0的位置,那么長度就是255了.
【2017年9月計算機二級c語言基礎(chǔ)試題】相關(guān)文章:
2017年9月計算機二級c語言試題06-17
2017年9月計算機二級c語言考試試題基礎(chǔ)版06-20
2017年9月計算機二級C語言模式試題06-05
2017年9月計算機二級c語言筆試試題06-17
2017年9月計算機二級c語言檢測試題06-17
2017年9月計算機二級c語言筆試題庫06-17
計算機二級c語言考試試題基礎(chǔ)版08-26