刷题总结(6)
1、有以下程序
#include <stdio.h> main() { int x; for( x=3; x<6; x++ ) printf( (x%2 ) ? ("*%d") :("#%d"),x); printf("\n"); }
则程序的输出结果是(3#45)
分析:
(1)x=3,3%2=1
为真,所以执行*%d
,即*3
(2)X=4,4%2=0
为假,所以执行#%d
,即#4
(3)X=5,5%2=1
为真,所以执行*%d
,即*5
(4)X=6
,不满足条件,继续执行,所以最后结果为*3#4*5
2、在以下给出的表达式中,与 do--while(E)
语句中的(E)
不等价的表达式是(E==0)
。
分析:
一直执行do
,当满足while
条件的时候;
或者说,执行完之后,检查while是否满足条件,满足则继续执行;
3、若言int a[10],*p=a;
则以下表示中不能代表a[6]
的是p+6
。
分析:P
是指整形数组a的一个指针(首地址),p+6
也只是a[6]
的地址而已,本身还是一个指针。
4、已知fun(int)
是类Test
的公有成员函数,p
是指向成员函数fun()
的指针,采用p=&Test::fun
是正确的。
5、在C程序中,可把整型数以二进制形式存放到文件中的函数是(fwrite
函数)。
【知识拓展】fprintf
函数只能以字符串的形式写入到文件中;fread
函数则是从文件中读数据,而不是写数据;fputc
函数是以字符的形式写到文件中;fwrite
函数则是将某数以其机器数的形式写入到文件中。故选择答案是C。
6、设x、y、t
均为int
型变量,则执行语句:t=3; x=y=2; t=x++||++y;
后,变量t
和y
的值分别为t=1 y=2
分析:x++||++y
执行后的结果是真,即1
,然后赋值给t
。因为是或运算,所以在判断x++
是真后,后面的++y
就不再执行了,所以y
值没有变还是
2```。
注意!||和&&存在一个短路规则,他们都是从左向右计算,但||只要左边为真,右边便不会计算,然后返回真,&&只要左边为假,右边便不再计算返回假。
7、若有struct student char name[20];float score;stu;
则以下赋值正确的是(C)。
A. student=96
B.stu=96
C.score=96
D.stu.score=96_
分析:
考察的是对结构体内的变量定义进行初始化赋值。student
是结构体标签,为了区分不同结构体而取的唯一标识,没有赋值功能。所以A错误。stu
是结构体的变量,通过变量结构体内部成员定义初始化或访问结构体内部定义的值,即stu.score
的方式。所以B错误。stu.score
是float
类型,赋值了96_
,类型不匹配。所以D错误。
8、关于#import
和#include
描述正确的是#import
是#include
的替代指令,防止重复引用。
【知识拓展】
在Objective-C
中,#import
被当成#include
指令的改良版本来使用。除此之外,#import
确定一个文件只能被导入一次,这使你在递归包含中不会出现问题。
一般来说,在导入Objective-C
头文件的时候使用#import
,包含C
头文件时使用#include
。#import
比起#include
的好处就是不会引起交叉编译。
实例说明:三个文件:文件A.h
文件B.h
文件C.h
, 文件C.h
需要引入A.h、B.h
,文件B.h
需要引入文件A.h
,这样就重复引用了A.h
两次,使用#import
可以进行优化。
9、保护成员可以在定义它的类中使用,也可以在派生类中使用,保护类就是为了继承产生的;普通 构造函数 能够被 隐式调用 。而explicit 构造函数 只能被显式调用。
10、在C++中,数据封装可以由struct关键字提供;数据封装以后,仍然可以不通过使用函数就能直接存取数据。