• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            woaidongmao

            文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評(píng)論 - 661, 引用 - 0
            數(shù)據(jù)加載中……

            猜猜看,id變成9了嗎?

            #include "stdafx.h"
            #include "stdio.h"
            struct TestStr
            {
                int id;
                void SetId(int id_new){id = id_new;} 
            };

            int main(int argc, char* argv[])
            {
                const TestStr ts = {1};
                const TestStr* p_ts = &ts;
                ((TestStr)(*p_ts)).SetId(9);
                printf("TestStr::id = %d\r\n",ts.id);
                return 0;
            }


            id還是等于1,不信試試,順便替換成下面這一句再試試看
            ((TestStr&)(*p_ts)).SetId(9);


            另外還有一個(gè)奇怪的問題:
            ((TestStr)(*p_ts)).SetId(9);      //編譯通過
            ((TestStr)(*p_ts)).id = 9;         //編譯不通過
            (&((TestStr)(*p_ts)))->id = 9; //編譯通過

            誰(shuí)可以解釋一下原因?不知。

            posted on 2008-04-01 22:03 肥仔 閱讀(1643) 評(píng)論(10)  編輯 收藏 引用 所屬分類: C++ 基礎(chǔ)

            評(píng)論

            # re: 猜猜看,id變成9了嗎?  回復(fù)  更多評(píng)論   

            ((TestStr)(*p_ts)).SetId(9); 如果變成(TestStr(*p_ts)).SetId(9);
            這其實(shí)相當(dāng)于調(diào)用了TestStr(const TestStr&)生成了一個(gè)TestStr&的臨時(shí)變量。
            按理來(lái)說這三個(gè)應(yīng)該都可以,確實(shí)在gcc 4.1.3下可以全部編譯通過的。
            這個(gè)可能和編譯器有關(guān),在編譯((TestStr)(*p_ts)).id = 9; 時(shí)生成的臨時(shí)變量可能為const的,所以編譯不過。
            2008-04-01 23:18 | www

            # re: 猜猜看,id變成9了嗎?  回復(fù)  更多評(píng)論   

            @www
            //((TestStr)(*p_ts)).SetId(9); 如果變成(TestStr(*p_ts)).SetId(9);
            ((TestStr)(*p_ts)).SetId(9); 和(TestStr(*p_ts)).SetId(9); 是一樣的,//上面寫錯(cuò)了
            2008-04-01 23:20 | www

            # re: 猜猜看,id變成9了嗎?  回復(fù)  更多評(píng)論   

            C++標(biāo)準(zhǔn)規(guī)定,類性轉(zhuǎn)換表達(dá)式的目標(biāo)類型為引用時(shí),結(jié)果為l-value;否則為r-value

            對(duì)于built-in 類型,r-value是不可修改的;而對(duì)于user-defined類型,r-value在某些情況下是允許修改的

            GCC編譯沒問題,m$對(duì)標(biāo)準(zhǔn)的支持存在問題吧
            2008-04-02 00:01 | 嘯天豬

            # re: 猜猜看,id變成9了嗎?  回復(fù)  更多評(píng)論   

            關(guān)于結(jié)果等于1的問題,((TestStr)(*p_ts)) 新生成了一個(gè)對(duì)象,因?yàn)閜_ts指向的是const
            2008-04-02 09:27 | hsen

            # re: 猜猜看,id變成9了嗎?  回復(fù)  更多評(píng)論   

            ((TestStr)(*p_ts)).SetId(9); //編譯通過
            ((TestStr)(*p_ts)).id = 9; //編譯不通過
            (&((TestStr)(*p_ts)))->id = 9; //編譯通過


            我在VS2005下:
            正如作者所說中間的是編不過的,error,說是l-value不能賦值。
            但是能編過的2個(gè)結(jié)果都還是1,沒有修改了原來(lái)的值,因?yàn)樵陬愋娃D(zhuǎn)化的時(shí)候都調(diào)用了拷貝構(gòu)造函數(shù),從新生成一個(gè)對(duì)象你修改的是拷貝后的臨時(shí)對(duì)象。(你可以寫拷貝構(gòu)造函數(shù)測(cè)試一下)


            所以同意:
            這其實(shí)相當(dāng)于調(diào)用了TestStr(const TestStr&)生成了一個(gè)TestStr&的臨時(shí)變量。
            C++標(biāo)準(zhǔn)規(guī)定,類性轉(zhuǎn)換表達(dá)式的目標(biāo)類型為引用時(shí),結(jié)果為l-value;否則為r-value。


            2008-04-02 10:02 | 夢(mèng)在天涯

            # re: 猜猜看,id變成9了嗎?  回復(fù)  更多評(píng)論   

            類型轉(zhuǎn)換(非引用)必然會(huì)產(chǎn)生一個(gè)臨時(shí)對(duì)象。所有的一切問題都可以歸結(jié)到這里:
            ((TestStr)(*p_ts)).SetId(9);//產(chǎn)生non-const臨時(shí)對(duì)象,SetId()操作的是臨時(shí)對(duì)象,因此原對(duì)象不變
            ((TestStr&)(*p_ts)).SetId(9);//去掉原對(duì)象的const。可以寫成const_cast<TestStr&>(*p_ts)).SetId(9)
            ((TestStr)(*p_ts)).id = 9; //GCC可以編譯
            (&((TestStr)(*p_ts)))->id = 9; //編譯通過
            2008-04-02 13:57 | raof01

            # re: 猜猜看,id變成9了嗎?  回復(fù)  更多評(píng)論   

            @夢(mèng)在天涯
            這個(gè)有道理,有人驗(yàn)證過嗎?
            2008-04-02 16:16 | foobar

            # re: 猜猜看,id變成9了嗎?  回復(fù)  更多評(píng)論   

            你看下你的反匯編代碼就知道了。
            編譯的時(shí)候,常量在允許的情況下編譯器會(huì)幫你替換成立即數(shù)(因?yàn)榱⒓磳ぶ繁容^快)。
            所以你的printf("TestStr::id = %d\r\n",ts.id)在編譯的時(shí)候會(huì)當(dāng)成
            printf("TestStr::id = %d\r\n",1)編譯。
            但是ts所在內(nèi)存的內(nèi)容是的確已經(jīng)改變了。
            你把(*p_ts)打出來(lái)看看就知道了。
            對(duì)于指針,編譯器是沒有辦法在編譯的時(shí)候替換成立即數(shù)的。
            2008-04-02 19:52 | -.-:

            # re: 猜猜看,id變成9了嗎?  回復(fù)  更多評(píng)論   

            把void SetId(int id_new)的參數(shù)改成引用或指針類型試試?


            2008-04-08 17:45 | ww

            # re: 猜猜看,id變成9了嗎?  回復(fù)  更多評(píng)論   

            ((TestStr)(*p_ts)).SetId(9); //編譯通過
            ((TestStr)(*p_ts)).id = 9; //編譯不通過
            (&((TestStr)(*p_ts)))->id = 9; //編譯通過


            1,3 大家都講了,這個(gè)很好理解,實(shí)際上是生成了臨時(shí)的對(duì)象。編譯通過但是不會(huì)修改原來(lái)的變量。
            2 可以通過這個(gè)例子來(lái)理解

            class A;
            Func(A& p) {...}
            main()
            {
            Func(A());//編譯錯(cuò)誤,因?yàn)榕R時(shí)對(duì)象必須是const&
            }

            如果Func(A const&p) {A &c =(A&)p;c.xxx}這是合法的。
            所以3,就類似與后面這個(gè)Func 作的事情。

            臨時(shí)對(duì)象不能修改,這是c++標(biāo)準(zhǔn)規(guī)定的,在侯捷書More C++ Exception里面提到過的。至于g++可以編譯通過,G++在默認(rèn)拷貝時(shí)候構(gòu)造的對(duì)象多于1個(gè)造成的。大家可以在析構(gòu)函數(shù)里輸出就可以看出來(lái)了。
            2008-12-20 23:05 | 楊成
            99精品国产综合久久久久五月天| 精品国产乱码久久久久软件| 国产精品日韩欧美久久综合| 久久性精品| 亚洲av日韩精品久久久久久a | 日韩精品国产自在久久现线拍| 91久久国产视频| 久久久久亚洲AV片无码下载蜜桃| 久久99国产精品久久| 欧美性猛交xxxx免费看久久久| 久久综合香蕉国产蜜臀AV| 久久国产三级无码一区二区| 久久天天躁狠狠躁夜夜网站| 久久亚洲视频| 夜夜亚洲天天久久| 热re99久久6国产精品免费| 国产精品无码久久四虎| 久久丫精品国产亚洲av不卡| 无码人妻久久一区二区三区蜜桃| 一本久久a久久精品综合夜夜| 亚洲AV无码久久精品色欲| 婷婷久久综合九色综合绿巨人| 久久成人国产精品二三区| 久久精品亚洲日本波多野结衣| 精品伊人久久久| 无码乱码观看精品久久| 国产精品免费久久| 青青草国产精品久久久久| 九九精品99久久久香蕉| 日韩精品久久久久久免费| 久久综合亚洲色HEZYO国产| 久久久久无码专区亚洲av| 久久93精品国产91久久综合| 久久久久久狠狠丁香| 狠狠色丁香久久婷婷综| 国产婷婷成人久久Av免费高清 | 久久国产精品99久久久久久老狼 | 久久久久亚洲AV无码去区首| 国内精品伊人久久久久网站| 久久久久一级精品亚洲国产成人综合AV区| 久久亚洲国产中v天仙www |