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

小星星的天空

O(∩_∩)O 小月亮的fans ^_^

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  16 隨筆 :: 0 文章 :: 61 評論 :: 0 Trackbacks
通常在C的編程中,我們經常使用memset函數將一塊連續的內存區域清零或設置為其它指定的值,最近在移植一段java代碼到C++的時候,不當使用memset函數花費了我幾個小時的調試時間。對于虛函數的底層機制很多資料都有較詳細闡述,但對我個人而言,這次的調試讓我感觸頗深。

先來看一段代碼,在繼承的類Advance之中,有很多屬性字段,我希望將其清成0或NULL,于是在構造函數中我通過memset將當前類的所有屬性置0。

class Base{

public:

virtual void kickoff() = 0;

};
class Advance:public Base{

public:

Advance(){

memset(this, 0, sizeof(Advance));

}

void kickoff(){

count++;

//... do something else;

}

private:

int attr1, attr2;

char* label;

int count;

//... other attributes, they should be initiated to 0 or NULL at beginning.

};

int _tmain(int argc, _TCHAR* argv[])

{
Base* ptr = new Advance();
ptr->kickoff();
return 0;
}

這樣看似能正常運行,但運行程序時,你會發現類似于下面的錯誤:

TestVirtual.exe 中的 0x00415390 處未處理的異常: 0xC0000005: 讀取位置 0x00000000 時發生訪問沖突

同時斷點停留在ptr->kickoff()處,從錯誤提示我們可以得知無法調用kickoff方法,這個方法的指針沒有被正確初始化,但為什么呢?

指出問題之前,先看看這段文獻上的關于虛函數機制的說明:

函數賴以生存的底層機制:vptr + vtable。虛函數的運行時實現采用了VPTR/VTBL的形式,這項技術的基礎:
①編譯器在后臺為每個包含虛函數的類產生一個靜態函數指針數組(虛函數表),在這個類或者它的基類中定義的每一個虛函數都有一個相應的函數指針。
②每個包含虛函數的類的每一個實例包含一個不可見的數據成員vptr(虛函數指針),這個指針被構造函數自動初始化,指向類的vtbl(虛函數表)
③當客戶調用虛函數的時候,編譯器產生代碼反指向到vptr,索引到vtbl中,然后在指定的位置上找到函數指針,并發出調用。

這里的問題,就出在

memset(this, 0, sizeof(Advance));

上面,虛函數指針應該在進入構造函數賦值體之前自動初始化的,而memset卻又將已經初始化好的指針清0了,這就是為什么會產生上面的訪問零址的錯誤。將上面的memset語句去除程序就可以正常運行了。

所以,從上面的問題中,我們可以看出在構造函數體內調用memset將整個對象清0是很有風險的,當沒有虛函數的時候上面程序可以正常運行(可以試著將Base類的純虛函數聲明改成非虛函數再運行程序)。初始化類的屬性對象時,比較穩妥的辦法還是手動逐個進行初使化
posted on 2009-10-20 21:11 Little Star 閱讀(2835) 評論(7)  編輯 收藏 引用 所屬分類: 找工作

評論

# re: 【轉】不當使用memset函數帶來的麻煩問題 2009-10-20 22:32 OwnWaterloo
沒有虛函數也不可以亂來。
空指針并不一定是二進制全0。

1.
char* label = 0;

2.
char* label;
memset(&label,0,sizeof(label) );

有平臺上兩者功能不同。

  回復  更多評論
  

# re: 【轉】不當使用memset函數帶來的麻煩問題 2009-10-21 10:47 Little Star
謝謝!@OwnWaterloo
  回復  更多評論
  

# re: 【轉】不當使用memset函數帶來的麻煩問題 2009-10-21 21:11 周龍亭
在C++中不能用memset來初始化一個類。
你上面的的代碼,其實是用寫C代碼的習慣來寫C++代碼,
推薦LZ全新的學習C++。  回復  更多評論
  

# re: 【轉】不當使用memset函數帶來的麻煩問題 2009-10-21 23:02 Little Star
@周龍亭

這個是我轉的,不代表我的意見。
問題是如果說一個類有上千個屬性的話,要咋清零呢?
  回復  更多評論
  

# re: 【轉】不當使用memset函數帶來的麻煩問題 2009-10-21 23:39 OwnWaterloo
@Little Star
class C {
/* data declaration */
public:
C() { memset(this,0,sizeof(*this); }
};

改為:
class C {
struct data {
/* data declaration */
} data_;
public:
C() { memset(&data_,0,sizeof(data_); }
};


還是需要注意memset( ... 0 ... );
不能保證: 指針是nullptr,浮點數是0.0, 0.0f, 0.0lf。
能保證:整數是0, 字符是null字符,即'\0'。

  回復  更多評論
  

# re: 【轉】不當使用memset函數帶來的麻煩問題[未登錄] 2009-10-22 01:52 Little star
@OwnWaterloo
那,有誰能講講為什么不能保證:指針是nullptr,浮點數是0.0, 0.0f, 0.0lf呢?  回復  更多評論
  

# re: 【轉】不當使用memset函數帶來的麻煩問題 2009-10-22 02:40 OwnWaterloo
@Little star
標準就這么規定的。

《C 語言常見問題集》 5.14中介紹了一些古怪的空指針。
“至少PL/I, Prime 50 系列用段07777, 偏移0 作為空指針。
……
CDC Cyber 180 系列使用包含環(ring), 段和位移的48 位指針。多數用戶
(在環11 上) 使用的空指針為0xB00000000000。
在舊的1 次補碼的CDC 機器上
用全1 表示各種數據, 包括非法指針, 是十分常見的事情。
Symbolics Lisp 機器是一種標簽結構, 它甚至沒有傳統的數字指針; 它使用
<NIL, 0> 對(通常是不存在的<對象, 偏移> 句柄) 作為C 空指針。


浮點如果是采用IEEE754, 0.0恰好是二進制全0。
但標準沒有保證浮點數一定采用IEEE754。

  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲美女视频网| 在线观看中文字幕不卡| 欧美伊人久久久久久久久影院 | 欧美激情一区二区三级高清视频| 久久午夜国产精品| 欧美不卡三区| 欧美日韩免费一区| 国产精品影片在线观看| 国产一区二区| 亚洲国产欧美日韩| 一区二区三区精品在线| 久久xxxx精品视频| 亚洲福利国产| 99热在这里有精品免费| 欧美一区二区视频97| 久久久精品性| 国产综合色在线| 亚洲高清视频在线观看| 99国产精品国产精品毛片| 欧美亚洲视频在线看网址| 模特精品裸拍一区| 99爱精品视频| 久久久久免费视频| 国产精品啊啊啊| 亚洲激情影院| 久久精品国产91精品亚洲| 欧美不卡视频| 亚洲欧美在线观看| 欧美日本三级| 亚洲高清av| 久久精品亚洲热| 一区二区高清视频在线观看| 久久婷婷国产综合尤物精品| 国产精品老女人精品视频| 亚洲激情影视| 嫩草国产精品入口| 欧美一站二站| 国产欧美1区2区3区| 亚洲天堂免费在线观看视频| 欧美国产日韩xxxxx| 欧美在线亚洲| 国产美女精品视频| 亚洲伊人观看| 日韩午夜黄色| 欧美人牲a欧美精品| 91久久在线视频| 你懂的视频一区二区| 久久国产视频网| 国产欧美日韩伦理| 香蕉久久夜色| 亚洲美女精品久久| 欧美激情一区二区三区在线视频观看| 黄色成人在线观看| 久久久噜噜噜久久中文字幕色伊伊 | 亚洲国产精品尤物yw在线观看| 欧美自拍丝袜亚洲| 狠狠色狠狠色综合日日tαg| 久久久精彩视频| 久久精品青青大伊人av| 国内在线观看一区二区三区| 久久精品视频亚洲| 久久久欧美精品sm网站| 一区视频在线看| 欧美成人精品| 欧美国产一区视频在线观看| 99视频精品全部免费在线| 91久久香蕉国产日韩欧美9色| 欧美成人综合| 亚洲免费视频一区二区| 亚洲午夜国产成人av电影男同| 国产精品美女一区二区| 欧美一级片在线播放| 国产精品久久久久久影视| 亚洲第一精品夜夜躁人人爽 | 亚洲精品在线一区二区| 国产一区二区三区四区老人| 一区二区三区精品| 亚洲黄色成人| 国产精品人人爽人人做我的可爱 | 欧美片网站免费| 亚洲人成亚洲人成在线观看图片| 久久精品中文字幕一区二区三区| 国产在线欧美| 亚洲第一精品福利| 欧美午夜精品久久久| 久久国产加勒比精品无码| 欧美专区在线观看一区| 亚洲欧洲一区二区三区久久| 亚洲丝袜av一区| 精品二区视频| 野花国产精品入口| 国产综合精品一区| 亚洲精品女人| 国产精品视频99| 欧美成人综合网站| 欧美性一区二区| 欧美成人免费网| 国产精品美女视频网站| 欧美国产视频在线观看| 国产精品性做久久久久久| 欧美黑人一区二区三区| 国产精品一二三视频| 亚洲第一精品夜夜躁人人爽| 国产欧美精品一区| 亚洲免费不卡| 亚洲激情av| 午夜国产精品影院在线观看| 久久高清福利视频| 亚洲欧美激情一区二区| 欧美成人精品| 麻豆精品网站| 国产视频一区三区| 日韩系列在线| 一本久道久久久| 欧美3dxxxxhd| 免费观看日韩| 伊人狠狠色j香婷婷综合| 亚洲女同在线| 亚洲欧美日韩在线综合| 欧美日韩亚洲一区二| 亚洲成人在线视频播放| 黄网站色欧美视频| 欧美国产先锋| 西瓜成人精品人成网站| 国产模特精品视频久久久久| 艳妇臀荡乳欲伦亚洲一区| 亚洲精品视频在线播放| 久久亚洲春色中文字幕| 久久综合给合久久狠狠狠97色69| 国产精品久久久久9999| 亚洲九九精品| 正在播放亚洲一区| 欧美激情视频在线播放| 欧美国产一区二区三区激情无套| 国产一区二区精品久久91| 亚洲午夜精品一区二区| 亚洲午夜精品一区二区| 欧美日韩精品国产| 亚洲精品一级| 正在播放欧美视频| 欧美日韩一区综合| 中文在线不卡视频| 亚洲欧美视频在线观看| 欧美性大战xxxxx久久久| 亚洲专区欧美专区| 久久精品亚洲乱码伦伦中文| 国产主播一区二区三区四区| 久久久国产午夜精品| 欧美福利网址| 一区二区三区不卡视频在线观看| 欧美精品情趣视频| 一区二区三区三区在线| 欧美亚洲综合另类| 伊人成人在线视频| 欧美精品免费观看二区| 亚洲一区二区不卡免费| 久久九九全国免费精品观看| 亚洲第一网站| 欧美日韩一区二| 亚洲欧美在线播放| 欧美va亚洲va国产综合| 99国产精品久久久久老师| 国产精品久久久久一区| 欧美专区在线观看| 亚洲区国产区| 久久精品国产免费看久久精品 | 亚洲精品国精品久久99热一| 欧美日韩xxxxx| 欧美一级视频精品观看| 亚洲东热激情| 久久av一区| 亚洲麻豆av| 国产一区成人| 欧美日韩在线免费视频| 久久精品国产精品亚洲精品| 亚洲人成网站777色婷婷| 欧美在线观看网站| 99视频有精品| 在线精品国产欧美| 国产欧美91| 国产精品第十页| 欧美成人精品在线播放| 欧美一区二区精品久久911| 亚洲精品专区| 欧美激情一区二区三区在线视频观看| 午夜激情综合网| 99精品欧美一区二区三区综合在线 | 亚洲精选成人| 激情成人av| 国产精品第一页第二页第三页| 亚洲高清自拍| 国产精品成人一区二区| 久久免费高清| 亚洲欧美中文日韩v在线观看| 蜜桃久久精品一区二区| 亚洲午夜羞羞片| 日韩视频久久| 91久久午夜| 在线观看一区| 黄色精品一区二区|