c++网络编程面试题.docxVIP

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

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

文档评论(0)

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

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

1亿VIP精品文档

相关文档