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

小星星的天空

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 閱讀(2845) 評論(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>
            亚洲国产黄色| 亚洲人成久久| 性久久久久久久久久久久| 国产精品久久国产三级国电话系列| 亚洲美女诱惑| 日韩视频免费在线观看| 欧美午夜a级限制福利片| 亚洲视频一区在线| 99国产成+人+综合+亚洲欧美| 欧美日韩国产123| 亚洲欧美日韩国产一区二区三区 | 午夜精品久久久久久久白皮肤 | 久久九九免费视频| 久久福利一区| 亚洲精品免费观看| 亚洲网站在线观看| 国模精品一区二区三区| 欧美xxx成人| 欧美日韩视频在线第一区| 亚洲欧美自拍偷拍| 久久婷婷丁香| 亚洲图中文字幕| 欧美一区二区三区视频在线观看| 精品成人免费| 一区二区av| 韩国av一区二区三区四区| 欧美激情在线观看| 国产精品入口夜色视频大尺度| 欧美一区二区精美| 欧美激情成人在线| 久久久精品999| 欧美精品三区| 久久久精品动漫| 欧美伦理a级免费电影| 久久精品一区二区国产| 欧美精品在线视频观看| 久久精品av麻豆的观看方式 | 亚洲精品免费看| 国产麻豆视频精品| 亚洲国产三级在线| 国产午夜亚洲精品理论片色戒| 亚洲福利视频专区| 国产午夜精品理论片a级大结局| 欧美激情精品久久久久久久变态| 国产精品美女一区二区| 亚洲大片精品永久免费| 国产亚洲精品资源在线26u| 亚洲精品在线电影| 亚洲大片精品永久免费| 亚洲一区二区成人在线观看| 亚洲黑丝一区二区| 久久精品中文字幕一区| 欧美亚洲专区| 国产精品嫩草影院av蜜臀| 欧美激情视频在线免费观看 欧美视频免费一 | 久久狠狠婷婷| 欧美一区二区精品久久911| 欧美精品国产精品日韩精品| 欧美xxx在线观看| 韩国av一区二区| 午夜精品视频一区| 欧美一级艳片视频免费观看| 欧美日韩在线一区二区| 亚洲三级视频在线观看| 亚洲精品日日夜夜| 久久男人资源视频| 麻豆精品网站| 激情亚洲网站| 久久婷婷亚洲| 美女久久一区| 亚洲国产精品一区二区www在线| 欧美在线观看视频在线| 久久网站热最新地址| 狠狠色狠狠色综合| 久久精品国产亚洲精品| 久久久综合网站| 一区二区三区自拍| 久久综合中文| 91久久黄色| 在线视频欧美日韩| 国产精品国产三级欧美二区| 中国日韩欧美久久久久久久久| 亚洲伊人网站| 国产一区二区三区高清| 久久精品一区二区| 欧美成人免费全部观看天天性色| 亚洲国产精品久久久| 欧美精品一区二区三区一线天视频 | 日韩视频免费在线观看| 欧美日韩999| 亚洲制服少妇| 麻豆国产精品一区二区三区 | 国产欧美日韩综合| 久久精品三级| 亚洲人成人一区二区在线观看 | 黄色成人免费观看| 久久夜色精品国产欧美乱极品 | 久久精品国产免费观看| 黄色资源网久久资源365| 免费一级欧美片在线观看| 亚洲全黄一级网站| 久久gogo国模啪啪人体图| 在线观看亚洲视频| 欧美日本一区| 久久久91精品国产| 亚洲精品一区二区三区樱花| 午夜一区二区三区在线观看| 亚洲国产精品123| 欧美午夜宅男影院在线观看| 久久高清一区| av成人福利| 你懂的国产精品| 亚洲欧美日韩一区二区在线| 亚洲国产精品va在线观看黑人| 国产精品盗摄久久久| 久久久最新网址| 一区二区欧美国产| 欧美好骚综合网| 欧美一区影院| 亚洲天堂av综合网| 亚洲欧洲另类国产综合| 国产精品一区二区三区久久 | 小嫩嫩精品导航| 亚洲毛片一区二区| 欧美激情精品久久久久久| 久久久欧美一区二区| 亚洲小说欧美另类社区| 亚洲福利视频网站| 国产一区在线视频| 国产精品嫩草影院一区二区| 欧美精品在线观看91| 毛片基地黄久久久久久天堂| 羞羞漫画18久久大片| 亚洲视频欧美视频| 亚洲精品免费网站| 亚洲激情在线激情| 蜜臀久久99精品久久久久久9| 欧美综合激情网| 亚洲国产经典视频| 亚洲国语精品自产拍在线观看| 国产精品嫩草影院av蜜臀| 欧美日产国产成人免费图片| 免费成人激情视频| 男人的天堂亚洲在线| 老巨人导航500精品| 久久乐国产精品| 久久久久久9999| 久久久精品性| 久久综合久久久久88| 久久影视精品| 免费不卡欧美自拍视频| 久久综合国产精品| 男女激情视频一区| 欧美顶级少妇做爰| 欧美日韩xxxxx| 欧美无乱码久久久免费午夜一区| 欧美性色综合| 国产精品一区二区男女羞羞无遮挡| 欧美午夜宅男影院在线观看| 国产精品久久久91| 国产目拍亚洲精品99久久精品| 国产精品一区二区三区成人| 国内精品久久久久国产盗摄免费观看完整版| 国产免费一区二区三区香蕉精| 国产性色一区二区| 亚洲电影免费观看高清完整版在线观看 | 欧美黑人在线播放| 欧美精品自拍偷拍动漫精品| 欧美日韩国产不卡| 国产精品腿扒开做爽爽爽挤奶网站| 国产精品久久国产精麻豆99网站| 国产精品午夜电影| 在线观看欧美日韩| 一区二区三区欧美日韩| 久久国产99| 欧美成人激情在线| 99精品国产热久久91蜜凸| 亚洲自拍三区| 另类激情亚洲| 欧美亚韩一区| 一区视频在线| 亚洲一级黄色片| 老司机一区二区| 99精品视频免费全部在线| 欧美在线影院在线视频| 欧美成人r级一区二区三区| 国产精品大片免费观看| 亚洲电影欧美电影有声小说| 在线亚洲国产精品网站| 久久午夜影视| 99亚洲精品| 免费不卡在线观看av| 国产精品v欧美精品v日韩 | 精品动漫3d一区二区三区| 中日韩高清电影网| 久久综合一区二区三区| 中国女人久久久| 欧美极品欧美精品欧美视频| 国产一区二区三区成人欧美日韩在线观看 | 久热国产精品|