www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 公眾號(hào)精選 > C語(yǔ)言與CPP編程
[導(dǎo)讀]一、轉(zhuǎn)換構(gòu)造函數(shù)的學(xué)習(xí): 1、回憶數(shù)據(jù)類(lèi)型轉(zhuǎn)換: 在平時(shí)寫(xiě)代碼的時(shí)候,最怕的就是那種隱式數(shù)據(jù)類(lèi)型轉(zhuǎn)換了,一不小心,軟件就bug不斷;而顯式數(shù)據(jù)類(lèi)型(一般是程序自己去強(qiáng)制類(lèi)型轉(zhuǎn)換,這個(gè)是我們能夠明顯的識(shí)別和掌控的)。為此我們這里總結(jié)了一副隱式類(lèi)型轉(zhuǎn)


一、轉(zhuǎn)換構(gòu)造函數(shù)的學(xué)習(xí):

1、回憶數(shù)據(jù)類(lèi)型轉(zhuǎn)換:

在平時(shí)寫(xiě)代碼的時(shí)候,最怕的就是那種隱式數(shù)據(jù)類(lèi)型轉(zhuǎn)換了,一不小心,軟件就bug不斷;而顯式數(shù)據(jù)類(lèi)型(一般是程序自己去強(qiáng)制類(lèi)型轉(zhuǎn)換,這個(gè)是我們能夠明顯的識(shí)別和掌控的)。下面,我們來(lái)幾個(gè)隱式轉(zhuǎn)換的例子:

代碼版本一:

#include #include int main()
{
     short s ='a';
     unsigned int ui = 100;
     int i = -200;
     double d = i;

     std::cout<<"d =" << d <"ui= "<if((ui+i)>0)
     {
          std::cout<<"Postive"<else {
        std::cout<<"Negative"<return 0;
}

輸出結(jié)果:

root@txp-virtual-machine:/home/txp# ./a.out d =-200
ui= 100
Postive

注解:這里我們明顯發(fā)現(xiàn)(-200+100)還是大于0,這顯然不符合正常人的思維了;所以我們仔細(xì)分析一下,發(fā)現(xiàn)這里肯定是進(jìn)行了隱式轉(zhuǎn)換了,為此我們?cè)偌右粭l語(yǔ)句看看(ui+i)的值到底是多少:

代碼版本二:

#include #include int main()
{
     short s ='a';
     unsigned int ui = 100;
     int i = -200;
     double d = i;

     std::cout<<"d =" << d <"ui= "<if((ui+i)>0)
     {
        std::cout<<"(ui+i) = "<"Postive"<else {
        std::cout<<"Negative"<return 0;
}

輸出結(jié)果:

root@txp-virtual-machine:/home/txp# ./a.out d =-200
ui= 100
(ui+i) = 4294967196
Postive

注解:通過(guò)打印(ui+i)的值我們發(fā)現(xiàn),i原本是int數(shù)據(jù)類(lèi)型,這里隱式轉(zhuǎn)換成無(wú)符號(hào)的數(shù)據(jù)類(lèi)型了

為了讓大家更加理解隱式的轉(zhuǎn)換,我們下面再來(lái)一個(gè)例子:

代碼版本三:

#include #include int main()
{
     short s ='a';
     unsigned int ui = 100;
     int i = -200;
     double d = i;

     std::cout<<"d =" << d <"ui= "<if((ui+i)>0)
     {
        std::cout<<"(ui+i) = "<"Postive"<else {
        std::cout<<"Negative"<"sizeof(s+'b') = "<'b')<return 0;
}

輸出結(jié)果:

root@txp-virtual-machine:/home/txp# g++ test.cpp root@txp-virtual-machine:/home/txp# ./a.out d =-200
ui= 100
(ui+i) = 4294967196
Postive
sizeof(s+'b') = 4

注解:這里我們發(fā)現(xiàn)sizeof出來(lái)的內(nèi)存大小是4個(gè)字節(jié)大??;其實(shí)這里編譯器把short和char類(lèi)型的都轉(zhuǎn)換int類(lèi)型了,所以最終兩個(gè)int數(shù)據(jù)相加,所占的內(nèi)存大小就是int類(lèi)型了。

所以咋們平時(shí)在寫(xiě)代碼的時(shí)候,腦袋里面要有這種寫(xiě)代碼謹(jǐn)慎的思維,防止出現(xiàn)這種隱式轉(zhuǎn)換的情況出現(xiàn),養(yǎng)成寫(xiě)代碼的好習(xí)慣

2、普通類(lèi)型與類(lèi)類(lèi)型之間能否進(jìn)行類(lèi)型轉(zhuǎn)換,類(lèi)類(lèi)型之間又是否能夠類(lèi)型轉(zhuǎn)換呢?

為了說(shuō)明這些問(wèn)題,咋們通過(guò)實(shí)際的代碼測(cè)試來(lái)看看啥情況:

代碼:普通類(lèi)型轉(zhuǎn)換成類(lèi)類(lèi)型

#include #include class Test{

public: Test()
    {

    }
    Test(int i)
    {

    }
};

int main()
{
     Test t;

     t =6; 從 C 語(yǔ)言角度,這里將 5 強(qiáng)制類(lèi)型轉(zhuǎn)換到 Test 類(lèi)型,只不過(guò)編譯器 在這里做了隱式類(lèi)型轉(zhuǎn)換 return 0;
}

輸出結(jié)果(顯示可以編譯通過(guò))

root@txp-virtual-machine:/home/txp# g++ test.cpp root@txp-virtual-machine:/home/txp# ./a.out 

代碼類(lèi)類(lèi)型轉(zhuǎn)換為普通類(lèi)型

#include #include class Test{

public: Test()
    {

    }
    Test(int i)
    {

    }
};

int main()
{
     Test t;

     int i = t; return 0;
}

輸出結(jié)果(沒(méi)有編譯通過(guò))

root@txp-virtual-machine:/home/txp# g++ test.cpp test.cpp: In function ‘int main()’:
test.cpp:21:14: error: cannot convert ‘Test’ to ‘int’ in initialization
      int i = t;
              ^

代碼類(lèi)類(lèi)型與類(lèi)類(lèi)型之間的轉(zhuǎn)換:

#include #include class Value{

};


class Test{

public: Test()
    {

    }
    Test(int i)
    {

    }
};

int main()
{
     Test t;
     Value i;

     t=i; return 0;
}

輸出結(jié)果(暫時(shí)還是不行,編譯不通過(guò)):

root@txp-virtual-machine:/home/txp# g++ test.cpp test.cpp: In function ‘int main()’:
test.cpp:27:7: error: no match for ‘operator=’ (operand types are ‘Test’ and ‘Value’)
      t=i;
       ^
test.cpp:27:7: note: candidate is:
test.cpp:9:7: note: Test& Test::operator=(const Test&)
 class Test{
       ^
test.cpp:9:7: note:   no known conversion for argument 1 from ‘Value’ to ‘const Test&’

說(shuō)明:上面的例子,我們只是簡(jiǎn)單的按照實(shí)際角度出發(fā),發(fā)現(xiàn)確實(shí)有寫(xiě)轉(zhuǎn)換行不通。那么真理到底是怎樣的?我們接著往下看

3、轉(zhuǎn)換構(gòu)造函數(shù)出廠(chǎng):

我們前面學(xué)習(xí)過(guò)構(gòu)造函數(shù),構(gòu)造函數(shù)它可以定義不同類(lèi)型的參數(shù);但是我們今天這里所說(shuō)的轉(zhuǎn)換構(gòu)造函數(shù)的定義時(shí)這樣的:

  • 有且僅有一個(gè)參數(shù)

  • 參數(shù)是基本類(lèi)型

  • 參數(shù)是其它類(lèi)型

接著我們對(duì)上面的普通數(shù)據(jù)類(lèi)型轉(zhuǎn)換類(lèi)類(lèi)型的代碼進(jìn)行分析:

#include #include class Test{

public: Test()
    {

    }
    Test(int i)
    {

    }
};

int main()
{
     Test t;

     t =6; //從 C 語(yǔ)言角度,這里將 5 強(qiáng)制類(lèi)型轉(zhuǎn)換到 Test 類(lèi)型,只不過(guò)編譯器 在這里做了隱式類(lèi)型轉(zhuǎn)換 return 0;
}

分析:

上面的Test(int i )就是一個(gè)轉(zhuǎn)換構(gòu)造函數(shù),所以我們上面的這句隱式轉(zhuǎn)換語(yǔ)句:

t =6

這里其實(shí)發(fā)生了我們剛才說(shuō)的利用了轉(zhuǎn)換構(gòu)造函數(shù),把6轉(zhuǎn)換成Test(6),而這樣寫(xiě)就會(huì)產(chǎn)生一臨時(shí)對(duì)象,所以就可以進(jìn)行賦值了;但是在現(xiàn)在的技術(shù)發(fā)展中,肯定是不希望出現(xiàn)這種要人去防止這隱式轉(zhuǎn)換,所以在c++中有了新技術(shù)來(lái)防止出現(xiàn)隱式轉(zhuǎn)換:

  • 工程中通過(guò)explicit關(guān)鍵字杜絕編譯器的轉(zhuǎn)換嘗試

  • 轉(zhuǎn)換構(gòu)造函數(shù)被explicit修飾只能進(jìn)行顯示轉(zhuǎn)換(也就是強(qiáng)制類(lèi)型轉(zhuǎn)換)

代碼實(shí)踐一:

#include #include class Test{

public: Test()
    {

    }
   explicit Test(int i)
    {

    }
};

int main()
{
     Test t;

     t =6; return 0;
}

輸出結(jié)果:

root@txp-virtual-machine:/home/txp# g++ test.cpp test.cpp: In function ‘int main()’:
test.cpp:21:8: error: no match for ‘operator=’ (operand types are ‘Test’ and ‘int’)
      t =6;
        ^
test.cpp:21:8: note: candidate is:
test.cpp:4:7: note: Test& Test::operator=(const Test&)
 class Test{
       ^
test.cpp:4:7: note:   no known conversion for argument 1 from ‘int’ to ‘const Test&’

注解:這里顯示不能這樣轉(zhuǎn)換

代碼實(shí)踐二(進(jìn)行顯示轉(zhuǎn)換):

#include #include class Test{

public: Test()
    {

    }
   explicit Test(int i)
    {

    }
};

int main()
{
     Test t;

     t =static_cast(6); return 0;
}

輸出結(jié)果(編譯通過(guò)):

root@txp-virtual-machine:/home/txp# g++ test.cpp root@txp-virtual-machine:/home/txp#  

4、小結(jié):

  • 轉(zhuǎn)換構(gòu)造函數(shù)只有一個(gè)參數(shù)

  • 轉(zhuǎn)換構(gòu)造函數(shù)的參數(shù)類(lèi)型是其它類(lèi)型

  • 轉(zhuǎn)換構(gòu)造函數(shù)在類(lèi)型轉(zhuǎn)換時(shí)被調(diào)用

  • 隱式類(lèi)型轉(zhuǎn)換是工程中bug的重要來(lái)源

  • explicit關(guān)鍵字用于杜絕隱式類(lèi)型轉(zhuǎn)換

二、類(lèi)型轉(zhuǎn)換函數(shù):

1、類(lèi)類(lèi)型轉(zhuǎn)換普通類(lèi)型:

在我們上面通過(guò)代碼測(cè)試發(fā)現(xiàn)不行,那么是真的不行嗎,事實(shí)是可以進(jìn)行轉(zhuǎn)換的,不過(guò)要用到我們現(xiàn)在c++里面的類(lèi)型轉(zhuǎn)換函數(shù)(它用于將類(lèi)對(duì)象轉(zhuǎn)換為其它類(lèi)型),類(lèi)型轉(zhuǎn)換的語(yǔ)法如下:

operator Type()
{
    Type ret; return ret;

}

代碼實(shí)踐:

#include #include class Test{

public: Test()
    {

    }
   operator int()
   {

    }
};

int main()
{
     Test t;
     int i =t; return 0;
}

輸出結(jié)果(編譯沒(méi)有報(bào)錯(cuò)):

root@txp-virtual-machine:/home/txp# g++ test.cpp root@txp-virtual-machine:/home/txp#  

注:

  • 與轉(zhuǎn)換構(gòu)造函數(shù)具有同等的地位

  • 使得編譯器有能力將對(duì)象轉(zhuǎn)化為其它類(lèi)型

  • 編譯器能夠隱式的使用類(lèi)型轉(zhuǎn)換函數(shù)

2、類(lèi)類(lèi)型之間的轉(zhuǎn)換:

這個(gè)問(wèn)題也是之前我們上面簡(jiǎn)單的測(cè)試,不能進(jìn)行類(lèi)類(lèi)型之間的轉(zhuǎn)換;現(xiàn)在我們學(xué)習(xí)了類(lèi)型轉(zhuǎn)換函數(shù),是可以進(jìn)行轉(zhuǎn)換的:

代碼版本一:

#include #include using namespace std;

class Test;

class Value
{
public: Value()
    {
    }
    explicit Value(Test& t)
    {
    }
};

class Test
{
    int mValue;
public:
    Test(int i = 0)
    {
        mValue = i;
    }
    int value()
    { return mValue;
    }
    operator Value()
    {
        Value ret;
        cout << "operator Value()" << endl; return ret;
    }
/*工程上通過(guò)以下方式;
  Value toValue()
  {
      Value ret; return ret;
  
  }
};

int main()
{   
    Test t(100);
    Value v = t; return 0;
}

輸出結(jié)果(編譯通過(guò)):

root@txp-virtual-machine:/home/txp# g++ test.cpp root@txp-virtual-machine:/home/txp#  

注意:這里還有一種讓編譯器犯難的轉(zhuǎn)換寫(xiě)法;我們上面這樣寫(xiě)是用explicit關(guān)鍵字屏蔽了Value類(lèi)里面的隱式轉(zhuǎn)換,所以不會(huì)犯難,下面是犯難的代碼示例

#include #include using namespace std;

class Test;

class Value
{
public: Value()
    {
    }
     Value(Test& t)
    {
    }
};

class Test
{
    int mValue;
public:
    Test(int i = 0)
    {
        mValue = i;
    }
    int value()
    { return mValue;
    }
    operator Value()
    {
        Value ret;
        cout << "operator Value()" << endl; return ret;
    }
};

int main()
{   
    Test t(100);
    Value v = t; return 0;
}

輸出結(jié)果:

root@txp-virtual-machine:/home/txp# g++ test.cpp test.cpp: In function ‘int main()’:
test.cpp:42:15: error: conversion from ‘Test’ to ‘Value’ is ambiguous
     Value v = t;
               ^
test.cpp:41:10: note: candidates are:
     Test t(100);
          ^
test.cpp:31:5: note: Test::operator Value()
     operator Value()
     ^
test.cpp:14:6: note: Value::Value(Test&)
      Value(Test& t)

3、小結(jié):

  • 無(wú)法抑制隱式的類(lèi)型轉(zhuǎn)換函數(shù)調(diào)用

  • 類(lèi)型轉(zhuǎn)換函數(shù)可能與轉(zhuǎn)換構(gòu)造函數(shù)起沖突

  • 當(dāng)然工程中可能比較習(xí)慣用 Type toType()的公有成員代替類(lèi)型轉(zhuǎn)換函數(shù)(就是換了種寫(xiě)法)

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀(guān)點(diǎn),不代表本平臺(tái)立場(chǎng),如有問(wèn)題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀(guān)點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車(chē)的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車(chē)技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車(chē)工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車(chē)。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車(chē) 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶(hù)希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱(chēng),數(shù)字世界的話(huà)語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱(chēng)"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉