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

隨筆-90  評論-947  文章-0  trackbacks-0

先看一個例子。首先,我要寫一個vector;其次,為了使用方便,我需要提供一個帶 size 參數的構造函數。要求就這兩點。

那么,勢必要:

class vector
{
public:
    vector(size_t size)
    {
        // ...
        m_pData = new int[size]; // 假設就是 int 這樣的基本類型好了,以避免下面可能出現的離題
        // ...
    }
};

問題來了。new 不是有可能失敗嗎?失敗了在老編譯器里會返回 NULL(這個情形也先無視),在新編譯器里會拋異常。那么,在這里要不要進行檢查呢?如果檢查:

try
{
    m_pData = new int[size];
}
catch (...)
{

}

catch到了。那么在這里可以干啥呢?似乎。。。啥也干不了!作為構造函數,沒法使用返回值,自然只能使用異常來提示外界;既然本來就是異常,我又何必在這里 try 一次呢?(假設這里沒有其他錯誤要處理,也假設這里的類型是int之類的基本類型,不會出現執行元素的構造函數失敗的情形)

既然這里的 try 讓我們如此無奈,那么就不必 try 了。這個時候,我需要給 vector(size_t size) 標記上 throw 嗎?如果不標記,使用者怎么知道這里可能會有異常?如果標記了,或者沒標記但使用者意識到了,那么他會這樣用:

try
{
    vector v(10);
    // Task with v
    // ...
    // ...
    // ...
}
catch (...)
{
    // Error handler
}

因為 v 的作用域被限制在了 try 內,所以所有的與 v 相關的邏輯代碼全部要放在 try 內部了。這種樣子似乎與 C# 很像!在 C# 里,try...catch... 是標準的做法;但是在 C++ 里,似乎不會如此經常地用 try catch,要不然,為什么我見過的 C++ 代碼都不是這樣子的呢?兩年前在金山實習的時候,有一次我把 try...catch 當做通用的錯誤處理來做,所有的錯誤都搞成一種異常,返回值僅返回正常值。結果董波叔叔說,這樣子是不對滴,但是沒給出讓我信服理由,可能就是,C++ 的 try...catch 的性能很不好之類的。(C# 以及 Java 的 try...catch 的性能好嗎?)

好,既然大家都不這么辦,是不是這里也不用 try 了?于是,內存分配錯誤就讓它自生自滅了……記得以前某本書上看到,說這種情形下的處理,僅僅是一個道德問題而已。真的無解嗎?

如果放寬要求,不要求在構造函數提供內存分配,那倒是有一種解法——分兩階段構造:

class vector
{
public:
    vector()
    {
        // ...
    }
    bool allocate(size_t size)
    {
        try
        {
            m_pData = new int[size];
        }
        catch (...)
        {
            return false;
        }
        if (m_pData == NULL)
        {
            return false;
        }
        // Other code ...
        return true;
    }
};

但是使用起來就不“方便”了。現實中,這種情形倒是存在,如 CWindow 的 Create,還有啥啥啥的 Init 等等。

真的沒有辦法兼顧方便與安全嗎?

posted on 2010-03-30 22:31 溪流 閱讀(2406) 評論(15)  編輯 收藏 引用 所屬分類: C++

評論:
# re: 道德問題?論new操作失敗后的操作 2010-03-30 22:48 | OwnWaterloo
最近很活躍嘛  回復  更多評論
  
# re: 道德問題?論new操作失敗后的操作 2010-03-30 22:54 | OwnWaterloo
>>我需要給 vector(size_t size) 標記上 throw 嗎?如果不標記,使用者怎么知道這里可能會有異常?

不需要, 不標記就是throw all。

new失敗了
1 :讓bad_alloc直接向上拋就是了
為什么不需要大量的try catch?
因為向上拋的過程中會析構棧上的對象, 回滾狀態, 并找到一個處理器。
你會將代碼寫成異常安全的, 是吧?

2: 采用兩段式。
其實就是使用返回狀態代碼的處理方式了。

在某個函數f中, 先構造一個半成品, 在使用之前create或者怎樣。
如果失敗, 就通過狀態碼向f的調用者報告。
f的調用者g又可能向g的調用者繼續報告。
直到找到一個能處理的地方。

這其實和異常是相同的, 只是異常對這些過程是自動的。
  回復  更多評論
  
# re: 道德問題?論new操作失敗后的操作 2010-03-31 00:14 | 溪流
@OwnWaterloo
其實我不是很清楚什么叫異常安全。不知道異常安全是盡量避免寫出 try catch 還是盡量到處寫 try catch。但我潛意識里不喜歡寫 try catch,也不喜歡用會拋異常的東東,如 MFC 中的 CFile。  回復  更多評論
  
# re: 道德問題?論new操作失敗后的操作[未登錄] 2010-03-31 08:55 | chentan
樓主最近寫的都是非常敏感的話題  回復  更多評論
  
# re: 道德問題?論new操作失敗后的操作 2010-03-31 09:02 | 欣萌
Mark  回復  更多評論
  
# re: 道德問題?論new操作失敗后的操作 2010-03-31 09:14 | 溪流
@chentan
是嗎?哈哈~  回復  更多評論
  
# re: 道德問題?論new操作失敗后的操作 2010-03-31 09:15 | 溪流
@OwnWaterloo
因為最近又想起了那些困惑的事~~  回復  更多評論
  
# re: 道德問題?論new操作失敗后的操作 2010-03-31 10:39 | ljbxc
我也常遇到,很煩人的問題。  回復  更多評論
  
# re: 道德問題?論new操作失敗后的操作 2010-03-31 14:52 | OwnWaterloo
@溪流
這樣很好。 不要悶頭只顧寫代碼; 花一些時間思考。  回復  更多評論
  
# re: 道德問題?論new操作失敗后的操作 2010-03-31 15:42 | 陳梓瀚(vczh)
你只要覺得,你那一行發生的錯誤的話那么你的class就不能被創建,那就在那里拋異常。這樣可以使得你的class在那種情況下不可能被創建成功。  回復  更多評論
  
# re: 道德問題?論new操作失敗后的操作 2010-04-03 15:06 | 溪流
@陳梓瀚(vczh)
那我該期待別人怎么用我的class呢?  回復  更多評論
  
# re: 道德問題?論new操作失敗后的操作 2010-04-06 15:39 | only
你可以去認真看看《effective C++ 》(第三版) 條款49-52!
相信對于你會很有用,樓主!  回復  更多評論
  
# re: 道德問題?論new操作失敗后的操作 2010-04-06 15:54 | 溪流
@only
它是不是講如何利用什么handler去釋放內存之類的?
我的題設是內存申請失敗,而不是被new的那個對象的構造函數執行失敗。(我已經假設了被new的只是一個int)
我的困惑不是技術上如何保證沒有內存泄漏,而是——
要是我的構造函數有異常拋出,用戶該如何用這個類?我該不該讓構造函數拋出異常?  回復  更多評論
  
# re: 道德問題?論new操作失敗后的操作[未登錄] 2010-04-14 15:11 | siwei
@溪流
有意思的話題。Symbian中的方式是重載了new,以及應用兩段構造。  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            翔田千里一区二区| 欧美一区二区三区四区在线观看地址 | 午夜精品一区二区三区电影天堂| 国产一区二区三区不卡在线观看| 欧美高清在线视频观看不卡| 久久久成人精品| 亚洲精品日韩在线观看| 国产亚洲二区| 国产无一区二区| 激情婷婷欧美| 亚洲美女av电影| 最新日韩欧美| 亚洲国产老妈| 亚洲少妇自拍| 久久久综合视频| 亚洲国产精品一区二区第一页 | 卡通动漫国产精品| 久久九九免费视频| 亚洲人成网站999久久久综合| 在线看片欧美| 亚洲精品免费一二三区| 欧美国产精品劲爆| 欧美 日韩 国产 一区| 欧美国产91| 在线成人性视频| 日韩系列在线| 久久综合99re88久久爱| 亚洲免费电影在线观看| 午夜精品免费| 日韩一区二区精品葵司在线| 久久久久国色av免费观看性色| 亚洲高清123| 午夜一区不卡| 欧美午夜精品久久久| 91久久精品国产91久久| 久久影视精品| 午夜宅男久久久| 国产欧美三级| 欧美伊人久久久久久午夜久久久久| 99国产精品| 国产精品丝袜白浆摸在线| 亚洲一区二区在线免费观看| 亚洲国产成人91精品| 免费精品视频| 宅男精品视频| 亚洲欧美综合网| 亚洲国产高清aⅴ视频| 欧美福利专区| 国产欧美 在线欧美| 久久人人看视频| 久久人人精品| 亚洲天堂av高清| 欧美一级久久久| 曰本成人黄色| 亚洲欧美日韩另类精品一区二区三区 | 在线天堂一区av电影| 国产一区二区久久久| 亚洲大片免费看| 国产精品视频xxxx| 亚洲欧洲日韩综合二区| 精品999在线播放| av72成人在线| 亚洲精选大片| 午夜精品福利在线| 亚洲人被黑人高潮完整版| 午夜国产精品视频| 亚洲伊人久久综合| 欧美麻豆久久久久久中文| 久久亚洲国产成人| 国产精品久久影院| 99国产精品久久| 日韩亚洲欧美精品| 免费成人性网站| 免费成人黄色片| 在线观看91久久久久久| 午夜精品久久久久久99热软件 | 欧美www在线| 欧美成人高清视频| 亚洲精选成人| 国产精品成人国产乱一区| 日韩亚洲欧美一区| 亚洲视频一区在线| 国产精品国码视频| 亚洲中字黄色| 你懂的一区二区| 亚洲美女精品一区| 国产精品视频免费观看www| 亚洲视频中文| 久久影音先锋| 亚洲一级免费视频| 亚洲一线二线三线久久久| 亚洲一区高清| 在线 亚洲欧美在线综合一区| 另类激情亚洲| 欧美一级二区| 亚洲毛片在线观看| 亚洲欧美日韩精品久久奇米色影视 | 亚洲高清免费在线| 亚洲视频999| 尤物网精品视频| 国产精品欧美日韩久久| 玖玖在线精品| 亚洲欧美卡通另类91av| 亚洲精品三级| 老巨人导航500精品| 亚洲一区二区三区在线视频| 国产亚洲一区二区三区| 欧美成人午夜剧场免费观看| 亚洲一区二区在线免费观看视频| 激情另类综合| 国产伦精品一区二区三区视频黑人| 欧美国产另类| 欧美激情精品久久久久久蜜臀| 久久综合九色九九| 免费欧美在线视频| 欧美国产视频一区二区| 欧美激情影音先锋| 亚洲黄色在线| 亚洲品质自拍| 亚洲自拍三区| 亚洲欧美影院| 欧美怡红院视频| 久久国产精品久久w女人spa| 亚洲已满18点击进入久久| 亚洲一线二线三线久久久| 亚洲欧美网站| 性18欧美另类| 久久免费视频网| 免费亚洲一区二区| 亚洲经典三级| 在线综合视频| 久久er99精品| 欧美精品18+| 国产视频观看一区| 国产精品伊人日日| 亚洲国产精品久久久久| 91久久在线播放| 一区二区成人精品| 久久超碰97中文字幕| 最新69国产成人精品视频免费| 日韩视频―中文字幕| 久久亚洲美女| 韩国欧美一区| 久久国产精品99国产精| 一本大道久久精品懂色aⅴ| 久久久天天操| 国外成人网址| 久久综合激情| 久久精品最新地址| 国产日韩欧美电影在线观看| 一本色道88久久加勒比精品| 亚洲激情社区| 欧美日韩一区不卡| 亚洲主播在线观看| 亚洲自拍偷拍视频| 国产乱码精品| 久久在线精品| 男女av一区三区二区色多| 亚洲毛片在线免费观看| 亚洲精品一二三| 欧美三区视频| 久久久国产精彩视频美女艺术照福利| 午夜在线a亚洲v天堂网2018| 国产一级一区二区| 模特精品裸拍一区| 欧美视频日韩视频在线观看| 一本大道久久a久久精品综合| 亚洲欧洲精品一区二区精品久久久| 欧美精品导航| 久久久久高清| 亚洲国产精品黑人久久久| 欧美亚洲视频在线看网址| 久久香蕉精品| 亚洲一区二区视频| 久久精品首页| 午夜精品一区二区三区在线| 久久视频在线免费观看| 亚洲精品一区二区三区不| 欧美一区二区三区啪啪| 亚洲激情第一页| 久久免费少妇高潮久久精品99| 一区二区三区黄色| 免费成人av在线| 久久嫩草精品久久久精品| 国产精品国产一区二区| 亚洲免费激情| 亚洲激情成人在线| 美乳少妇欧美精品| 另类人畜视频在线| 极品尤物一区二区三区| 欧美亚洲一区三区| 久久久91精品国产一区二区三区| 国产精品大片| 亚洲一区免费视频| 亚洲综合大片69999| 国产精品视频网址| 欧美尤物一区| 欧美激情欧美激情在线五月| 亚洲经典在线| 欧美成人综合在线|