1、对于如下程序:

[csharp] view plaincopy
  1. #include  <iostream>
  2. using namespace std;
  3. class A
  4. {
  5. public:
  6. A()
  7. {
  8. cout<<"A"<<endl;
  9. }
  10. };
  11. int  main(void)
  12. {
  13. A a[4], b,*p;
  14. }

会输出多少个A?(   C   )

A、2                   B、3                        C、5                            D、6

p只是一个对象指针,并没有指向一个对象的内存空间,所以没有调用构造函数。

2、头文件中的 ifndef/define/endif 有什么作用?
答:防止该头文件被重复引用,避免变量、类型等被重新定义。

3、const 有什么用途?(请至少说明两种)

答:(1)可以定义 const 常量。
(2)const可以修饰函数的参数、返回值,甚至函数的定义体。被const修饰的东西都受到强制保护,可以预防意外的变动,能提高程序的健壮性。
4、如下的字符串函数,用于生存一个字符串 ”连接号码异常” ,并返回它的指针

[cpp] view plaincopy
  1. char* strfun()
  2. {
  3. char str[20];
  4. strcpy(str, “连接号码异常”);
  5. printf(“%s \n”, str);             //printf语句1
  6. return str;
  7. }
  8. void main()
  9. {
  10. char *pstr = strfun();
  11. printf("%s \n", pstr);            //printf语句2
  12. }

问题1 : printf语句1和printf语句2哪个能在屏幕上正在打印出来?

问题2 : 如果不能正常在屏幕上打印出字符串,请说明原因。

问题3 : 如果不修改strfun的声明,请问该如何修改上述程序的错误。

答:

问题1:语句1可以正常打印,语句2不能正常打印;

问题2:语句2使用的指针所指向的内存空间str[20],在函数strfun返回时已经被释放了;

问题3:可以将函数strfun中的语句char str[20];改为char *str = new char[20];

5、下面是交换两个double型数据的函数,

[cpp] view plaincopy
  1. void swap( double* p1, double* p2 )
  2. {
  3. double *p;
  4. *p = *p1;
  5. *p1 = *p2;
  6. *p2 = *p;
  7. }
  8. void main()
  9. {
  10. double a = 0.1;
  11. double b = 0.2;
  12. swap( &a, &b );
  13. }

请找出上述代码的错误,指出错误的原因,并改正。

答:函数swap中混淆了double型指针与double型变量的差别,对于一个未初始化的指针访问其内存空间是非常危险的。对swap函数修改如下:

[cpp] view plaincopy
  1. void swap( double* p1, double* p2 )
  2. {
  3. double p;
  4. p = *p1;
  5. *p1 = *p2;
  6. *p2 =p;
  7. }

6、在电信业务的后台处理程序中,经常会涉及到处理字符串,除了用char *处理字符串之外,C++还为我们提供了封装了的字符串类string,其本质也是用一个动态数组来保存字符串,类String的原型为:

[cpp] view plaincopy
  1. class String
  2. {
  3. public:
  4. String(const char *str = NULL); // 普通构造函数
  5. String(const String &other);        // 拷贝构造函数
  6. ~String(void);                      // 析构函数
  7. String & operate =(const String &other);    // 赋值函数
  8. private:
  9. char *m_data;               // 用于保存字符串
  10. };

请编写String的上述4个函数普通构造函数、拷贝构造函数、析构函数和赋值函数。

代码如下:

[cpp] view plaincopy
  1. class String
  2. {
  3. private:
  4. char *m_data;                 //私有成员,保存字符串
  5. public:
  6. String(const char *str = NULL);       //普通构造函数
  7. String(const String &other);          //复制构造函数
  8. ~String(void);                        //析构函数
  9. String & operator =(const String &other);      //赋值函数
  10. };
  11. String::String(const char *str = NULL)    //带一个指针的普通构造函数
  12. {
  13. if(str == NULL)
  14. {
  15. m_data = new char[1];    //分配一个字节
  16. assert(m_data != NULL);
  17. *m_data = '\0';
  18. }
  19. else
  20. {
  21. m_data = new char[strlen(str)+1];    //分配空间容纳str内容
  22. assert(m_data != NULL);
  23. strcpy(m_data,str);
  24. }
  25. }
  26. String::String(const String &other)     //拷贝构造函数
  27. {
  28. m_data = new char[strlen(other.m_data)+1];
  29. assert(m_data != NULL);
  30. strcpy(m_data,other.m_data);
  31. }
  32. String::~String(void)            //析构函数
  33. {
  34. if(m_data != NULL)
  35. {
  36. delete []m_data;
  37. m_data = NULL;
  38. }
  39. }
  40. String & String::operator=(const String &other)     //赋值函数
  41. {
  42. if(&other == this)            //如果对象与other是同一个对象
  43. return *this;
  44. delete []m_data;       //释放堆内存
  45. m_data = new char[strlen(other.m_data)+1];
  46. assert(m_data != NULL);
  47. strcpy(m_data,other.m_data);
  48. return *this;
  49. }

亚信联创2011.9.17招聘会笔试题相关推荐

  1. 亚信联创2011 9 17招聘会笔试题

    分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow 也欢迎大家转载本篇文章.分享知识,造福人民,实现我们中华民族伟大复兴! 1.对于 ...

  2. 【转】亚信联创2011.9.17招聘会笔试题 .

    http://blog.csdn.net/hackbuteer1/article/details/6823272 1.对于如下程序: view plaincopy to clipboardprint? ...

  3. 阿里云2011.9.17招聘会笔试题

    1. 堆和栈的区别? 答:1.栈区(stack)-   由编译器自动分配释放   ,存放函数的参数值,局部变量的值等.其操作方式类似于数据结构中的栈.         2.堆区(heap) 一般由程序 ...

  4. 网新恒天2011 9 21招聘会笔试题

    1.下列哪种数据类型不能用作switch的表达式变量(C) A.byte         B.char         C.long       D.enum 2.在图采用邻接表存储时,求最小生成树的 ...

  5. 网新恒天2011.9.21招聘会笔试题

    1.下列哪种数据类型不能用作switch的表达式变量(C) A.byte         B.char         C.long       D.enum 2.在图采用邻接表存储时,求最小生成树的 ...

  6. 亚新联创 2011.9.17招聘会笔试题目

    1.对于如下程序 #include <iostream> using namespace std; class A { public:A(){cout<<"A&quo ...

  7. 亚信科技2019届实习生招聘笔试题(前端)

    亚信来我们学校宣讲,让我们做了笔试题,我选择了前端方向,下面是我的试题整理还有我的答案(不一定正确)以及知识点整理,如果有错误请大神们指正.这份笔试题涉及到了HTML CSS JavaScript j ...

  8. 腾讯校园招聘会笔试题 难题解析

    1. 数据存储在磁盘上的排列方式会影响I/O服务的性能,一个圆环的磁道上有10个物理块,10个数据记录R1------R10存放在这个磁道上,记录的安排顺序如下表所示: 物理块 1 2 3 4 5 6 ...

  9. 腾讯2011.10.15校园招聘会笔试题

    转载请标明出处,原文地址:http://blog.csdn.net/hackbuteer1/article/details/6878287 1.下面的排序算法中,初始数据集的排列顺序对算法的性能无影响 ...

最新文章

  1. 误入人体的海洋细菌,能轻易吞噬你的肢体乃至生命
  2. 云南昆明:看猪展迎猪年
  3. 如何获取python的当前工作目录-python如何获取当前工程根目录
  4. UVa12326 Yummy Triangular Pizza(dfs)
  5. 微软发布 SQL Server 2019 新版本
  6. 前端学习(1851)vue之电商管理系统电商系统vue创建项目
  7. 42 MM配置-采购-条件-定义工厂层的条件控制
  8. win10开移动热点让手机使用上网
  9. JSON Schema
  10. python初学入门——————输入输出语句
  11. cad2010多个文件并排显示_CAD软件同时显示两张或多张图纸的方法
  12. 地铁应急指挥系统解决方案
  13. Selenium使用之——键盘操作方法
  14. 【JZOJ A组】【NOIP2019模拟】最短路(tiring)
  15. 360浏览器html文件无图标,360浏览器在网页的右键里不显示审查元素怎么了
  16. 兆骑科创创新创业服务平台,海内外高层次人才引进,活动赛事
  17. Blender游戏开发教程
  18. 空间三点定圆的解算过程
  19. 自制的MATLAB拼图游戏GUI界面版详解(下篇)
  20. TCP-实现英译汉服务器客户端(多进程/多线程)

热门文章

  1. 这是一趟豪华的 Android 列车,就问你上不上?
  2. 中文版Winflash
  3. X60的BIOS白名单-黑苹果之路
  4. 快速刷入recovery的方法
  5. 高度塌陷问题及解决方法
  6. PL/0编译程序的简单实现
  7. 2023年河北医科大学流行病学考研经验分享
  8. API接口,亲测有效
  9. [从零开始学习FPGA编程-44]:视野篇 - 集成电路助力数字化时代高质量发展-1-集成电路芯片主要形态
  10. kafka学习bolg