C++ :类 和 对象 ※重点※(一)

简介: C++ :类 和 对象 ※重点※

默认成员函数:

  默认成员函数分为6种,他们都是如果我们不写,编译器会自动生成的函数,如果写了,编译器就不会生成了

ec4779b4f58e43eabdac71f59c5670c4.png前面四个是非常重要的,后面两个用得不多


构造函数:

  我们在平常写一个类得时候,就怕我们没有给他进行初始化,我们再去访问就是随机值了,怎么解决这种不确定性呢,这个时候我们得默认构造函数就出来了


构造函数的特性:

构造函数是一种特殊的成员函数,构造函数的主要任务不是去创建对象,而是去初始化对象。

  1. 函数名与类名相同。
  2. 没有返回值。
  3. 对象实例化的时候会自动调用构造函数
  4. 可以重载


这些是构造函数的特性,来看看他写出来是什么样吧:

class stu
{
public:
  stu()
  {
    _a = 10;
    _c = 'A';
    _b = 20;
  }
  stu(int a, char c, int b)
  {
    _a = a;
    _c = c;
    _b = b;
  }
  void test1()
  {
    cout << _a << "-" << _c << "-" << _b << endl;
  }
private:
  int _a;
  char _c;
  int _b;
};

  这里就是一个重载,构造函数的参数也是可以加缺省值的,建议呢是全部都加上缺省值,这样也可以防止传参的时候写错而出些错误(注意给缺省值的顺序是从右往左给的)


如果你想调用一个不用传参的构造函数,定义的时候应该是这样的:

class stu
{
public:
  stu()
  {
    _a = 10;
    _c = 'A';
    _b = 20;
  }
  stu(int a, char c, int b)
  {
    _a = a;
    _c = c;
    _b = b;
  }
  void test1()
  {
    cout << _a << "-" << _c << "-" << _b << endl;
  }
private:
  int _a;
  char _c;
  int _b;
};
int main()
{
  stu s1;
  stu s3(4, 'C', 40);
}

  大家看见没有,这里是不需要加括号的,加上括号反而会出错,编译器会认为你定义那里并没有定义出一个对象,无法区分是一个函数的声明还是对象的定义;传参的时候也是在对象的后面直接传参的。


 还有一个小小的细节:我们的全缺省的构造函数和自己写的无参的构造函数不要同时存在,虽说他们在语法上,不使用这个类,是可以编译通过的,但是一旦我们使用,用这个类定义一个不传参的对象,这就会报错了,因为两个构造函数都是可以不用传参可以直接调用的,编译器这个时候就不知道用哪个了,然后就报错了

所以我平常写的时候,如果有需要,都是定义为全缺省的,既方便也不容易出错


内置、自定义类型?

我们要学习默认构造函数,就要知道内置类型和自定义类型,内置类型就是我们平常经常用的那些类型,自定义类型顾名思义就是我们自己定义的类型

我们编译器默认生成的构造函数对内置类型不做处理,对于自定义类型会去调用它的构造函数:

class date
{
public:
    date()
    {
        _a=100;
    }
private:
    int _a;
};
class stu
{
public:
  void print()
  {
    cout << _a << "-" << _c << "-" << _b << endl;
  }
private:
  int _a;
  char _c;
  int _b;
    date a1;
};
int main()
{
  stu s3
}

8551fc52690e425c9550318aeb72880c.png

 对于初始化是区分化处理的,我的内置类型得不到初始化除非自己显示得去写,大家有没有觉得挺奇怪的呢?所以有了一个这样的总结:

  如果一个类中的成员全是自定义类型,我们就用自己默认生成的就够了,有内置成员、或者要显示传参,就要自己写了。


对于这种处理方式呢,后面在c++11里面给了一个解决办法就是这样:

class date
{
public:
    date()
    {
        _a=100;
    }
private:
    int _a;
};
class stu
{
public:
  void print()
  {
    cout << _a << "-" << _c << "-" << _b << endl;
  }
private:
  int _a = 10;
  char _c = 'A';
  int _b = 20;
    date a1;
};
int main()
{
  stu s3
}

这里给的不是一个赋值,这里依旧只是声明,我们给的值是一个缺省值,是给我们构造函数的初始化列表使用的,如果我们我自己写了构造函数,并给内置类型赋值了,就不会用这些给的缺省值了,大家学到后面初始化列表就知道怎么回事了


 构造函数的小细节:

一:

我们自己写的构造函数对于自定义类型也是会处理的

93665f1d9cc145159d242016a8c28f64.png


二:  

  注意:无参的构造函数和全缺省的构造函数也是可以叫做默认构造函数的(他们和编译器默认生成的都是不需要传参的),但是默认构造函数只能有一个且必须有一个(也可以是半缺省)六大成员函数包括编译器自动生成的默认构造,我们上面说过无参的和全缺省的不能写在一起报错就是这样的:

04dba9843d2e4040b38afceecf31bfb3.png


三:

   没有默认构造可用的情况就是这样的:

class stu
{
public:
  stu(int a ,char c='A',int b=20)
  {
    _a = a;
    _c = c;
    _b = b;
  }
  void print()
  {
    cout << _a << "-" << _c << "-" << _b << endl;
  }
private:
  int _a;
  char _c;
  int _b;
};
int main()
{
  stu s1;
}

 这里就是编译器因为你自己写了,就没有生成默认的,但是你自己写的,你也没用,就报错了!!!

luck++
+关注
目录
打赏
0
0
0
0
0
分享
相关文章
【C++篇】深度解析类与对象(下)
在上一篇博客中,我们学习了C++的基础类与对象概念,包括类的定义、对象的使用和构造函数的作用。在这一篇,我们将深入探讨C++类的一些重要特性,如构造函数的高级用法、类型转换、static成员、友元、内部类、匿名对象,以及对象拷贝优化等。这些内容可以帮助你更好地理解和应用面向对象编程的核心理念,提升代码的健壮性、灵活性和可维护性。
c++模板初阶----函数模板与类模板
class 类模板名private://类内成员声明class Apublic:A(T val):a(val){}private:T a;return 0;运行结果:注意:类模板中的成员函数若是放在类外定义时,需要加模板参数列表。return 0;
44 0
c++的类(附含explicit关键字,友元,内部类)
本文介绍了C++中类的核心概念与用法,涵盖封装、继承、多态三大特性。重点讲解了类的定义(`class`与`struct`)、访问限定符(`private`、`public`、`protected`)、类的作用域及成员函数的声明与定义分离。同时深入探讨了类的大小计算、`this`指针、默认成员函数(构造函数、析构函数、拷贝构造、赋值重载)以及运算符重载等内容。 文章还详细分析了`explicit`关键字的作用、静态成员(变量与函数)、友元(友元函数与友元类)的概念及其使用场景,并简要介绍了内部类的特性。
111 0
【c++11】c++11新特性(上)(列表初始化、右值引用和移动语义、类的新默认成员函数、lambda表达式)
C++11为C++带来了革命性变化,引入了列表初始化、右值引用、移动语义、类的新默认成员函数和lambda表达式等特性。列表初始化统一了对象初始化方式,initializer_list简化了容器多元素初始化;右值引用和移动语义优化了资源管理,减少拷贝开销;类新增移动构造和移动赋值函数提升性能;lambda表达式提供匿名函数对象,增强代码简洁性和灵活性。这些特性共同推动了现代C++编程的发展,提升了开发效率与程序性能。
114 12
【C++进阶】特殊类设计 && 单例模式
通过对特殊类设计和单例模式的深入探讨,我们可以更好地设计和实现复杂的C++程序。特殊类设计提高了代码的安全性和可维护性,而单例模式则确保类的唯一实例性和全局访问性。理解并掌握这些高级设计技巧,对于提升C++编程水平至关重要。
98 16
类和对象(中 )C++
本文详细讲解了C++中的默认成员函数,包括构造函数、析构函数、拷贝构造函数、赋值运算符重载和取地址运算符重载等内容。重点分析了各函数的特点、使用场景及相互关系,如构造函数的主要任务是初始化对象,而非创建空间;析构函数用于清理资源;拷贝构造与赋值运算符的区别在于前者用于创建新对象,后者用于已存在的对象赋值。同时,文章还探讨了运算符重载的规则及其应用场景,并通过实例加深理解。最后强调,若类中存在资源管理,需显式定义拷贝构造和赋值运算符以避免浅拷贝问题。
类和对象(上)(C++)
本篇内容主要讲解了C++中类的相关知识,包括类的定义、实例化及this指针的作用。详细说明了类的定义格式、成员函数默认为inline、访问限定符(public、protected、private)的使用规则,以及class与struct的区别。同时分析了类实例化的概念,对象大小的计算规则和内存对齐原则。最后介绍了this指针的工作机制,解释了成员函数如何通过隐含的this指针区分不同对象的数据。这些知识点帮助我们更好地理解C++中类的封装性和对象的实现原理。
|
4月前
|
【c++】继承(继承的定义格式、赋值兼容转换、多继承、派生类默认成员函数规则、继承与友元、继承与静态成员)
本文深入探讨了C++中的继承机制,作为面向对象编程(OOP)的核心特性之一。继承通过允许派生类扩展基类的属性和方法,极大促进了代码复用,增强了代码的可维护性和可扩展性。文章详细介绍了继承的基本概念、定义格式、继承方式(public、protected、private)、赋值兼容转换、作用域问题、默认成员函数规则、继承与友元、静态成员、多继承及菱形继承问题,并对比了继承与组合的优缺点。最后总结指出,虽然继承提高了代码灵活性和复用率,但也带来了耦合度高的问题,建议在“has-a”和“is-a”关系同时存在时优先使用组合。
235 6
类和对象(下)C++
本内容主要讲解C++中的初始化列表、类型转换、静态成员、友元、内部类、匿名对象及对象拷贝时的编译器优化。初始化列表用于成员变量定义初始化,尤其对引用、const及无默认构造函数的类类型变量至关重要。类型转换中,`explicit`可禁用隐式转换。静态成员属类而非对象,受访问限定符约束。内部类是独立类,可增强封装性。匿名对象生命周期短,常用于临时场景。编译器会优化对象拷贝以提高效率。最后,鼓励大家通过重复练习提升技能!
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问