青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

OnTheWay2012
埋葬昨天的我,迎來重生的我!
posts - 15,  comments - 89,  trackbacks - 0
今天在寫代碼的時(shí)候發(fā)現(xiàn)了一個(gè)很有意思的錯(cuò)誤,出錯(cuò)的代碼如下。
加入你的電腦里定義了JAVA_HOME這個(gè)環(huán)境變量,你能看出程序的輸出結(jié)果是什么嗎?
 1#include <iostream>
 2#include <assert.h>
 3#include <map>
 4#include <string>
 5
 6using namespace std;
 7
 8bool GetEnvByKey(string const &strKey, string &strValue)
 9{
10    bool bRet = false;
11
12    assert(!strKey.empty());
13
14    size_t sizeValue = 0;
15    if(0 == getenv_s(&sizeValue, NULL, 0, strKey.c_str()))
16    {
17        strValue.reserve(sizeValue);
18        bRet = (0 == getenv_s(&sizeValue, const_cast<char*>(strValue.c_str()), sizeValue, strKey.c_str()));
19    }

20
21    return bRet;
22}

23
24int main( )
25{
26    string strKey("JAVA_HOME");
27    string strValue;
28    
29    if(GetEnvByKey(strKey, strValue))
30    {
31        cout<<strKey<<endl;
32        cout<<strValue<<endl;
33
34        map<stringstring> mapEnvInfo;
35        mapEnvInfo.insert(mapEnvInfo.end(), make_pair(strKey, strValue));
36
37        cout<<mapEnvInfo.size()<<endl;
38        cout<<mapEnvInfo.begin()->first<<endl;
39        cout<<mapEnvInfo.begin()->second<<endl;
40    }

41
42    return 0;
43}


先把你猜想的結(jié)果寫出來,然后再把代碼復(fù)制到VC里你試一下,看看到底輸出什么。你猜對(duì)了嗎?是不是輸出結(jié)果有點(diǎn)不太對(duì)?呵呵,經(jīng)過調(diào)試代碼你發(fā)現(xiàn)錯(cuò)誤了嗎?
錯(cuò)誤就在
strValue.reserve(sizeValue);
bRet = (0 == getenv_s(&sizeValue, const_cast<char*>(strValue.c_str()), sizeValue, strKey.c_str()));
這兩行。
錯(cuò)在這種使用strValue的方式,詳述如下:
strValue.reserve(sizeValue)這句代碼給strValue分配了sizeValue字節(jié)的內(nèi)存,然后getenv_s又把從操作系統(tǒng)里取得的值賦給了strValue所代表的內(nèi)存中,請(qǐng)注意strValue除了有指向字符串的內(nèi)存數(shù)組,還有一個(gè)記錄該字符串中保存的字符數(shù)的一個(gè)變量_Mysize。上面的getenv_s執(zhí)行后只是把字符串給賦值了,但是這個(gè)記錄字符串中字符個(gè)數(shù)的變量卻沒有賦值。下面的代碼需要使用這個(gè)變量才能進(jìn)行輸出,而此時(shí)這個(gè)變量是0,所以strValue就沒有輸出。
經(jīng)過上面的說明之后你肯定明白了上述代碼出錯(cuò)的原因。為什么會(huì)出錯(cuò)?是因?yàn)槲覀兪褂胹trValue的時(shí)候把它認(rèn)為成了數(shù)組,所以就出錯(cuò)了。本來strValue是一個(gè)對(duì)象,它具有各種方法,但是我們的使用方式強(qiáng)迫strValue脫下外衣,強(qiáng)迫它變成赤裸裸的字符串?dāng)?shù)組,這就是問題的發(fā)生根源。因此我們使用類對(duì)象的時(shí)候一定不能把類的外衣脫掉,讓類帶來的好處消失于無形。
posted on 2010-04-02 22:30 OnTheWay 閱讀(2818) 評(píng)論(9)  編輯 收藏 引用 所屬分類: C、C++

FeedBack:
# re: 不要把類的外衣脫下來,讓類的美麗消失于無形
2010-04-02 22:54 | 楊帆
恩,明白,有收獲。3Q。  回復(fù)  更多評(píng)論
  
# re: 不要把類的外衣脫下來,讓類的美麗消失于無形
2010-04-02 23:10 | 楊帆
不對(duì),我又看了看,我覺得樓主的理解似乎有問題,也請(qǐng)指教指教。

strValue.reserve(sizeValue);
bRet = (0 == getenv_s(&sizeValue, const_cast<char*>(strValue.c_str()), sizeValue, strKey.c_str()));

的確是這里有問題,問題的確出在const_cast<char*>(strValue.c_str())這個(gè)表達(dá)式上。

但是樓主想表達(dá)的意思是不是getenv_s()這個(gè)函數(shù)把strValue這個(gè)string類型“強(qiáng)行”當(dāng)做的了一個(gè)字符串來進(jìn)行處理,這個(gè)函數(shù)修改strValue的時(shí)候,僅僅修改了“一部分”?

我想應(yīng)該是這樣,const_cast<char*>(strValue.c_str())是這么執(zhí)行的:
1、strValue.c_str() 這里strValue返回了一個(gè)”臨時(shí)的“字符串,注意,是臨時(shí)的而且是const的,它應(yīng)該是新開辟了一小段內(nèi)存用以存儲(chǔ)這個(gè)C-Style字符串,而不是把strValue本身當(dāng)做字符串給返回回去了。

2、使用const_cast<char *>將這個(gè)const 并且”臨時(shí)的“字符串進(jìn)行了轉(zhuǎn)換,轉(zhuǎn)換成了 非const ,但仍然是臨時(shí)的字符串。

3、然后getenv_s()函數(shù)會(huì)對(duì)這個(gè)臨時(shí)非const的字符串進(jìn)行一些操作。

4、隨著函數(shù)調(diào)用的結(jié)束,這個(gè)臨時(shí)的字符串被釋放掉了。

在上邊這個(gè)過程中,并沒有對(duì)strValue進(jìn)行任何改變,也正因此在以后才什么都沒有輸出來。

和樓主不一樣的是,getenv_s()根本沒有對(duì)strValue進(jìn)行任何操作。  回復(fù)  更多評(píng)論
  
# re: 不要把類的外衣脫下來,讓類的美麗消失于無形
2010-04-03 08:59 | OnTheWay
@楊帆
謝謝你的關(guān)注。
不過strValue.c_str()沒有返回什么臨時(shí)的指針。
因?yàn)閏_str()函數(shù)返回的是一個(gè)char const *類型,這說明返回的指針是不可寫的。但是我為了讓返回的指針可寫,所以加了const_cast。這同時(shí)說明有const_cast的地方都存在潛在的錯(cuò)誤。你可以在VC2005的debug版下看看程序具體的執(zhí)行過程,在此過程中沒有創(chuàng)建臨時(shí)的字符串?dāng)?shù)組。  回復(fù)  更多評(píng)論
  
# re: 不要把類的外衣脫下來,讓類的美麗消失于無形
2010-04-03 09:24 | CBKID
@楊帆
我也感覺有點(diǎn)像你的看法,但是如果這樣的話可以先給strValue賦值,如果真的沒有進(jìn)行任何操作的話結(jié)果就很顯眼了。  回復(fù)  更多評(píng)論
  
# re: 不要把類的外衣脫下來,讓類的美麗消失于無形
2010-04-03 13:06 | 楊帆
@OnTheWay
感謝樓主,恩,我驗(yàn)證了一下,我的理解不正確,不好意思哈,也感謝從你這學(xué)到了東西,3Q。

我用下列代碼進(jìn)行了驗(yàn)證,在gcc下編譯通過。

#include <iostream>
#include <string>
using namespace std;

int main(){
string CppString("我是一個(gè)string啊,咿呀咿呀喲!");

//在這里用c_str()返回了一個(gè)CStyle字符串,保存在CStyleString上
char * CStyleString = const_cast< char *>( CppString.c_str() );

//首先驗(yàn)證一下這個(gè)CStyleString的內(nèi)容是不是正確
cout << CStyleString <<endl;

//然后對(duì)CStyleString進(jìn)行一些改變。
cin >> CStyleString ;

//輸出改變后的CStyleString看看。
cout << CStyleString << endl;

//這時(shí)再輸出CppString的內(nèi)容,它改變了!。
cout << CppString <<endl;
return 0;
}

程序運(yùn)行如下:
我是一個(gè)string啊,咿呀咿呀喲!
我是一個(gè)CStyle String啊,咿呀咿呀喲! //這是我的輸入。
我是一個(gè)CStyle
我是一個(gè)CStyle ……&%¥*&…… //后邊一一堆亂碼,原因請(qǐng)見樓主的帖子。  回復(fù)  更多評(píng)論
  
# re: 不要把類的外衣脫下來,讓類的美麗消失于無形
2010-04-03 15:06 | 楊帆
進(jìn)一步琢磨,我在http://www.cplusplus.com/上查了查c_str的描述,連接為:http: //www.cplusplus.com/reference/string/string/c_str/
描述如下:
const char* c_str ( ) const;

Get C string equivalent
Generates a null-terminated sequence of characters (c-string) with the same content as the string object and returns it as a pointer to an array of characters.

A terminating null character is automatically appended.

The returned array points to an internal location with the required storage space for this sequence of characters plus its terminating null-character, but the values in this array should not be modified in the program and are only granted to remain unchanged until the next call to a non-constant member function of the string object.


關(guān)鍵位最后一段:(湊乎著翻譯下,大家海涵哈,不要覺得它慘不忍睹哈,^_^)

該函數(shù)所返回的指針(數(shù)組)指向該字符串的內(nèi)部(internal)位置,并且該位 置具有足夠存儲(chǔ)空間來存儲(chǔ)該字符序列以及表示結(jié)尾的空字符,但是返回?cái)?shù)組中的值在程序不應(yīng)該有任何修改并只應(yīng)被傳值使用(這里的grant實(shí)在譯不好,望 大牛們指教),直到下一次調(diào)用該字符串對(duì)象的非常(non-const)成員函數(shù)。

這一段話再次驗(yàn)證了樓主的說法。


  回復(fù)  更多評(píng)論
  
# re: 不要把類的外衣脫下來,讓類的美麗消失于無形
2010-04-03 19:44 | OnTheWay
@楊帆
感謝你的持續(xù)關(guān)注。
你的鉆研精神值得敬佩。  回復(fù)  更多評(píng)論
  
# re: 不要把類的外衣脫下來,讓類的美麗消失于無形
2010-04-05 08:18 | 99書城
福建省地方你們是地方  回復(fù)  更多評(píng)論
  
# re: 不要把類的外衣脫下來,讓類的美麗消失于無形
2010-04-13 02:29 | 欲三更
代碼沒看,但是要如lz所說的話,好無厘頭的錯(cuò)誤啊。。。  回復(fù)  更多評(píng)論
  

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理



<2010年4月>
28293031123
45678910
11121314151617
18192021222324
2526272829301
2345678

常用鏈接

留言簿(4)

隨筆分類

隨筆檔案

友情連接

搜索

  •  

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩国产综合久久| 中文欧美在线视频| 国产精品人人做人人爽| 欧美一区二区三区四区视频| 欧美精品久久久久久| 伊人色综合久久天天| 欧美中日韩免费视频| 亚洲免费视频观看| 国产精品日韩欧美综合| 亚洲男人的天堂在线aⅴ视频| 亚洲精品在线一区二区| 欧美精品123区| 夜夜精品视频| 日韩午夜在线电影| 欧美日韩一区在线观看| 亚洲视频在线观看| 日韩一级黄色大片| 欧美色道久久88综合亚洲精品| 日韩天堂av| 99精品免费网| 国产精品久久久久三级| 久久精品国亚洲| 久久全国免费视频| 99成人免费视频| 亚洲午夜高清视频| 国产亚洲网站| 亚洲国产成人精品女人久久久| 久久综合一区| 亚洲精品免费在线| 99pao成人国产永久免费视频| 欧美日韩专区在线| 性色av香蕉一区二区| 久久gogo国模裸体人体| 亚洲精品久久在线| 亚洲私人黄色宅男| 国产一二精品视频| 欧美国产激情二区三区| 欧美视频四区| 久久亚洲综合色一区二区三区| 久久综合九色99| 在线视频亚洲欧美| 午夜久久tv| 亚洲美女91| 亚洲欧美韩国| 亚洲美女在线视频| 亚洲欧美一区二区在线观看| 亚洲激情在线| 亚洲女ⅴideoshd黑人| 亚洲国产欧美一区| 亚洲午夜伦理| 最近中文字幕日韩精品 | 亚洲神马久久| 欧美在线观看日本一区| 亚洲人成在线观看一区二区| 亚洲桃花岛网站| 亚洲电影免费观看高清完整版在线| 亚洲精品之草原avav久久| 国产一区三区三区| 99国产精品视频免费观看一公开| 国产一区二区精品丝袜| 亚洲人成网站色ww在线| 国产欧美一区二区三区在线老狼| 欧美一级午夜免费电影| 欧美电影电视剧在线观看| 欧美午夜精品伦理| 欧美成人精品影院| 国产精品无码永久免费888| 亚洲第一色中文字幕| 国产美女诱惑一区二区| 99视频+国产日韩欧美| 在线观看欧美日韩| 欧美一区二区三区播放老司机| 亚洲视频1区2区| 可以看av的网站久久看| 欧美一级专区| 国产精品视频自拍| 一本一本久久a久久精品综合麻豆| 亚洲黄页一区| 久久久之久亚州精品露出| 久久大逼视频| 国产美女精品在线| 午夜亚洲激情| 亚洲欧美日韩精品久久奇米色影视| 男女av一区三区二区色多| 久久性天堂网| 国产真实精品久久二三区| 亚洲欧美日韩精品久久| 欧美一级播放| 国产精品一区在线观看| 亚洲午夜久久久| 欧美怡红院视频一区二区三区| 国产精品九九久久久久久久| 99精品热6080yy久久| 一区二区三区日韩| 欧美日韩美女一区二区| 亚洲精品永久免费| 亚洲作爱视频| 欧美日韩另类丝袜其他| 亚洲六月丁香色婷婷综合久久| 亚洲素人在线| 国产精品久久久久99| 亚洲一区免费| 欧美在线一区二区| 黑人巨大精品欧美一区二区小视频| 欧美在线视频在线播放完整版免费观看 | 黑丝一区二区三区| 久久国产天堂福利天堂| 久久美女性网| 亚洲国产天堂久久综合网| 女生裸体视频一区二区三区| 欧美激情第五页| 一个色综合av| 国产欧美一区二区三区另类精品 | 亚洲国产精品久久久久秋霞影院| 欧美一级理论片| 欧美在线视频一区二区三区| 国产综合婷婷| 国产精品高潮粉嫩av| 国产精品成人一区二区三区夜夜夜 | 久久精品国产一区二区三| 久久福利电影| 欧美成人r级一区二区三区| 亚洲黄色一区| 欧美视频你懂的| 亚洲愉拍自拍另类高清精品| 久久精品国产99国产精品| 在线观看一区| 欧美午夜精品久久久久久浪潮| 羞羞色国产精品| 亚洲国产成人av好男人在线观看| 一本大道av伊人久久综合| 国产精品美女久久久浪潮软件 | 亚洲一区在线观看免费观看电影高清| 欧美亚洲一区二区在线| 亚洲国产欧美在线| 国产精品美女久久久免费| 噜噜噜在线观看免费视频日韩| 亚洲麻豆av| 久久天堂av综合合色| 在线天堂一区av电影| 尤物九九久久国产精品的特点| 欧美日韩一区二区三区在线 | 亚洲国产黄色片| 欧美一区二区三区在| 亚洲精品国产精品国自产在线| 国产精品国产三级国产普通话蜜臀| 久久久精彩视频| 亚洲欧美国产精品桃花| 亚洲精品久久久久| 美腿丝袜亚洲色图| 午夜免费久久久久| 亚洲精品一区二区三区av| 国产亚洲综合性久久久影院| 欧美午夜不卡视频| 欧美激情按摩| 亚洲欧美日韩综合aⅴ视频| 亚洲日本成人在线观看| 国产一区二区三区av电影| 国产精品久久久久久久app| 欧美日本中文字幕| 欧美激情综合网| 欧美777四色影视在线| 久久久久国产精品人| 欧美一区激情| 亚洲永久免费观看| 一本色道久久88综合亚洲精品ⅰ| 91久久久精品| 亚洲欧洲在线视频| 亚洲国内高清视频| 亚洲国产精品va在线看黑人| 亚洲第一区色| 最新国产乱人伦偷精品免费网站 | 欧美视频观看一区| 午夜视频一区在线观看| 亚洲精品影院| 亚洲美女淫视频| 亚洲日本一区二区| 亚洲日本va午夜在线电影| 亚洲男女自偷自拍图片另类| 欧美国产免费| 久久久蜜桃一区二区人| 久久久av毛片精品| 久久国产加勒比精品无码| 欧美在线视频全部完| 欧美一区二区播放| 久久精品视频在线看| 欧美一级专区| 久久精品国产精品亚洲| 久久先锋影音| 亚洲成色精品| 9国产精品视频| 亚洲图片自拍偷拍| 欧美一区二区免费| 久久精品男女| 欧美电影免费观看网站| 欧美色区777第一页| 国产乱码精品一区二区三区忘忧草| 国产小视频国产精品| 一区二区在线视频| 亚洲免费av片|