default constructor that only initializes data members; use in-class member initializers instead C.45:不要只初始化数据成员的默认构造函数 ;使用类内成员初始化器 Reason(原因) Using in-class member initializers lets the compiler generate the function 使用类内初始化器可以让编译器为你生成一个函数。编译器生成的函数效率更高。 (简单)默认构造函数应该比使用常量初始化数据成员做的更多。 译者注:差不多就是杀鸡焉用牛刀的意思。
本文是对《Effective C++》的”Item 4: Make sure that objects are initialized before they’re used”的笔记和验证。 结论 在进入构造函数体之前,数据成员的初始化就已完成。 数据成员的初始化顺序取决于声明顺序。 而进入函数体之前的数据成员的初始化如何控制呢?答案就是——成员初始化列表。 PS: 顺便吐槽一下很多建议使用成员初始化列表而不讲为什么的老师和书,你们多讲一句能费多大劲 T.T。 ,对成员的初始化还是以声明顺序为依据。
本文是对《Effective C++》的”Item 4: Make sure that objects are initialized before they’re used”的笔记和验证。 结论 在进入构造函数体之前,数据成员的初始化就已完成。 数据成员的初始化顺序取决于声明顺序。 而进入函数体之前的数据成员的初始化如何控制呢?答案就是——成员初始化列表。 PS: 顺便吐槽一下很多建议使用成员初始化列表而不讲为什么的老师和书,你们多讲一句能费多大劲 T.T。 ,对成员的初始化还是以声明顺序为依据。
上面的构造函数(使用初始化列表的构造函数)显式的初始化类的成员;而没使用初始化列表的构造函数是对类的成员赋值,并没有进行显式的初始化。 初始化和赋值对内置类型的成员没有什么大的区别,像上面的任一个构造函数都可以。对非内置类型成员变量,为了避免两次构造,推荐使用类构造函数初始化列表。但有的时候必须用带有初始化列表的构造函数: ? 1.成员类型是没有默认构造函数的类。若没有提供显示初始化式,则编译器隐式使用成员类型的默认构造函数,若类没有默认构造函数,则编译器尝试使用默认构造函数将会失败。 2.const 成员或引用类型的成员。 因为类类型的数据成员对象在进入函数体前已经构造完成,也就是说在成员初始化列表处进行构造对象的工作,调用构造函数,在进入函数体之后,进行的是对已经构造好的类对象的赋值,又调用个拷贝赋值操作符才能完成(如果并未提供 初始化列表的成员初始化顺序: C++ 初始化类成员时,是按照声明的顺序初始化的,而不是按照出现在初始化列表中的顺序。 ?
C++初始化列表详解:性能优化与正确实践 在C++编程中,初始化列表是构造函数的重要组成部分,它不仅能提升代码性能,还能确保成员变量被正确初始化。本文将深入探讨初始化列表的语法、应用场景及最佳实践。 基类初始化:正确调用父类构造函数 当基类没有默认构造函数时,必须通过初始化列表显式调用其带参构造函数。 . */ } // 调用基类构造函数 }; 4.必须使用初始化列表的情况 在C++中,引用、const成员变量以及没有默认构造函数的类类型成员变量必须在构造函数初始化列表中进行初始化,这是由它们的语义和 C++对象生命周期的规则决定的。 初始化顺序由声明顺序决定 成员变量的初始化顺序由其在类中声明的顺序决定,而非初始化列表中的顺序。错误的顺序可能导致未定义行为。
in-class initializers to member initializers in constructors for constant initializers C.48:如果构造函数需要用常数初始化成员 ,使用类内初始化器更合适 Reason(原因) Makes it explicit that the same value is expected to be used in all constructors 维护人员怎么才能知道 j 是否是故意没有初始化(尽管这可能是坏主意)呢?怎么知道一种情况将s初始化为“”,而另一种情况初始化为"qqq"是有意而为之呢(这几乎就是一个错误)? 关于 j 的问题(忘了初始化某个成员)经常发生在向类添加新成员的时候。 (简单)针对构造函数的默认参数使用类内初始化器可能是更加恰当的选择。 ---- 觉得本文有帮助?请分享给更多人。 关注【面向对象思考】轻松学习每一天! 面向对象开发,面向对象思考!
分享一个之前学的知识点,感觉还挺重要的,就是当一个类中的某个数据成员同时拥有就地初始化、构造函数初始化列表和构造函数函数体里的赋值,那么它会先执行哪个?最后生效的又是哪个呢? 根据老师的讲解,数据成员的初始化次序依次为: 就地初始化 > 构造函数的初始化列表 >构造函数里的赋值(严格意义上不能成为初始化) 而当三种初始化方式都有时,构造函的函数体里的赋值肯定执行,并且生效 ,但是就地初始化和构造函数初始化列表的执行情况是怎样呢? ,而当调有参构造函数时,id没有执行就地初始化,而是直接执行了构造函数初始化列表。 所以当一个数据成员同时拥有就地初始化和初始化列表时,它会忽略就地初始化而执行构造函数初始化列表。
C++使用new来初始化类的指针 1.ClassName * p = new ClassName; 调用默认构造函数。 如果类里没有写默认构造函数,会使用编译器帮我们生成的,并且会初始化成员变量,比如 int 类会被初始化为 0 NoConstructor* p2 = new NoConstructor(); p2->printVal C++指针初始化问题 c++中的指针是一个很经典的用法,但是也是最容易出错的,比如定义了一个指针,必须对其进行初始化,不然这个指针指向的是一个未知的内存地址,后续对其操作的时候,会报错。 下面就总结一下c++指针初始化的一些方法,以及我自己遇到的一些问题以及心得体会。 c++指针初始化的一般方法 1.将一个已经在内存中存在变量的地址传递给定义的指针 这个指针就指向这个变量的内存地址(相同的数据类型),完成初始化。
在很多类中初始化和赋值的区别事关底层效率的问题:前者直接初始化数据成员,后者则先初始化再赋值。除了效率问题外更重要的是,一些数据成员必须初始化。 所以一般建议养成使用初始化列表的习惯,这样可以避免某些意想不到的编译错误,特别是遇到类包含构造函数初始值的成员时。 初始化顺序: 显然在构造函数中每个成员只能出现一次。 需要注意的是初始化列表不限定初始化的执行顺序,因为成员初始化的顺序与他们在类出现顺序一致,第一个成员先初始化,然后第二个,以此类推,因此构造函数初始化列表的前后位置并不影响实际的初始化顺序。 注意: 每个成员变量在初始化列表中只能出现一次(初始化只能一次) 类中包括以下成员,必须在初始化列表进行初始化 : 引用成员变量 const成员变量 自定义类型成员(并且该类没有默认构造函数时) 尽量使用初始化列表初始化,因为不管你是否使用初始化列表,对于自定义类型成员变量,一定会先使用初始化列表初始化 成员变量在类中声明次序就是其在初始化列表中的初始化顺序,与其在初始化列表中的先后次序无关。
如果你用过 Java ,那你一定对静态初始化代码块不会感到陌生, JavaScript 预计会在 v8 9.1 版本支持这个特性。 新的类静态初始化代码块允许开发人员执行针对某个类定义运行一次的代码,并将它们统一放在一个地方。参考下面的示例,在类 MyPRNG 定义时,在静态初始化代码块中会创建一个随机字符串数组。 与静态字段初始化器一样,静态代码块中的 this 值是类构造函数本身。同样, super 属性在静态块中引用父类的静态属性。 y; // → 'outer y' 多个代码块 一个类可以有多个静态初始化代码块。这些代码块按顺序执行。此外,如果有任何静态字段,所有静态元素都按顺序执行。 static block 2'); } } // → field 1 // static block 1 // field 2 // static block 2 访问私有属性 因为类静态初始化代码块总是嵌套在类的内部
C++之string类 本节目标 1. string类概览 1.1 string的由来 1.2 string函数列表 2.string常用接口 1. 注:本文参考以下两篇优秀文章,将其结合并加上额外的知识用自己的理解进行描述: C++之string类型详解 C++string类型详解 1. string类概览 1.1 string的由来 之所以抛弃char *的字符串而选用C++标准程序库中的string类,是因为他和前者比较起来,不必担心内存是否足够、字符串长度等等,而且作为一个泛型类出现,他集成的操作函数足以完成我们大多数情况下(甚至是100%)的需要 C++中对于string的定义为:typedef basic_string<char> string; 也就是说C++中的string类是一个泛型类,由模板而实例化的一个标准类,本质上不是一个标准数据类型 初始化 初始化有两种方式,其中使用等号的是拷贝初始化,不使用等号的是直接初始化。(注释后面是打印的结果) 但对于使用等号的和str(str1),即一个变量通过另一变量初始化的,都是拷贝构造。
前言 在前面的博客中已经分享有关构造函数 【C++】构造函数和析构函数详解,这次又再一次提到构造函数,一起来看看。 2. 所以c++中用了初始化列表,初始化列表是每个成员变量定义初始化的位置。 下面的成员变量也会走初始化列表,他们也要定义,只是没有给值就是随机值,如果给了值就直接初始化。 这里是显示的调构造 【注意】 每个成员变量在初始化列表中只能出现一次(初始化只能初始化一次) 类中包含以下成员,必须放在初始化列表位置进行初始化,不能在函数体内初始化: (1)引用成员变量 到时候初始化列表就直接用2去初始化,和上面的原因一样:同一个表达式连续步骤的构造,一般会被合二为一 成员变量在类中声明次序就是其在初始化列表中的初始化顺序,与其在初始化列表中的先后次序无关。 静态成员变量一定要在类外进行初始化。 面试题:实现一个类,计算程序中创建出了多少个类对象。 就是统计构造,构造函数调用了多少次。
❝在C++中int类型可以看作为一个类,那么它就有以下的初始化方式。 ❞ int i; /* 默认初始化 */ int i = 0; /* 拷贝初始化 */ int i(0); /* 直接初始化 */ int *i = new int(); /* 值初始化 */ int i{0}; /* 列表初始化 */ std::vector<int> i{1, 2, 3}; /* 列表初始化 */
public static void main(String[] args) { InitializeDemo n =new InitializeDemo("初始化 "); } } 类变量先分配内存并且赋值为默认值,再进行初始化。 类变量和对象变量初始化顺序都为从上到下初始化,有变量初始化,代码块初始化,构造器初始化 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/168704.html原文链接
关键字使用 3.结语 1.初始化列表 1.1初始化列表定义 C++中的初始化列表是一种在对象构造函数中初始化成员变量的方法。 1.2初始化列表原因 在C++类和对象中有些成员变量必须定义的时候初始化,这时候如果只是简单的使用构造函数来赋值是不可行的,所以C++引入了初始化列表这个概念; 类中包含以下成员,必须放在初始化列表位置进行初始化 没有默认构造函数的类类型成员变量_aobj:如果成员变量是一个类类型的对象,并且该类没有默认构造函数(无参构造函数),则必须在初始化列表中调用该类的有参构造函数进行初始化。 1.3初始化列表注意点 每个成员变量在初始化列表中只能出现一次(初始化只能初始化一次) 类中包含以下成员,必须放在初始化列表位置进行初始化: 引用成员变量 const成员变量 自定义类型成员(且该类没有默认构造函数时 3.结语 初始化列表是C++类和对象中初始化成员变量的方式,在一些情况下可以提高效率和代码可读性。
总结如下: (1)类的成员变量在定义时候可以初始化,当然静态成员变量不行。 (2)类的成员函数默认参数需要在头文件声明里面指定,在定义函数时候不能指定。
VECTORTYPE &); int main() { VECTORTYPE v1; //two list's initialize VECTORTYPE v2{1,2,3,4,5,6,7,8,9,0 }; VECTORTYPE V21 = {1,2,3,4,5,6,7,8,9,0}; //tow copy of container's element VECTORTYPE v3(v2); = vec.end() ; ++i) { cout << *i << " ";} cout << endl; return ; } 总结起来有以下几个: 2列表初始化,2个拷贝 ,2构造,1默认(无初值),1迭代器共8种方法。 当然是用迭代器初始化,可以相互转换都可以,而且不要求容器和元素类型相同。
磁盘在联机后要初始化,同样也有两种方法,一种是调用IOCTL_DISK_CREATE_DISK,还有一种是调用WMI的Initialize方法。 1.首先说说简单的WMI的方法: 大致思路同博客:C++ 实现磁盘联机 先获取磁盘的id, 然后执行无参数方法Initialize 核心模块代码如下: wchar_t msftDiskObjectID GetLastError(); } CloseHandle(hFile); return retcode; } GPT磁盘类似,不同的地方在于传入的参数变成了GUID 核心代码在于CREATE_DISK结构的初始化发生了变化
探索路径同样是参考oc的探索路径,先从类开始。 类初始化 1. 使用Xcodel断点调试 ? 创建一个简单的类,开启汇编断点 ? swift_allocObject是初始化第二步 下断点,按住control+↓进入下一步 ? swift_slowAlloc是初始化第三步 下断点,按住control+↓进入下一步 ? ? return object; } void *swift::swift_slowAlloc(size_t size, size_t alignMask) { void *p; //一般使用 8字节对齐 8字节对齐 #define malloc_zone_malloc(zone,size) malloc(size) malloc_zone_malloc只是一个宏定义,最终调用malloc 3. 初始化流程图 ? 类结构 - HeapObject结构 1. 编译器断点 ? 在进行类创建,源码调试的时候发现swift的类结构是这样的。和oc比起来是有一些不同的。
没有默认构造函数的类类型,因为使用初始化列表可以不必调用默认构造函数来初始化,而是直接调用拷贝构造函数初始化 五 、成员变量是按照在类中声明的顺序被初始化的而不是在初始化列表中的顺序 struct foo 一个好的习惯是,按照成员定义的顺序进行初始化。 六、含有参数的继承类的初始化 代码1如下: 1 // 集成类的初始化实验.cpp : 定义控制台应用程序的入口点。 2 // 3 4 #include "stdafx.h" 5 #include<iostream> 6 using namespace std; 7 8 class A 9 { 10 ):A(a2,b2,c2)的a2,b2,c2,d2,然后在将a2,b2,c2,依次赋值给13行中A(int a1,int b1,char c1) 的a1,b1,c1 将代码改变一下: 1 // 集成类的初始化实验 2 // 3 4 #include "stdafx.h" 5 #include<iostream> 6 using namespace std; 7 8 class A 9 { 10