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

小星星的天空

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>
            国产日韩欧美亚洲| 一本色道久久综合亚洲精品不| 国产欧美一区二区视频| 欧美四级伦理在线| 欧美日韩视频在线一区二区观看视频 | 销魂美女一区二区三区视频在线| 亚洲免费在线精品一区| 久久免费黄色| 蜜臀久久久99精品久久久久久 | 中国女人久久久| 亚洲图片在线| 久久黄色影院| 欧美激情精品久久久| 亚洲另类在线视频| 夜久久久久久| 久久精品噜噜噜成人av农村| 欧美成人免费全部| 国产精品日韩久久久久| 狠狠综合久久| 亚洲小视频在线| 久久这里有精品视频| 91久久精品久久国产性色也91| 亚洲国产精品一区二区尤物区| 这里只有精品视频在线| 久久人人爽爽爽人久久久| 欧美日韩一区综合| 在线观看亚洲一区| 亚洲欧美精品中文字幕在线| 牛牛精品成人免费视频| 亚洲香蕉网站| 欧美激情亚洲视频| 国产一区二区三区四区五区美女| 亚洲精品一品区二品区三品区| 欧美专区在线观看一区| 亚洲日本成人在线观看| 久久久久九九九| 国产视频在线观看一区二区| 亚洲私人黄色宅男| 亚洲高清精品中出| 久久久国产精品一区| 国产目拍亚洲精品99久久精品 | 久久九九国产精品怡红院| 国产精品mm| 99re热精品| 欧美国产精品久久| 久久米奇亚洲| 国产综合av| 欧美综合77777色婷婷| 日韩午夜精品视频| 欧美精品麻豆| 亚洲美女在线视频| 亚洲第一精品夜夜躁人人躁| 欧美一区日本一区韩国一区| 国产精品日本欧美一区二区三区| 99在线精品视频在线观看| 亚洲高清av| 欧美激情91| 日韩午夜中文字幕| 亚洲激情成人在线| 欧美激情第三页| 99视频有精品| 欧美精品123区| 久久亚洲精品一区二区| 国产亚洲福利| 久久不射网站| 久久国产婷婷国产香蕉| 韩日欧美一区| 欧美电影免费网站| 欧美mv日韩mv亚洲| 亚洲乱码一区二区| 99精品国产热久久91蜜凸| 欧美午夜一区| 久久国产精品一区二区| 久久精品视频免费| 亚洲二区在线视频| 亚洲经典三级| 欧美视频在线一区| 久久av在线看| 久热这里只精品99re8久| 亚洲欧洲一区二区在线播放| 亚洲日韩欧美视频一区| 欧美四级在线观看| 久久精品导航| 欧美大尺度在线观看| 在线视频你懂得一区| 亚洲在线中文字幕| 一区视频在线| 亚洲免费成人av| 国产日韩在线一区| 欧美国产另类| 欧美三区在线| 久久综合伊人77777尤物| 欧美精品一区二区三区在线播放| 亚洲一级在线观看| 久久久久国产精品一区二区| 在线视频免费在线观看一区二区| 性欧美超级视频| 亚洲精品一线二线三线无人区| 99国产精品久久久久久久成人热| 国产欧美欧美| 亚洲精品乱码久久久久久黑人| 国产精品视频免费| 亚洲国产日韩在线| 国产一区二区三区在线观看视频| 亚洲九九爱视频| 激情欧美丁香| 亚洲影院免费| 野花国产精品入口| 久久久久久久一区二区三区| 亚洲欧美日韩第一区| 欧美国产日韩一区二区在线观看| 久久成人人人人精品欧| 欧美日韩一区在线视频| 欧美激情四色 | 女同性一区二区三区人了人一| 亚洲在线一区| 欧美伦理视频网站| 欧美韩日视频| 精品99视频| 欧美在线日韩精品| 午夜日韩在线| 欧美色一级片| 伊人婷婷欧美激情| 一区二区黄色| 久久久亚洲一区| 久久免费黄色| 国产欧美精品日韩区二区麻豆天美| 99成人在线| 在线亚洲欧美专区二区| 猛男gaygay欧美视频| 看片网站欧美日韩| 精品91免费| 久久中文字幕一区| 毛片一区二区三区| 伊人成人在线视频| 久久久久久久久综合| 美女国产一区| 影音先锋亚洲一区| 久久亚洲精品一区| 欧美激情一区二区三区高清视频| 国内精品伊人久久久久av一坑| 先锋影音国产一区| 久久久免费av| 亚洲成色精品| 欧美国产一区视频在线观看| 亚洲精品国产精品国自产观看浪潮 | 亚洲精品乱码| 欧美精品国产一区| 亚洲精品国产精品乱码不99| 一本久道综合久久精品| 欧美日韩1区2区| 亚洲色图综合久久| 欧美一区二区三区四区在线观看地址 | 亚洲一级影院| 久久久精品2019中文字幕神马| 国产日韩欧美精品| 久久人人爽人人爽爽久久| 亚洲国产99| 先锋a资源在线看亚洲| 国内精品久久久久久久影视麻豆| 久久中文精品| 在线亚洲电影| 另类国产ts人妖高潮视频| 亚洲精品网站在线播放gif| 国产精品xxxxx| 久久一本综合频道| 一本色道精品久久一区二区三区| 欧美在线观看视频| 亚洲欧洲日本mm| 国产精品亚洲综合| 蜜桃av久久久亚洲精品| 99视频精品在线| 久久亚洲二区| 亚洲一区亚洲二区| 亚洲大片免费看| 国产精品成人观看视频免费 | 欧美成人精品| 亚洲资源在线观看| 在线播放国产一区中文字幕剧情欧美| 欧美护士18xxxxhd| 欧美一级久久久| 亚洲乱码久久| 欧美国产三级| 久久精品国产一区二区电影| 亚洲欧洲美洲综合色网| 国产欧美日韩在线视频| 欧美激情亚洲自拍| 欧美成人精品1314www| 国产精品区二区三区日本| 久久久精品日韩欧美| 日韩视频在线你懂得| 欧美xxxx在线观看| 欧美在线黄色| 亚洲一级在线观看| 亚洲剧情一区二区| 在线欧美影院| 红桃av永久久久| 国产偷国产偷亚洲高清97cao| 欧美日韩亚洲一区二区三区在线 | 欧美激情四色 |