首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C++】构造函数调用规则 ( 默认构造函数 | 默认无参构造函数 | 默认拷贝构造函数 | 构造函数调用规则说明 )

一、默认构造函数 C++ 类中 2 种特殊的构造函数 , 分别是 : 默认无参构造函数 : 如果 C++ 类中 没有定义构造函数 , C++ 编译器会自动为该类提供一个 " 默认的无参构造函数 " ,...没有为 C++ 类定义 构造函数 , C++ 编译器 将自动为该类 生成一个默认的无参构造函数 ; 定义了构造函数 : 如果为 C++ 类 定义了其他类型的构造函数 ( 有参构造函数 / 无参构造函数...; 创建一个类对象 并将其 赋值给 另一个类对象时 , 会自动调用 默认拷贝构造函数 ; 如果 C++ 类中 没有定义拷贝构造函数 , C++ 编译器会自动为该类提供一个 " 默认的拷贝构造函数 " ,...& other) { x = other.x; } }; 下面的代码 , 第一行代码会自动调用默认的无参构造函数 , 第二行代码会自动调用默认的拷贝构造函数 ; MyClass...obj; // 调用默认无参构造函数 MyClass obj2 = obj; // 调用默认拷贝构造函数 二、构造函数调用规则 ---- 1、构造函数规则说明 构造函数调用规则 : 提供 默认无参构造函数

1K30

C语言 | 函数调用

C语言函数调用的形式 一般形式 函数名(实参表列) 函数调用语句 把函数调用单独作为一个语句。 函数参数 函数调用作为另一个函数调用时的实参。 调用函数并不一定要求包括分号。...只有作为函数调用语句才需要有分号。如果作为函数表达式或函数参数,函数调用本身是不必有分号的。 C语言函数调用时的数据传递 在调用有参函数时,主调函数和被调函数之间有数据传递关系。...C语言函数调用的过程 在定义函数中指定的形参,在未出现函数调用时,它们并不是占内存中的存储单元。 将实参对应的值传递给形参。 通过return语句将函数值带回到主调函数调用结束,形参单元被释放。...C语言函数调用案例 #include//头文件 int maxNumber(int num1,int num2);//函数声明 int main()//主函数 {   int num1...100道C语言源码案例请去公众号:C语言入门到精通

3.3K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    7.2 C语言调用函数

    01函数调用的形式 1、一般形式 函数名(实参表列) 2、函数调用语句 把函数调用单独作为一个语句,如c=max(a,b),max(a,b)是一次函数调用,它是赋值表达式中的一部分。...3、函数参数 函数调用作为另一个函数调用时的实参。 4、调用函数并不一定要求包括分号,只有作为函数调用语句才需要有分号。如果作为函数表达式或函数参数,函数调用本身是不必有分号的。...02 函数调用时的数据传递 1、在调用有参函数时,主调函数和被调函数之间有数据传递关系。...03 函数调用的过程 1、在定义函数中指定的形参,在未出现函数调用时,它们并不是占内存中的存储单元。 2、将实参对应的值传递给形参。 3、通过return语句将函数值带回到主调函数。...3、在定义函数时指定的函数类型一般应该和return语句中的表达式类型一致。 4、函数类型决定返回值类型。 C语言 | 求1+2+...100的和 更多案例可以go公众号:C语言入门到精通

    2.4K3027

    C++】构造函数意义 ( 构造函数显式调用与隐式调用 | 构造函数替代方案 - 初始化函数 | 初始化函数缺陷 | 默认构造函数 )

    一、构造函数意义 1、类的构造函数 C++ 提供的 构造函数 和 析构函数 作为 类实例对象的 初始化 和 销毁 方案 ; 定义一个类的 若干 实例对象 , 每个对象都有独立的 成员属性 ; 当 定义...类的 实例对象时 , C++ 编译器 会自动调用 开发者定义的 构造函数 ; 2、构造函数显式调用与隐式调用 类 的 构造函数 可以 自动调用 , 也可以手动调用 ; 一般 默认的 无参构造函数 是 自动地...由 C++ 编译器默认提供 ; 默认构造函数 分为 2 种类型 : 默认无参构造函数 : 如果 类 中没有定义 构造函数 , C++ 编译器 会默认提供一个 无参构造函数 , 该构造函数函数体为空...; 默认拷贝构造函数 : 如果 类 中没有定义 拷贝构造函数 , C++ 编译器 会默认定义一个 默认拷贝构造函数 , 该函数的作用是进行简单的成员变量赋值 ; 6、代码示例 - 初始化函数无法及时调用..., C++ 编译器 会提供一个 默认构造函数 // Student 类 没有提供拷贝构造函数 , C++ 编译器 会提供一个 默认拷贝构造函数 Student s; // 调用初始化函数 s.init

    73620

    C语言函数调用约定

    C语言默认调用约定,参数通过从右向左的顺序压栈,调用函数恢复堆栈 1265: ff 75 fc push DWORD PTR [ebp-0x4...是从左到右入栈还是从右到左入栈; [参数弹出方式]:函数调用后,由谁来把栈恢复原状? 函数调用结束后需要将压入栈中的参数全部弹出,以使得栈在函数调用前后保持一致。...这个弹出的工作可以由调用方来完成,也可以由被调用方来完成。 [函数名修饰方式]:函数名在编译时会被修改,调用惯例可以决定如何修改函数名。...函数调用惯例在函数声明和函数定义时都可以指定,语法格式为: ‌返回值类型 调用惯例 函数名(函数参数) int __cdecl max(int m, int n); // __cdecl是C语言默认的调用约定...函数的第一个和第二个DWORD参数通过ecx和edx传递,剩下的参数按照从右到左的顺序入栈 cdecl: C语言默认,变参函数 由于每次函数调用都要由编译器产生还原栈的代码,所以使用 __cdecl

    18010

    C++构造函数 | 构造函数

    C++构造函数的作用 C++提供了构造函数来处理对象的初始化,构造函数是一 种特殊的成员函数,与其他成员函数不同,不需要程序员来调用它,而是在建立对象时自动执行。...构造函数的名字必须与类名同名,而不能由程序员任意命 ,以便编译系统能识别它并把它作为构造函数处理,构造函数不具有任何类型,不返回任何值,它的功能是由程序员定义,程序员根据初始化的要求设计函数体和函数参数...关于构造函数,以下5点需要读者注意:  在类对象进入其作用域时调用构造函数构造函数没有返回值,不需要在定义构造函数时声明类型。 构造函数不需要程序员调用,也不能被程序员调用。...如果用户自己没有定义构造函数,则C++编译系统会自动生成一个构造函数,只是这个构造函数函数体是空的,也没有参数,不执行初始化操作。...以上,如果你看了觉得对你有所帮助,就给小林点个赞叭,这样小林也有更新下去的动力,跪谢各位父老乡亲啦~ C++构造函数 | 构造函数 更多案例可以go公众号:C语言入门到精通

    2.2K74

    C++】构造函数初始化列表 ④ ( 构造函数 和 析构函数 调用顺序分析 )

    初始化 , 所有的构造函数都要进行初始化操作 ; 一、构造函数 和 析构函数 调用顺序 说明 1、构造函数调用顺序 在一个类 C 中 , 嵌套了 A 和 B 两个类类型的 对象 作为 成员变量 ; 构造函数的...调用顺序如下 : 先调用 被嵌套类 A 和 B 的构造函数 , 再调用外部 C 类的构造函数 ; A 和 B 构造函数 , 成员变量 中 谁先声明 , 就先调用谁的 构造函数 ; 注意 : A...和 B 在 构造函数 初始化列表 中的顺序 , 与先调用谁的构造函数无关 ; 2、析构函数调用顺序 析构函数调用顺序 与 构造函数调用顺序相反 , 直接 将 构造函数 调用顺序 倒序排列即可 ; 3、...A -> B -> C 类的构造函数 ; 执行 // 调用 C 的拷贝构造函数 C c2 = c; 代码时 , 先执行 A -> B 的构造函数 , 然后执行 C 的拷贝构造函数 ; 2、代码示例...的有参构造函数 // 其中 构造函数中的参数 作为 参数列表 中的参数值 C c(10, 10, 150, 18, 180); // 调用 C 的拷贝构造函数 C c2 = c; //

    31620

    函数调用堆栈图-c语言

    我们就使用一个简单的c语言程序来对描述一下在函数调用的时候都发生了什么。 ?...中间的一小段没有意义的汇编语言是为了方便设置断点,为后面的调试做好铺垫,因为有时会碰到找不到断点位置的情况,使用这个方法,可以在找不到断点的时候向后执行一次,而不破坏我们想调试的程序当前的堆栈状态,这里对...此时的堆栈是没有发生变化的,现在开始到了函数调用的关键阶段了。...然后让esp减去了0c0h位,开始提升堆栈了,为程序的运行开辟一个存储空间,这个区域也就是平时所说的缓冲区,因为一个单元是四个字节,c0也就是往上提了48个格,由于位置有限中间依旧省略,此时堆栈就变成了如下的样子...还有另一种方式是使用内平栈的方式,即在函数内部就将堆栈恢复平衡,使用ret 8的方式。 再往后面的操作就是main函数的堆栈平衡的处理了,与上面的函数调用类似,就不提了。

    2.7K10

    C++】构造函数初始化列表 ⑤ ( 匿名对象 生命周期 | 构造函数 中 不能调用 构造函数 )

    中传入的 参数 ; 类初始化时 , 根据定义顺序 , 先调用 成员变量的 构造函数 , 然后调用外部类构造函数 , 析构函数正好相反 ; 实例对象 的 const 成员变量 必须只能在 初始化列表 中进行...初始化 , 所有的构造函数都要进行初始化操作 ; 构造函数 中 不能调用 构造函数 ; 一、匿名对象 生命周期 1、匿名对象 生命周期 说明 调用 类名(构造函数参数) 创建的是 匿名对象 ; 匿名对象...二、构造函数调用 构造函数 ---- 1、构造函数 中 不能调用 构造函数 构造函数调用 构造函数 是危险行为 ; 构造函数调用 构造函数 , 并不会为本对象进行初始化操作 ; 构造函数调用方式...执行 Student 的构造函数" << endl; } 然后 , 在无参的 构造函数中 , 调用 有参构造函数 ; // 构造函数调用 构造函数 是危险行为 Student() { /...endl; } // 构造函数调用 构造函数 是危险行为 Student() { // 构造函数调用构造函数 // 此时 创建 的是匿名对象 // 如果 匿名对象 没有被接收

    21020

    C++】构造函数与析构函数概念简介 ( 构造函数和析构函数引入 | 构造函数定义与调用 | 析构函数定义与调用 | 代码示例 )

    一、构造函数和析构函数引入 在 C++ 语言中 , 创建对象时 , 需要进行对象创建的初始化工作 , 如 : 创建集合数组 , 为成员变量设置初始值 ; 在 C++ 头文件中 , 声明类的时候 , 不能对类的成员变量设置初始值..." 构造函数 " 是 C++ 类中的一种特殊的 " 成员函数 " , 该函数不需要用户手动调用 , 而是在 C++ 类 实例对象 创建时 , 自动执行的 ; " 析构函数 " 是 构造函数 的 对应相反的函数...名称 与 类名相同 ; 构造函数参数 : 构造函数 可以有 若干参数 , 也可以没有参数 ; 构造函数返回值 : 构造函数 没有返回值 ; 2、构造函数调用 构造函数调用 : 自动调用 : C++ 编译器会...在创建 C++ 类实例对象时 , 自动调用类的 构造函数 ; 手动调用 : 构造函数 也可以手动调用 , 如调用构造函数的重载函数 ; 3、代码示例 - 构造函数定义与调用 定义了一个 C++ 类 Student...; 析构函数返回值 : 析构函数 没有返回值 ; 2、析构函数调用 析构函数调用 : 自动调用 : C++ 编译器会 在销毁 C++ 类实例对象时 , 自动调用类的 析构函数 ; 3、代码示例 - 析构函数定义与调用

    31320

    C++】构造函数分类 ① ( 构造函数分类简介 | 无参构造函数 | 有参构造函数 | 拷贝构造函数 | 代码示例 - 三种类型构造函数定义与调用 )

    一、构造函数分类 1、构造函数分类简介 C++ 构造函数可以分为以下几类 : 无参构造函数 : 最简单也是默认的构造函数 , 函数没有参数 , 如果创建一个对象 , 没有传入参数 , 调用的就是该类型的...< endl; } 下面的代码 , 是自动调用无参构造函数 , 创建 实例对象 的方法 ; // 调用无参构造函数 Student s1; // 打印 Student s1 实例对象值 cout...参数中 , 传递进来 , 并在 构造函数 中 , 为 成员变量 赋值具体的值 ; 此处需要注意的是 , 这里传入的是 C 语言中的字符串 , 也就是 char * 类型的指针 , 传入后拷贝字符串时..." << endl; } 下面的代码 , 使用了 2 种方法 , 手动调用了 有参构造函数 ; // 调用有参构造函数 Student s2 = Student(18, "Tom"); // 打印 Student..." << endl; } 二、代码示例 - 三种类型构造函数定义与调用 ---- 在下面的代码中 , 分别在 Student 类中定义了 无参构造函数 有参构造函数 拷贝构造函数 分别调用了上述三种类型的

    37910

    C语言函数调用详解】——传值调用&传址调用

    num1,num2的目的,我们看看结果是什么样的: 因此,传值调用,要想在函数内部交换两个变量的值,是不可行的。...这里就需要传址调用。 二.传址调用 那什么是传址调用呢?这里的“址”指的是地址。 传址调用是把函数外部创建变量的内存地址传递给函数参数的一种调用函数的方式。...这种传参方式可以让函数函数外边的变量建立起真正的联系,也就是函数内部可以直接操作函数外部的变量。...那现在我们用传址调用的方法对上面的函数重新进行实现: #include //正确的版本 void Swap2(int* px, int* py) { int tmp = 0; tmp...以上就是对函数调用的两种方式,传值调用和传址调用的介绍,欢迎大家指正,我们一起进步!!!

    62910

    C++不要在构造函数和析构函数调用函数

    虽然可以对虚函数进行实调用,但程序员编写虚函数的本意应该是实现动态联编。在构造函数调用函数函数的入口地址是在编译时静态确定的,并未实现虚调用。...但是为什么在构造函数调用函数,实际上没有发生动态联编呢? 1. 不要在构造函数调用函数的原因 第一个原因,在概念上,构造函数的工作是为对象进行初始化。...当创建某个派生类的对象时,如果在它的基类的构造函数调用函数,那么此时派生类的构造函数并未执行,所调用函数可能操作还没有被初始化的成员,浙江导致灾难的发生。...在Visual C++中,包含虚函数的类对象的虚指针被安排在对象的起始地址处,并且虚函数表(vtable)的地址是由构造函数写入虚指针的。...---- 参考文献 [1]陈刚.C++高级进阶教程[M].武汉:武汉大学出版社,2008[8.6(P299-P302)]

    3.6K30

    C语言函数调用-学习十七

    max(a,b); 按函数调用在程序中出现的形式和位置来分, 可以有以下3种函数调用方式: 1.函数调用语句 把函数调用单独作为一个语句。...如: printf_star(); 这时不要求函数带回值,只要求函数完成一定的操作。 2.函数表达式 函数调用出现在另一个表达式中。如:c=max(a,b); 这时要求函数带回一个确定的值。...3.函数参数 函数调用作为另一函数调用时的实参。如:m=max(a,max(b,c)); 其中 max(b,c) 是一次函数调用,它的值作为max另一次调用的实参。...C语言规定,实参变量对形参变量的数据传递是“值传递”,即单向传递,只由实参传给形参,而不能由形参传回来给实参。 在内存中,实参单元与形参单元是不同的单元。...add(a, b); printf("结果:%f\n", c); } 如果已经在文件的开头( 所有函数之前),对本文中所调用函数进行了声明,则在各函数中不必对其所调 用的函数再作声明。

    2.2K30

    C++】构造函数分类 ③ ( 调用有参构造函数的方法 | 括号法 | 等号法 )

    一、在不同的内存中创建类的实例对象 在上一篇博客 【C++】构造函数分类 ② ( 在不同的内存中创建类的实例对象 | 栈内存中创建实例对象 | new 关键字创建对象 ) 中 , 分析了 在 栈内存 和...堆内存 中创建对象 的 两种情况 ; 本篇博客中 , 继续分析 , 栈内存中调用 有参构造函数的 两种方法 : 括号法 等号法 C++ 类成员变量为 : public: int m_age; char...有参构造函数 , 并将创建的 实例对象 赋值给 s5 变量 , 这是 C++ 对 = 等号运算符的增强 ; // 使用 等号法 调用 有一个参数的 有参构造函数 // C++ 对等号进行了功能增强...自动调用 默认无参构造函数 , 使用括号法调用 2 参数有参构造函数 调用 拷贝构造函数 使用等号法调用 1 参数有参构造函数 代码示例 : #include "iostream" using namespace...有一个参数的 有参构造函数 // C++ 对等号进行了功能增强 Student s5 = "K"; // 打印 Student s4 实例对象值 cout << "name : " << s5

    21440

    Java构造函数调用顺序问题

    参考链接: Java构造函数 今天对Java的构造函数调用顺序进行研究,使用的是与C++类似的方法,即不对源码进行研究,而是直接通过打印代码对构造函数调用顺序进行研究。 ...代码如下,使用的是Java核心技术中的代码,对其进行了改造,在构造函数中加入了输出信息  public class ConstructorTest {    public static void main...   }   执行结果   object initialization block : 0  static initialization block : 1  constructors3 : 2   构造函数最后调用...最后一点:如果构造器第一行调用了第二个构造器,则执行第二个构造器的主体。  最后还有一点非常重要的内容,构造调用一定要是第一句,否则编译出错。...在构造器中只能调用一次其他构造函数,不能调用两次,即无法再调用第三个构造函数。  本人是初学者,还无法从JVM的角度分析问题,同时回应各位大神对文中的错漏进行指出。

    1.1K40

    c语言调用bool函数,C语言中 bool的用法

    bool可用于定义函数类型为布尔型,函数里可以有 return TRUE; return FALSE 之类的语句。...提高程序的可读性 bool类型的变量只可能有两个值true或false,在没有统一的布尔类型在大型的工程项中特别是用到第三方程序库时,可能使用不同的手段模拟布尔类型以提交代码的可读性,这样会使得代码有些混乱,C语言中引入了...2、提高程序的性能 bool在绝大多数编译器编译时都将其实现为1字节,即sizeof(bool)的值为1,加上其只有两个值的值域{true, false},是C语言中最小的数据类型了。...虽然char、unsigned char和signed char类型在C语言中没有特定的实现要求,但一般也实现为一个字节,这样看来与bool类型从内存空间的占用上并没有性能上的差异。

    3.5K50
    领券