- 0
- 0
- 约3.24万字
- 约 45页
- 2026-01-31 发布于山东
- 举报
2026年c语言考试题库100道
第一部分单选题(100题)
1、已知数组`intarr[]={10,20,30,40};`,指针`p=arr;`,执行`p+=2;`后,`*p`的值是?
A.10
B.20
C.30
D.40
【答案】:C
解析:本题考察数组与指针的关系。数组名`arr`等价于首元素地址`arr[0]`,指针`p`初始指向`arr[0]`。`p+=2`表示指针向后移动2个`int`类型的大小(即跳过2个元素),此时`p`指向`arr[2]`。`*p`表示解引用指针,即获取`arr[2]`的值,为30。选项A错误(指向`arr[0]`),选项B错误(指向`arr[1]`),选项D错误(指向`arr[3]`)。
2、在C语言中,变量`a`的`sizeof`值为多少?`inta=10;`
A.4
B.1
C.2
D.8
【答案】:A
解析:本题考察`sizeof`运算符的使用。`sizeof`用于计算数据类型或变量占用的字节数,`a`是`int`类型变量,在大多数C语言实现中(如32/64位系统),`int`类型占用4字节,因此`sizeof(a)`的值为4。错误选项B(1字节)对应`char`类型,C(2字节)对应`short`类型,D(8字节)对应`longlong`类型,均不符合`int`的大小。
3、以下关于C语言函数参数传递方式的描述,正确的是?
A.数组名作为函数参数时,实参是数组的首地址,属于地址传递
B.指针作为函数参数时,实参是指针的地址,属于地址传递
C.结构体作为函数参数时,默认通过指针传递(地址传递)
D.值传递时,形参修改会直接影响实参的值
【答案】:A
解析:A选项正确,数组名作为函数参数时退化为指向数组首元素的指针,传递的是数组首地址,属于地址传递(本质是值传递,但值为地址)。B选项错误,指针作为参数传递时,传递的是指针变量的值(即地址),仍属于值传递。C选项错误,结构体默认通过值传递(形参是实参的拷贝),需显式传递指针才是地址传递。D选项错误,值传递中形参是实参的拷贝,修改形参不会影响实参。
4、以下代码运行后,输出结果是?
#includestdio.h
voidfun(intarr[]){
printf(%d,%d,sizeof(arr),sizeof(*arr));
}
intmain(){
inta[10];
fun(a);
return0;
}
A.4,4
B.8,4
C.10,4
D.10,40
【答案】:B
解析:本题考察数组名作为函数参数的行为。C语言中数组名作为函数参数时会退化为指针,此时sizeof(arr)计算的是指针的大小(64位系统中为8字节),而sizeof(*arr)等价于sizeof(int)(4字节)。因此,输出结果为8,4,选项B正确;选项A错误(32位系统指针大小为4字节,但题目未明确系统,通常默认64位),选项C和D错误(数组名退化为指针后,sizeof(arr)不再表示数组元素个数10)。
5、执行语句inta=5;printf(%d,a+++++a);输出结果是多少?
A.11
B.12
C.10
D.13
【答案】:A
解析:表达式中a++为后置自增运算符,先使用当前值(5)再自增;++a为前置自增运算符,先自增(a从5变为6)再使用。因此a++的值为5,++a的值为6,两者相加5+6=11。其他选项错误原因:B选项错误认为后置自增后值为6;C选项错误忽略了前置自增的作用;D选项错误叠加了两次自增。
6、关于C语言函数参数传递的描述,正确的是?
A.函数参数传递时,实参的值会复制一份传给形参,修改形参不影响实参(值传递)
B.函数参数传递时,形参是实参的引用,修改形参会直接修改实参(引用传递)
C.C语言中所有参数都是按引用传递的,通过指针可修改实参
D.数组作为函数参数时,是按值传递的,即传递数组的整个拷贝
【答案】:A
解析:本题考察函数参数传递机制。C语言仅支持值传递,实参值复制给形参,修改形参不影响实参,因此A正确。B错误,C语言无引用传递,形参是实参的副本。C错误,C语言所有参数均为值传递,指针传递本质是传递地址值。D错误,数组作为参数传递的是首地址,而非整个数组拷贝。
7、以下关于C语言结构体的描述,错误的是?
A.使用typedef定义结构体类型时,可简化为:typedefstruct{inta;}MyStruct;
B.结构体成员默认是私有的(private),不能被外部函数直接访问
C.结构体指针作为函数参数传递时,若修改指针指向的内容,会影响原
原创力文档

文档评论(0)