C++中建構函式初始化列表為什麼會比建構函式中賦值要高效
Test
{
Test(test& t1)
{
this->t=t1;
}
private:
test t;
}
相信很多人跟我一樣,非常困惑為什麼Test構造時會先呼叫test的建構函式,再呼叫test類的賦值操作符。那是因為賦值操作符不能產生新的物件,Test構造時免不了要構造一個test物件。所以正常流程是 先構造t,然後再呼叫賦值操作符賦值t(this->t=t1)。
如果寫成
Test
{
Test(test& t1):t(t1)
{
}
private:
test t;
}
就只會呼叫一次test的拷貝建構函式,構造出t。所以初始化列表比賦值更高效。
相關推薦
C++中建構函式初始化列表為什麼會比建構函式中賦值要高效
Test { Test(test& t1) { this->t=t1; } private: test t; } 相信很多人跟我一樣,非常困惑為什麼Test構造時會先呼叫test的建構函式,再呼叫test類的賦值操作符。那是因為賦值操作符不能產生新的物件,Te
C++中預設建構函式和建構函式初始化列表
1、預設建構函式和建構函式 (1)建構函式:C++用於構建類的新物件時需要呼叫的函式,該函式無返回型別!(注意:是“無”! 不是空!(void))。 (2)預設建構函式:預設建構函式是在呼叫時不需要顯示地傳入實參的建構函式。 一個類如果自己沒有定義建構函式,則會有一個無參且函式體也是空的
C++建構函式初始化列表與建構函式中的賦值的區別
C++類中成員變數的初始化有兩種方式: 建構函式初始化列表和建構函式體內賦值。下面看看兩種方式有何不同。 成員變數初始化的順序是按照在那種定義的順序。 1、內部資料型別(char,int……指標等) class Animal { publ
C++類建構函式初始化列表
建構函式初始化列表以一個冒號開始,接著是以逗號分隔的資料成員列表,每個資料成員後面跟一個放在括號中的初始化式。例如: class CExample { public: int a; float b;
C++類使用建構函式初始化類表和建構函式函式體中賦值的區別
參考:http://www.360doc.com/content/13/0607/19/1317564_291331713.shtml C++ Primer中在講建構函式初始化列表的時候有這麼一段話: 無論是在建構函式初始化列表中初始化成員,還是在建構函式體中對它們賦
類建構函式初始化列表
表現形式有三種 當前類進行初始化,尤其是當成員變數是一個const或者一個引用型別 class Demo { private: int b; public: Demo(int a):b(a){}; } 需
C++ 建構函式初始化呼叫順序及類函式內部巢狀函式情況
C++建構函式初始化順序 C++建構函式按下列順序被呼叫:(1、2、3、4是按照優先順序順序來的!) (1)任何虛擬基類的建構函式按照它們被繼承的順序構造; (2)任何非虛擬基類的建構函式按照它們被繼承的順序構造; (3)任何成員物件的建構函式按照它們宣告的順序呼叫;(如果成員物件有前面出現
C++中只能使用初始化列表(只能是初始化)不能使用賦值的情況
(1)當類中含有const(常量)、reference(引用)成員變數時,只能初始化,不能對它們進行賦值; 常量不能被賦值,只能被初始化,所以必須在初始化列表中完成,C++引用也一定要初始化,所以必須在初始化列表中完成。 (2)基類的建
三種情況必須在類建構函式初始化列表初始化
//const成員的初始化只能在建構函式的初始化列表中進行 //引用成員的初始化也只能在建構函式的初始化列表中進行 class object { public: object(int num = 0 ,int knum = 0):num_(num),knum_(knum),refnum_(num) {
C++中必須在初始化列表初始化的型別
1.賦值是刪除原值,賦予新值,建構函式的意思是先開闢空間然後為其賦值,只能算是賦值,不算初始化;初始化列表開闢空間與初始化是同時完成的,直接給予一個值。 2. C++中常量是不能被賦值的,只能被初始化,所以const型別必須在初始化列表中完成; 3. 引用必須在定義的時候初
類的成員變數 宣告順序 決定 初始化順序(建構函式初始化列表不影響)
類成員的宣告順序決定初始化順序; 建構函式初始化列表不影響初始化順序; C++初始化類成員時,是按照宣告的順序初始化的,而不是按照出現在初始化列表中的順序。 class B { public: //m_b = 2,m_a = 1 B():m
C++解析(12):初始化列表與物件構造順序
0.目錄 1.類成員的初始化 2.類中的const成員 3.物件的構造順序 3.1 區域性物件的構造順序 3.2 堆物件的構造順序 3.3 全域性物件的構造順序 4.小結 1.類成員的初始化 類中是否可以定義const成員? 下面的類定義是否合法?如果合法,ci的值是什麼,儲
為什麼用成員初始化列表會快一些?
首先把資料成員按型別分類 1。內建資料型別,複合型別(指標,引用) 2。使用者定義型別(類型別) 分情況說明: 對於型別1,在成員初始化列表和建構函式體內進行,在效能和結果上都是一樣的 對於型別2,結果上相同,但是效能上存在很大的差別 因為類型別的資
C++必須使用【初始化列表】初始化資料成員的三種情況
類物件的構造順序是這樣的: 1.分配記憶體,呼叫建構函式時,隱式/顯示的初始化各資料成員; 2.進入建構函式後在建構函式中執行一般賦值與計算。 使用初始化列表有兩個原因: 原因1.必須這樣做: 《C++ Primer》中提到在以下三種情況下需要使用初始化成員列表:
C++中的預設建構函式和初始化列表和子類呼叫父類建構函式
預設建構函式:未提供顯式初始值時,用來建立物件的建構函式。 class testClass { public: testClass();
c++中初始化列表和建構函式初始化
初始化和賦值對內建型別的成員沒有什麼的的區別,在成員初始化列表和建構函式體內進行,在效能和結果上都是一樣的。對非內建型別成員變數,因為類型別的資料成員的資料成員物件在進入函式體前已經構造完成,也就是說在成員初始化列表處進行構造物件的工作,呼叫建構函式,在進入函式體之後,進行的是對已經構造好的類物件的賦值,又呼
c++建構函式成員初始化中賦值和初始化列表兩種方式的區別
先總結下: 由於類成員初始化總在建構函式執行之前 1)從必要性: a. 成員是類或結構,且建構函式帶引數:成員初始化時無法呼叫預設(無參)建構函式 b. 成員是常量或引用:成員無法賦值,只能被初始化 2)從效率上: 如果在類建構函式裡賦值:在成員
c++建構函式中初始化列表的作用和機制
#include <iostream> #include <string> using namespace std; class base { private: int m_i; int m_j; public: base(int i): m_j(i), m_i(m_j){}
在C++拷貝建構函式中使用初始化列表
今天同事遇到一個關於拷貝建構函式的問題。程式碼大致如下: class test { public: test( size_t size ) { v.assign( size, 1 ); } test( const test& rhs)
C++:建構函式的初始化列表,以及初始化的順序
建構函式的初始化值列表: 對於物件的資料成員而言,初始化和賦值是有區別的。 當資料成員是 const 、引用,或者屬於某種未提供預設建構函式的類型別的話,就必須通過建構函式的初始值列表為這些成員提供初始值,否則就會引發錯誤。 // 錯誤:ci 和 ri 必須初始化 CobstRef::C