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

——构造函数初始化列表

---- ---- 前言         在我们已经基本了解了的由来,和其六大基本默认函数后,此时我们再回过头来看,其中的构造函数。...在构造函数体内部,我们直接可以用的成员变量来赋值,但是在调用构造函数前是没有这个对象的,既然都没有这个对象,哪前面我们直接用来赋值的中的成员变量是哪里来的?        ...此时初始化列表就说:没错就是我干的,是我来真正初始化成员的,构造函数体内只是二次赋值罢了。 但在上面的图片中,我们明明没看见这个所谓的初始化列表那他在哪里呢?...小结         尽量使用初始化列表初始化,因为不管你是否使用初始化列表,对于自定义类型成员变量,一定会先使用初始化列表初始化,即在创建新的对象时,都会调用构造函数,也都会经过初始化列表(就算你不写...尽量使用初始化列表初始化还有个好处,就是将初始化的步骤可以尽可能的放在一起,而构造函数体内就可以写其它的需求实现,比如访问或修改除了新对象的其它变量等等,就可增加代码的可读性。

78820

C++ 构造函数初始化列表

上面的构造函数(使用初始化列表的构造函数)显式的初始化的成员;而没使用初始化列表的构造函数是对的成员赋值,并没有进行显式的初始化。...初始化和赋值对内置类型的成员没有什么大的区别,像上面的任一个构造函数都可以。对非内置类型成员变量,为了避免两次构造,推荐使用构造函数初始化列表。但有的时候必须用带有初始化列表的构造函数: ?...1.成员类型是没有默认构造函数。若没有提供显示初始化式,则编译器隐式使用成员类型的默认构造函数,若没有默认构造函数,则编译器尝试使用默认构造函数将会失败。 2.const 成员或引用类型的成员。...1.内置数据类型,复合类型(指针,引用)- 在成员初始化列表和构造函数体内进行,在性能和结果上都是一样的 2.用户定义类型(类型)- 结果上相同,但是性能上存在很大的差别。...因为类型的数据成员对象在进入函数体前已经构造完成,也就是说在成员初始化列表处进行构造对象的工作,调用构造函数,在进入函数体之后,进行的是对已经构造好的对象的赋值,又调用个拷贝赋值操作符才能完成(如果并未提供

1.9K20
您找到你想要的搜索结果了吗?
是的
没有找到

JavaScript 构造函数

构造函数是一个唯一的函数,用于创建和初始化的对象实例。在 JavaScript 中,当使用 new 关键字创建对象时,构造函数会被调用。...这是构造函数内部引用将要生成的新对象。 与 JavaScript 函数不同,构造函数定义属性和操作,而不是返回值。...使用构造函数创建新对象在 JavaScript 中使用构造函数创建对象是一个简单的过程。...幸运的是,JavaScript 中的构造函数与任何其他函数一样,可以提供参数。...构造函数可用于构建具有共享方法和属性的对象。此外,可以使用继承来定义对象层次结构。ES6 中的 class 关键字可用于定义传统的面向对象。此 JavaScript 版本还支持构造函数关键字。

13020

javascript构造函数

我们相约在今天,在今天讨论javascript构造函数,感谢你如约而至 昨天 我们昨天前几天讨论过构造函数constructor,得出了结论 constructor是原型对象上的一个属性,默认指向这个原型的构造函数...这个结论貌似对我们平时的工作中似乎并没有什么用处,那构造函数,就真的没什么用处吗?...今天 使用构造函数构造可以复用的对象 JS中的函数即可以是构造函数又可以当作普通函数来调用,当使用new来创建对象时,对应的函数就是构造函数,通过对象来调用时就是普通函数。 ?...); } //通过构造函数Person实例化一个p1,并传参 var p1 = new Person('postbird','earth'); //通过构造函数Person实例化一个p2,并传参 var...不是说constructor是原型对象上的一个属性,默认指向这个原型的构造函数?

96530

【Kotlin】初始化 ② ( 主构造函数 | 主构造函数定义临时变量 | 主构造函数中定义成员属性 | 次构造函数 | 构造函数默认参数 )

文章目录 一、主构造函数定义临时变量 二、主构造函数中定义成员属性 三、次构造函数 四、构造函数默认参数 一、主构造函数定义临时变量 ---- 在 Kotlin 中 , 可以在 声明 时 在 名后...定义 " 主构造函数 " ; 在 主构造函数 中 , 可以 定义 成员属性 , 并为 成员属性 提供 初始值 ; 在 主构造函数 中 , 可以定义 临时变量 , 临时变量 一般使用 以下划线为开头 的名称...---- 在主构造函数中 定义临时变量 , 格式为 : class 名(_临时变量名: 临时变量类型){} 在主构造函数中也可以 定义成员属性 , 格式为 : class 名(var 成员属性名:...---- Kotlin 只允许 在定义时 定义 一个主构造函数 , 在其中可以定义 临时变量 , 也可以定义 属性变量 ; 次构造函数 定义在 Kotlin 内部 , 可以定义 多个 次构造函数..., 每个次构造函数都可以有不同的参数组合 ; 定义次构造函数后 , 必须调用主构造函数 , 并且为每个主构造函数 的 参数设置 参数值 ; 次构造函数中可以实现代码逻辑 , 作为主构造函数的补充 ; 代码示例

4.7K20

【C++】构造函数初始化列表 ① ( 对象作为成员变量时的构造函数问题 | 构造函数初始化列表语法规则 )

一、对象作为成员变量时的构造函数问题 1、问题描述 如果 一个 A 的对象 作为 另外一个 B 的成员变量时 , 在以下场景会报错 : 为 A 定义 有参的 构造函数 , 那么 A 的无参默认构造函数就失效了...; 此时使用 默认无参构造函数 初始化 B , 就会报错 ; 在一个中 , 其成员变量是 带有参构造函数 的类型 , 这种情况下没有调用 有参构造函数的机会 , 此时就会出现 编译报错情况 ; 在下面的代码中...========== 生成: 成功 0 个,失败 1 个,最新 0 个,跳过 0 个 ========== 二、构造函数初始化列表 ---- 1、构造函数初始化列表语法规则 在 C++ 语言中 , 构造函数初始化列表...是一种用于初始化的成员变量的方法 ; 构造函数初始化列表 可实现功能 : 为成员变量提供初始值 调用其他 成员变量的 构造函数初始化成员变量 构造函数初始化列表语法规则 : 构造函数() : 成员变量名称...初始化列表中的元素由 成员变量的名称 和 初始值组成 , 使用等号 = 连接 ; 在下面的代码中 , 为 B 定义了默认的构造函数 , 其中定义了 构造函数 初始化列表 ; 在 初始化列表中 , m_age

43230

【C++】构造函数初始化列表 ② ( 构造函数初始化列表 传递参数 | 嵌套情况下 的 构造函数 析构函数 执行顺序 )

一、构造函数初始化列表 传递参数 1、构造函数参数传递 构造函数 初始化列表 还可以使用 构造函数 中的参数 ; 借助 构造函数 中的参数列表 , 可以为 初始化列表 传递参数 ; 在下面的代码中..., A 定义了 2 个参数的 有参构造函数 ; B 定义了 无参构造函数 , 但是在该 无参构造函数 中 , 定义了函数列表 B() : m_age(10), m_a(10, 150) , 在该函数列表中...0; } 执行结果 : 二、嵌套情况下 的 构造函数 / 析构函数 执行顺序 ---- 1、构造函数 / 析构函数 执行顺序 B 中 定义了 A 类型 的 成员变量 ; A 类型对象 是 被组合对象...; 构造函数执行顺序 : 在 初始化 B 类型 实例对象时 , 先执行 被组合对象 A 的构造函数 , 如果 被组合对象 有多个 , 则 按照 成员变量 的定义顺序 进行初始化 ; 注意 : 此处 不是按照...初始化列表 的顺序 进行初始化 ; 析构函数执行顺序 : 析构函数构造函数 的执行顺序 相反 ; 2、代码示例 - 构造函数执行顺序 下面的代码中 , 在 B 中定义 A 类型 成员变量 ;

18230

JavaScript构造函数

在Java语言中,我们使用构造函数是实例化对象的过程,在JavaScript语言中我们可以使用构造函数的方式创建对象,如: let obj = new LanguageFun("javaScript")...与面向对象的语言不同,JavaScript使用构造函数创建对象不是真正意义上的实例化,而是通过new操作符调用的构造函数。...构造函数的执行过程: 1. 创建一个新的对象obj 2. obj被执行原型链[[prototype]]连接 3. obj绑定到函数调用的this上 4....没有其他返回对象,则返回obj 包括我们知道的内置函数Number(), String()都可以使用new操作符创建新的对象,这种函数JavaScript中称为构造函数的调用。...,产生异常,所以我们需要对JavaScript构造函数进行兼容改造。

97670

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

一、构造函数意义 1、构造函数 C++ 提供的 构造函数 和 析构函数 作为 实例对象的 初始化 和 销毁 方案 ; 定义一个的 若干 实例对象 , 每个对象都有独立的 成员属性 ; 当 定义...隐式调用 ; 有参构造函数 是 由开发者 手动显式调用 ; 3、构造函数替代方案 - 初始化函数 构造函数的替代方案 - 初始化函数 : 共有初始化函数 : 为每个定义一个 public 共有初始化函数..., 造成未知风险 ; 无法调用 : 在某些特殊场合 , 初始化函数是无法被调用到的 , 如 : 只定义的变量类型 , 没有调用构造函数 , 此时会自动调用无参构造函数初始化实例对象 , 如果使用初始化函数..., 则无法进行初始化操作 ; 5、默认构造函数 如果 定义 时 , 没有写 构造函数 , C++ 编译器 会 为 提供一个默认构造函数 ; 默认构造函数函数体为空 , 不需要开发者定义 ,...; 默认拷贝构造函数 : 如果 中没有定义 拷贝构造函数 , C++ 编译器 会默认定义一个 默认拷贝构造函数 , 该函数的作用是进行简单的成员变量赋值 ; 6、代码示例 - 初始化函数无法及时调用

35720

JavaScript 工厂函数 vs 构造函数

工厂函数 所谓工厂函数,就是指这些内建函数都是对象,当你调用他们时,实际上是创建了一个实例”。意思就是当我调用这个函数,实际上是先利用创建了一个对象,然后返回这个对象。...由于 Javascript 本身不是严格的面向对象的语言(不包含),实际上来说,Javascript 并没有严格的“工厂函数”,但是在 Javascript中,我们能利用函数模拟。...它像工厂一样,“生产”出来的函数都是“标准件”(拥有同样的属性) 构造函数 不同于其它的主流编程语言,JavaScript构造函数并不是作为的一个特定方法存在的;当任意一个普通函数用于创建一对象时...理解 JavaScript 的原型 理解原型之前,需要记住以下几点知识: 所有的引用类型(数组、对象、函数),都具有对象特性,即可自由扩展属性(null除外) 所有的引用类型(数组、对象、函数),都有一个...__proto__属性,属性值是一个普通的对象 所有的函数,都有一个prototype属性,属性值也是一个普通的对象 所有的引用类型(数组、对象、函数),__proto__属性值指向它的构造函数的prototype

1K20

【Kotlin】Kotlin 构造函数 ( 主构造函数 | 主构造函数声明属性 | init 初始化代码块 | 次构造函数 | 构造函数委托 | 调用构造函数创建实例对象 )

初始化代码块 ---- 1 . init 代码块引入 : 主构造函数没有函数体 , 不能执行任何代码 ; 主构造函数初始化相关操作可以放在 init 初始化代码块中 ; 2 . init 初始化代码块...代码执行顺序 : init 初始化代码块 , 与的属性定义优先级相同 , 在对象实例初始化时 , 会按照在中定义的顺序 , 依次执行类属性初始化和 init 初始化代码块 ; 4 ....主构造函数参数 和 成员变量访问方式 ---- 1 . 主构造函数参数访问性 : 可以在 类属性字段初始化赋值 和 init 初始化代码块中 访问主构造函数中的参数变量值 ; 2 ....构造函数 代码执行顺序 ---- 1 . 代码执行顺序 : 先执行主构造函数 , 此时会初始化成员属性 与 执行 init 初始化代码块 , 然后执行次构造函数内容 ; 2 ....初始化代码块 : init 代码块等同于主构造函数函数体 , 当次构造函数将操作委托给主构造函数时 , 会先执行 init 初始化代码块 , 然后再运行次构造函数体 ; IX .

3K10

【Kotlin】初始化 ③ ( init 初始化块 | 初始化顺序 : 主构造函数属性赋值 -> 类属性赋值 -> init 初始化块代码 -> 次构造函数代码 )

时会执行一系列的 初始化操作 , 这些操作按照如下顺序执行 : 主构造函数 中属性赋值 中的属性赋值 init 初始化块 中的代码执行 次构造函数 中的代码执行 代码示例 : 通过下面的代码分析 Kotlin...实例对象 各种初始化操作的 初始化顺序 ; class Hello( // 主构造函数, 直接在主构造函数中定义属性 var name: String, // 该值是临时变量,...: 首先 , 为 name 属性赋值 , 这是在 主构造函数 中完成的操作 ; 然后 , 为 age 和 type 属性赋值 , 这是在 中的 age 属性进行的赋值 , 使用的是 主构造函数 中的临时变量...; 最后 , 为 gender 赋值 , 这是在 init 初始化块 中进行的赋值 ; 然后分析 次构造函数 , 在 如下的 次构造函数的代码中 , 先执行了 主构造函数 , 然后才为 type 属性赋值...} 因此得到了上述初始化操作的执行顺序 : 主构造函数属性赋值 -> 类属性赋值 -> init 初始化块代码 -> 次构造函数代码

1.2K30

【C++】STL 容器 - vector 动态数组容器 ② ( vector 有参构造函数 | 范围构造函数 | 初始化 n 个 指定元素 | 拷贝构造函数 )

文章目录 一、vector 有参构造函数 1、使用另外的 vector 对象初始化 - 范围构造函数 2、vector 容器初始化 n 个 指定元素 3、vector 容器拷贝构造函数 4、代码示例 -...vector 容器有参构造函数 一、vector 有参构造函数 1、使用另外的 vector 对象初始化 - 范围构造函数 vector 动态数组容器 , 初始化时 , 可以使用另外的 vector...与 使用两个迭代器范围进行初始化构造函数略有不同 ; 使用两个迭代器范围进行初始化时 , 会复制指定范围内的所有元素到新创建的 vector 中 ; 本构造函数 使用 n 和 元素值 进行初始化时...动态数组容器 // 该容器中 有 3 个元素 , 每个元素值为 字符 `A` std::vector vec(3, 'A'); 3、vector 容器拷贝构造函数 vector 容器拷贝构造函数..." // 自定义 class Student{}; int main() { // 创建一个 vector 动态数组容器 // 该容器中 有 3 个元素 , 每个元素值为 int 类型值

22610

JavaScript构造函数的继承

现在有一个"动物"对象的构造函数。 function Animal(){ this.species = "动物"; } 还有一个"猫"对象的构造函数。...一、 构造函数绑定 使用 call 或 apply 方法,将父对象的构造函数绑定在子对象上,即在子对象构造函数中加一行: function Cat(name,color){ Animal.apply...Cat.prototype.constructor = Cat; 任何一个 prototype 对象都有一个 constructor 属性,指向它的构造函数。...alert(cat1.constructor == Animal); // true 这显然会导致继承链的紊乱(cat1明明是用构造函数Cat生成的),因此需要手动纠正,将 Cat.prototype...如果替换了 prototype 对象, o.prototype = {}; 那么,下一步是为新的 prototype 对象加上 constructor 属性,并将这个属性指回原来的构造函数

94110

前端基础-JavaScript构造函数

第2章 构造函数 学习目标 构造函数语法 分析构造函数 构造函数和实例对象的关系 实例的 constructor 属性 instanceof 操作符 普通函数调用和构造函数调用的区别 构造函数的返回值...构造函数的问题 2.1 构造函数 JavaScript 语言使用构造函数作为对象的模板。...所谓 ”构造函数”,就是一个普通的函数,只不过我们专门用它来生成对象(new 构造函数),这样使用的函数,就是构造函数; 它提供模板,描述对象的基本结构。...this 返回,也就是这个新对象 } 构造函数和实例对象的关系 构造函数是根据具体的事物抽象出来的抽象模板 实例对象是根据抽象的构造函数模板得到的具体实例对象 实例对象由构造函数而来,一个构造函数可以生成很多具体的实例对象...小结 构造函数语法 分析构造函数 构造函数和实例对象的关系 实例的 constructor 属性 instanceof 操作符 构造函数的问题

52310
领券