文思海辉 2021 技术岗面试题

小编:管理员 64阅读 2021.10.10

第1题:

在C++程序中调用被C编译器编译后的函数,为什么要加extern “C” 



 函数经过编译系统的翻译成汇编,函数名对应着汇编标号。 

 因为C编译函数名与得到的汇编代号基本一样,如:fun()=>_fun, main=>_main 

 但是C++中函数名与得到的汇编代号有比较大的差别。 

 如:由于函数重载,函数名一样,但汇编代号绝对不能一样。 

 为了区分,编译器会把函数名和参数类型合在一起作为汇编代号, 

 这样就解决了重载问题。具体如何把函数名和参数类型合在一起, 

 要看编译器的帮助说明了。 

 这样一来,如果C++调用C,如fun(),则调用名就不是C的翻译结果_fun, 

 而是带有参数信息的一个名字,因此就不能调用到fun(),为了解决 

 这个问题,加上extern "C"表示该函数的调用规则是C的规则,则调用 

 时就不使用C++规则的带有参数信息的名字,而是_fun,从而达到调用 

 C  函数的目的。 



第2题:

关联、聚合以及组合的区别 



关联:指的是模型元素之间的一种语义联系,是类之间的一种很弱的联系。关联可以有方向,可以是单向关联,也可以是双向关联。可以给关联加上关联名来描述关联的作用。关联两端的类也可以以某种角色参与关联,角色可以具有多重性,表示可以有多少个对象参与关联。可以通过关联类进一步描述关联的属性、操作以及其他信息。关联类通过一条虚线与关联连接。对于关联可以加上一些约束,以加强关联的含义。
  关联在C++中呈现为: 

 class A{...} 
   class B{ ...}
 A::Function1(B &b) //或A::Function1(B b) //或A::Function1(B *b) 

 即一个类作为另一个类方法的参数。 

 聚合:指的是整体与部分的关系。通常在定义一个整体类后,再去分析这个整体类的组成结构。从而找出一些组成类,该整体类和组成类之间就形成了聚合关系。例如一个航母编队包括海空母舰、驱护舰艇、舰载飞机及核动力攻击潜艇等。需求描述中“包含”、“组成”、“分为叢糠?”等词常意味着聚合关系。 

 组合:也表示类之间整体和部分的关系,但是组合关系中部分和整体具有统一的生存期。一旦整体对象不存在,部分对象也将不存在。部分对象与整体对象之间具有共生死的关系。 

 聚合和组合的区别在于:聚合关系是“has-a”关系,组合关系是“contains-a”关系;聚合关系表示整体与部分的关系比较弱,而组合比较强;聚合关系中代表部分事物的对象与代表聚合事物的对象的生存期无关,一旦删除了聚合对象不一定就删除了代表部分事物的对象。组合中一旦删除了组合对象,同时也就删除了代表部分事物的对象。 

 我们用浅显的例子来说明聚合和组合的区别。“国破家亡”,国灭了,家自然也没有了,“国”和“家”显然也是组合关系。而相反的,计算机和它的外设之间就是聚合关系,因为它们之间的关系相对松散,计算机没了,外设还可以独立存在,还可以接在别的计算机上。在聚合关系中,部分可以独立于聚合而存在,部分的所有权也可以由几个聚合来共享,比如打印机就可以在办公室内被广大同事共用。 

 在C++语言中,从实现的角度讲,聚合可以表示为: 

 class A {...} 
   class B { A* a; .....} 

 即类B包含类A的指针; 

 而组合可表示为: 

 class A{...} 
   class B{ A a; ...} 

 即类B包含类A的对象。 

 关联和聚合的区别主要在语义上,关联的两个对象之间一般是平等的,例如你是我的朋友,聚合则一般不是平等的,例如一个公司包含了很多员工,其实现上是差不多的。聚合和组合的区别则在语义和实现上都有差别,组合的两个对象之间其生命期有很大的关联,被组合的对象是在组合对象创建的同时或者创建之后创建,在组合对象销毁之前销毁。一般来说被组合对象不能脱离组合对象独立存在,而且也只能属于一个组合对象,例如一个文档的版本,必须依赖于文档的存在,也只能属于一个文档。聚合则不一样,被聚合的对象可以属于多个聚合对象,例如一个员工可能可以属于多个公司。 



第3题:

 面向对象的三个特征,并简述之。 



第4题:

 什么时候使用“常引用” 



 如果既要利用引用提高程序的效率,又要保护传递给函数的数据不在函数中被改变,就应使用常引用。 



第5题:

 static  有什么用途? 



 ①限制变量的作用域; 

 ②设置变量的存储域; 



第6题:

改错题 

 Void GetMemory  (  char *buf,int size  ) 

 { 

        if(buf != NULL ) free( buf ); 

        buf = (char *) malloc ( size ); 

 } 




 Int main(int argc, char *argv  ) 

 { 

        char * buf; 

        GetMemory( buf , 10); 

        printf(“%s”,buf); 

        free(buf); 

        if(buf != NULL) 

 { 

        Printf(“%s”,buf); 

 } 

 return 1; 

 } 



第7题:

 已知string类定义如下,写出类的成员函数实现。 

 Class String 

 { 

 Public  : 

        String  (  const char *str = NULL  )  ; 

        String ( const String &another ); 

        ~String(); 

        String & operater = (const String &rhs); 

 Private: 

        Char *m_data; 

 } 



第8题:

 写一个双向链表的插入和删除操作 



第9题:

 线性表a , b 为两个有序升序的线性表,编写一程序,使两个有序线性表合并成一个有序升序线性表h 


关联标签: