C&C++面试题之五(每次10题)

本文详细解释了结构与联合的概念及区别,通过实例演示了联合在C语言中的使用方法,并介绍了字符串复制函数的实现过程,此外还涉及了面向对象的三大特征、UML中的关联、聚合与组合的区别等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 结构与联合有和区别?
    • 结构和联合都是由多个不同的数据类型成员组成, 但在任何同一时刻, 联合中只存放了一个被选中的成员(所有成员共用一块地址空间), 而结构的所有成员都存在(不同成员的存放地址不同)
    • 对于联合的不同成员赋值, 将会对其它成员重写, 原来成员的值就不存在了, 而对于结构的不同成员赋值是互不影响的
  2. 求关于“联合”的题目的输出?
    • #include <stdio.h>
      union
      {
          int i;
          char x[2];
      }a; 

      void main()
      {
          a.x[0] = 10;
          a.x[1] = 1;
          printf("%d",a.i);
      }
    • 答案:266 (低位低地址,高位高地址,内存占用情况是Ox010A)
  3. 求下面代码的输出
    • main()
      {
          union
          { 
               int i;
               struct
               { 
                    char first;
                    char second;
                }half; number;
          }
          number.i=0x4241; 
          printf("%c%c/n", number.half.first, mumber.half.second);
          number.half.first='a'; 
          number.half.second='b';
          printf("%x/n", number.i);
          getch();
      }
    • 答案:AB (0x41对应'A',是低位;Ox42对应'B',是高位) ;6261 (number.i和number.half共用一块地址空间)
  4. 已知strcpy的函数原型:char *strcpy(char *strDest, const char *strSrc)其中strDest 是目的字符串,strSrc 是源字符串。不调用C++/C 的字符串库函数,请编写函数 strcpy。
    • char *strcpy(char *strDest, const char *strSrc)
      {
          if ( strDest == NULL || strSrc == NULL)
              return NULL ;
          if ( strDest == strSrc)
              return strDest ;
          char *tempptr = strDest ;
          while( (*strDest++ = *strSrc++) != ‘/0’);
          return tempptr ;
      }
  5. 已知String类定义如下,请尝试写出类的成员函数的实现
    • class String
      {
      public:
          String(const char *str = NULL); // 通用构造函数
          String(const String &another); // 拷贝构造函数
          ~ String(); // 析构函数
          String & operater =(const String &rhs); // 赋值函数
      private:
          char *m_data; // 用于保存字符串
      };
    • 答案:
      • String::String(const char *str)
        {
            if ( str == NULL ) //strlen在参数为NULL时会抛异常才会有这步判断
            {
                m_data = new char[1] ;
                m_data[0] = '/0' ;
            }
            else
            {
                m_data = new char[strlen(str) + 1];
                strcpy(m_data,str);
            }
        }

        String::String(const String &another)
        {
            m_data = new char[strlen(another.m_data) + 1];
            strcpy(m_data,other.m_data);
        }

        String& String::operator =(const String &rhs)
        {
            if ( this == &rhs)
                 return *this ;
            delete []m_data; //删除原来的数据,新开一块内存
            m_data = new char[strlen(rhs.m_data) + 1];
            strcpy(m_data,rhs.m_data);
            return *this ;
        }

        String::~String()
        {
            delete []m_data ;
        }
  6. .h头文件中的ifndef/define/endif 的作用?
    • 防止该头文件被重复引用。
  7. #include<file.h> 与 #include "file.h"的区别?
    • 前者是从Standard Library的路径寻找和引用file.h,而后者是从当前工作路径搜寻并引用file.h。
  8. UML中的关联、聚合(Aggregation)以及组合(Composition)的区别?

    • 关联:表示两个类的一般性联系,比如“学生”和“老师”就是一种关联关系
    • 聚合:表示has-a的关系,是一种相对松散的关系,聚合类不需要对被聚合类负责,用空的菱形表示聚合关系: 例如class A {...} class B { A* a; .....}
    • 组合:表示contains-a的关系,关联性强于聚合:组合类与被组合类有相同的生命周期,组合类要对被组合类负责,采用实心的菱形表示组合关系: class A{...} class B{ A a; ...}
  9. 面向对象的三个基本特征,并简单叙述之?
    • 封装:将客观事物抽象成类,每个类对自身的数据和方法实行protection(private, protected,public)
    • 继承:广义的继承有三种实现形式:实现继承(指使用基类的属性和方法而无需额外编码的能力)、可视继承(子窗体使用父窗体的外观和实现代 码)、接口继承(仅使用属性和方法,实现滞后到子类实现)。前两种(类继承)和后一种(对象组合=>接口继承以及纯虚函数)构成了功能复用的两种方式。
    • 多态:是将父对象设置成为和一个或更多的他的子对象相等的技术,赋值之后,父对象就可以根据当前赋值给它的子对象的特性以不同的方式运作。简单的说,就是一句话:允许将子类类型的指针赋值给父类类型的指针,父类型在执行的时候调用子类型中跟父类型同时实现了的相同的函数
  10. 重载(overload)和重写(overried,有的书也叫做“覆盖”)的区别?
    • 定义
      • 重载:是指允许存在多个同名函数,而这些函数的参数表不同(或许参数个数不同,或许参数类型不同,或许两者都不同)。
      • 重写:是指子类重新定义复类虚函数的方法。
    • 实现原理
      • 重载:编译器根据函数不同的参数表,对同名函数的名称做修饰,然后这些同名函数就成了不同的函数(至少对于编译器来说是这样的)。如,有两个同名函数:function func(p:integer):integer;和function func(p:string):integer;。那么 编译器做过修饰后的函数名称可能是这样的:int_func、str_func。对于这两个函数的调用,在编译器间就已经确定了,是静态的。也就是说,它 们的地址在编译期就绑定了(早绑定),因此,重载和多态无关!
      • 重写:和多态真正相关。当子类重新定义了父类的虚函数后,父类指针根据赋给它的不同的子类指针,动态的调用属于子类的该函数,这样的函数调用在编译期间是无法确定的(调用的子类的虚函数的地址无法给出)。因此,这样的函数地址是在运行期绑定的(晚绑定)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值