溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

union怎么在C++11中使用

發(fā)布時間:2021-03-26 15:54:51 來源:億速云 閱讀:344 作者:Leah 欄目:編程語言

這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)union怎么在C++11中使用,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

union即為聯(lián)合,它是一種特殊的類。通過關(guān)鍵字union進行定義,一個union可以有多個數(shù)據(jù)成員。例如

union Token{
char cval;
int ival;
double dval;
};

c++11中union除了繼承c語言的數(shù)據(jù)共享內(nèi)存之外,行為上越來越像一個類,比如成員默認(rèn)是public類型。

在C++11以后,很多基礎(chǔ)語法都進行了修正。其中 union 的行為向類對象進行了發(fā)展,在兼容原有語法定義的基礎(chǔ)上進行了擴充:

  • union可以擁有成員函數(shù)(包含構(gòu)造函數(shù)和析構(gòu)函數(shù)),但是不能有虛函數(shù)

  • union不能參與繼承,不能成為基類也不能成為子類

  • union的成員對象不能為引用類型

對于全部成員都是 build-in 的 union 類,還可以向以往一樣進行使用:

#include <iostream>
#include <cstdint>
union S
{
 std::int32_t n;  // 占用4字節(jié)
 std::uint16_t s[2]; // 占用4字節(jié)
 std::uint8_t c;  // 占用1字節(jié)
};      // 整體占用4字節(jié)
 
int main()
{
 S s = {0x12345678}; // 初始化第一個成員,當(dāng)前s.n為活躍成員
 // 于此點,讀取 s.s 或 s.c 是未定義行為
 std::cout << std::hex << "s.n = " << s.n << '\n';
 s.s[0] = 0x0011; // s.s 現(xiàn)在是活躍成員
 // 在此點,讀取 s.n 或 s.c 是未定義行為
 std::cout << "s.c is now " << +s.c << '\n' // 11 or 00, 依賴平臺實現(xiàn)
    << "s.n is now " << s.n << '\n'; // 12340011 or 00115678
}

對于全部包含非 built-in 的 union 類,則:

  1. 如果非靜態(tài)(non-static)成員帶有非平凡的特殊(non-trivial special)成員函數(shù)(自定義的:復(fù)制/移動構(gòu)造函數(shù),復(fù)制/移動賦值函數(shù),析構(gòu)函數(shù)),則該 union 類的默認(rèn)相關(guān)的復(fù)制/移動構(gòu)造函數(shù)、復(fù)制/移動賦值函數(shù)、析構(gòu)函數(shù)都會被刪除,如果需要的話,要求用戶自己定義實現(xiàn),如果用戶沒有自己定義,則不能進行相關(guān)的復(fù)制/移動操作

  2. 如果非靜態(tài)(non-static)成員帶有非平凡的特殊(non-trivial special)構(gòu)造函數(shù)(自定義的構(gòu)造函數(shù)),則該 union 類的默認(rèn)構(gòu)造函數(shù)會被刪除,如果需要的話,要求用戶自己定義實現(xiàn),如果用戶沒有自己定義,則不能該 union 類不能進行實例化。

  3. 至多一個變體成員能擁有默認(rèn)成員初始化值

  4. 不能有靜態(tài)成員數(shù)據(jù)(這個很奇怪,在clang上會報鏈接錯誤而不是語法錯誤),但是可以有靜態(tài)成員函數(shù)

  5. 全部成員的訪問控制都是 public

第1、2點的意思是,如果成員數(shù)據(jù)類型是非平凡的(non-trivial),則 union 類需要定義相關(guān)的構(gòu)造函數(shù)、復(fù)制函數(shù)、移動構(gòu)造、移動賦值函數(shù)、析構(gòu)函數(shù)等。

union A {
 int a;
 double b;
 std::string c;
 A() : c("111") {} // 因為std::string擁有是非平凡的的數(shù)據(jù)類型,
 ~A() {}   // 則A必須自定義構(gòu)造函數(shù)和析構(gòu)函數(shù),否則無法進行實例化
     // 如果想實現(xiàn)復(fù)制語義,還得自定義復(fù)制(構(gòu)造)函數(shù)
};

第3點的意思是:

union A {
 int a;
 double b;
 std::string c = "abc"; // 只有一個成員數(shù)據(jù)能擁有這種初始化值
 ~A(){};
};

上述就是小編為大家分享的union怎么在C++11中使用了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI