C语言经典问题摘录.pdf

C语言经典问题摘录.pdf

ID:52429815

大小:119.72 KB

页数:7页

时间:2020-03-27

C语言经典问题摘录.pdf_第1页
C语言经典问题摘录.pdf_第2页
C语言经典问题摘录.pdf_第3页
C语言经典问题摘录.pdf_第4页
C语言经典问题摘录.pdf_第5页
资源描述:

《C语言经典问题摘录.pdf》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、C语言经典问答摘录1.这样的初始化有什么问题?char*p=malloc(10);编译器提示“非法初始式”云云。答:这个声明是静态或非局部变量吗?函数调用只能出现在自动变量(即局部非静态变量)的初始式中。因为静态变量的地址必须在编译的过程中就确定下来而malloc()申请的内存地址是在运行时确定的。2.*p++自增p还是p所指向的变量?答:后缀++和--操作符本质上比前缀一目操作的优先级高,因此*p++和*(p++)等价,它自增p并返回p自增之前所指向的值。要自增p指向的值,使用(*p)++,如果副作用的顺序无关紧要也可以使用++*p。3我有一个char*型指针正巧指向一些int型变

2、量,我想跳过它们。为什么如下的代码((int*)p)++;不行?答:在C语言中,类型转换意味着“把这些二进制位看作另一种类型,并作相应的对待”;这是一个转换操作符,根据定义它只能生成一个右值(rvalue)。而右值既不能赋值,也不能用++自增。(如果编译器支持这样的扩展,那要么是一个错误,要么是有意作出的非标准扩展。)要达到你的目的可以用:p=(char*)((int*)p+1);或者,因为p是char*型,直接用p+=sizeof(int);4.空指针和未初始化的指针是一回事吗?答:空指针在概念上不同于未初始化的指针:空指针可以确保不指向任何对象或函数;而未初始化指针则可能指向任何

3、地方。5.我可以用0来表示空指针吗?答:根据语言定义,在指针上下文中的常数0会在编译时转换为空指针。也就是说,在初始化、赋值或比较的时候,如果一边是指针类型的值或表达式,编译器可以确定另一边的常数0为空指针并生成正确的空指针值。因此下边的代码段完全合法:char*p=0;if(p!=0)然而,传入函数的参数不一定被当作指针环境,因而编译器可能不能识别未加修饰的0“表示”指针。在函数调用的上下文中生成空指针需要明确的类型转换,强制把0看作指针。例如,Unix系统调用execl接受变长的以空指针结束的字符指针参数。它应该如下正确调用:execl("/bin/sh","sh","-c","

4、date",(char*)0);如果省略最后一个参数的(char*)转换,则编译器无从知道这是一个空指针,从而当作一个0传入。(注意很多Unix手册在这个例子上都弄错了。)摘要:==========================

5、=============================

6、

7、可以使用未加修饰的0

8、需要显示的类型转换

9、

10、

11、

12、------------------------

13、---------------------------

14、

15、

16、

17、*初始化

18、*函数调用,作用域内无原型

19、

20、

21、

22、*赋值

23、*变参函数调用中的可变参数

24、

25、

26、

27、*比较

28、

29、

30、

31、

32、*固定参数的函数调用

33、

34、

35、

36、

37、且在

38、作用域内有原型

39、

40、

41、==========================

42、=============================有两条简单规则你必须遵循:1)当你在源码中需要空指针常数时,用“0”或“NULL”。2)如果在函数调用中“0”或“NULL”用作参数,把它转换成被调函数需要的指针类型6.既然数组引用会蜕化为指针,如果arr是数组,那么arr和&arr又有什么区别呢?答:区别在于类型:在标准C中,&arr生成一个“T型数组”的指针,指向整个数组。在所有的C编译器中,对数组的简单引用(不包括&操作符)生成一个T的指针类型的指针,指向数组的第一成。7.我如何声明一个数组指针?

43、答:通常,你不需要。当人们随便提到数组指针的时候,他们通常想的是指向它的第一个元素的指针。考虑使用指向数组某个元素的指针,而不是数组的指针。类型T的数组蜕变成类型T的指针,这很方便;在结果的指针上使用下标或增量就可以访问数组中单独的成员。而真正的数组指针,在使用下标或增量时,会跳过整个数组,通常只在操作数组的数组时有用——如果还有一点用的话。如果你真的需要声明指向整个数组的指针,使用类似“int(*ap)[N];”这样的声明。其中N是数组的大小。如果数组的大小未知,原则上可以省略N,但是这样生成的类型,“指向大小未知的数组的指针”,毫无用处。8.当我向一个接受指针的指针的函数传入二维

44、数组的时候,编译器报错了,这是怎么回事?答:数组蜕化为指针的规则不能递归应用。数组的数组(即C语言中的二维数组)蜕化为数组的指针,而不是指针的指针。数组指针常常令人困惑,需要小心对待;如果你向函数传递二位数组:intarray[NROWS][NCOLUMNS];f(array);那么函数的声明必须匹配:voidf(inta[][NCOLUMNS]){...}或者voidf(int(*ap)[NCOLUMNS])/*ap是个数组指针*/{...}在第一个声明

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。