c++面试题1.docVIP

  1. 1、本文档共56页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
c面试题1

1,关于动态申请内存 答:内存分配方式三种: (1)从静态存储区域分配:内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在。 全局变量,static变量。 (2)在栈上创建:在执行函数时,函数内局部变量的存储单元都可以在栈上创建, 函数执行结束时这些存储单元自动被释放。 栈内存分配运算内置于处理器的指令集中,效率很高,但是分配的内存容量有限。 (3)用malloc或new申请内存之后,应该立即检查指针值是否为NULL.防止使用指针值为NULL的内存, 不要忘记为数组和动态内存赋初值。防止将未被初始化的内存作为右值使用。避免数组或指针的下标越界, 特别要当心发生“多1”或者“少1”操作。动态内存的申请与释放必须配对,防止内存泄漏。 用free或delete释放了内存之后,立即将指针设置为NULL,防止产生“野指针”。从堆上分配,亦称动态内存分配。 程序在运行的时候用malloc或new申请任意多少的内存,程序员自己负责在何时用free或delete释放内存。 动态内存的生存期由程序员决定,使用非常灵活。(int *pArray;???int MyArray[6];????pArray = MyArray[0];) 如果在申请动态内存时找不到足够大的内存块,malloc和new将返回NULL指针, 判断指针是否为NULL,如果是则马上用return语句终止本函数, 或者马上用exit(1)终止整个程序的运行,为new和malloc设置异常处理函数。 ? 2,C++指针攻破 答案:指针是一个变量,专门存放内存地址,特点是能访问所指向的内存 ? 指针本身占据了4个字节的长度 int **ptr; //指针的类型是 int ** int (*ptr)[3]; //指针的类型是 int(*)[3]? int *(*ptr)[4]; //指针的类型是 int *(*)[4]? ?ptr++:指针ptr的值加上了sizeof(int) ptr+=5:将指针ptr的值加上5*sizeof(int) ? 指针的赋值: 把一个变量的地址赋予指向相同数据类型的指针变量( int a;???int *ip;???ip=a; ) 把一个指针变量的值赋予指向相同类型变量的另一个指针变量(int a;??int *pa=a;??int *pb;???pb=pa; ) 把数组的首地址赋予指向数组的指针变量(int a[5],*pa;??pa=a;???也可写为:pa=a[0];) ? 如果给指针加1或减1 ,实际上是加上或减去指针所指向的数据类型大小。 当给指针加上一个整数值或减去一个整数值时,表达式返回一个新地址。 相同类型的两个指针可以相减,减后返回的整数代表两个地址间该类型的实例个数。 ? int ** cc=new (int*)[10]; 声明一个10个元素的数组,数组每个元素都是一个int *指针, 每个元素还可以单独申请空间,因为cc的类型是int*型的指针,所以你要在堆里申请的话就要用int *来申请; ???int ** a= new int * [2];     //申请两个int * 型的空间 ???a[0] = new int[4];        ////为a的第一个元素申请了4个int 型空间,a[0] 指向了此空间的首地址处 ???a[1] = new int[3];        //为a的第二个元素又申请了3个int 型空间,a[1]指向了此空间首地址处 ? 指针数组初始化赋值: 一维指针开辟空间:char *str;int *arr;????scanf(%d,N); str=(char*)malloc(sizeof(char)*N); arr=(int*)malloc(sizeof(int)*N); 二维指针开辟空间:int **arr,??????i;??????????scanf(%d%d,row,col); arr=(int**)malloc(sizeof(int)*row); for(i=0;irow;i++) ???arr[i]=(int*)malloc(sizeof(int)*col); ? 结构体指针数组,例如typedef struct{???char x;???int??y; }Quan,*QQuan; 定义一个结构体指针数组如:QQuan a[MAX]? for(i=0;iMAX;i++) { ????a[i]=(QQuan)malloc(sizeof(Quan)); ????memset(a[i],0,sizeof(Quan)); } 指针数组赋值 ?float a[]={100,200,300,400,500}; float??*p[5]={a[0],a[1],a[2],a[3],a[

您可能关注的文档

文档评论(0)

cuotian + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档