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

一個(gè)要引起注意的delete動作

我在雙向鏈表類中定義的clear()函數(shù)
如下:

void clear()

       {

              if( !isEmpty() )

              {

                     list_item< type >* temp = list_head;

                     list_item< type >* delTemp;

             

                     while( temp !=  list_tail )

                     {

                            delTemp = temp;

                            temp = temp->back;

                            delete delTemp;//釋放空間

                     }

原來這里的語句是temp !=  list_tail->back 但是一旦 temp 被賦值為 list_tail->back //么它本身就是 delTemp 即將被刪除的空間的一部分 再對一個(gè)已經(jīng)不存在的指針進(jìn)行操作當(dāng)然就會崩潰 這樣就導(dǎo)致在對temp的引用是不存在的 所以出錯

                     delete list_tail;

                     list_head = NULL;

                     size = 0;

              }

              else

              {

                     return;

              }

       }

我還是很快發(fā)現(xiàn)了 但是很有覺得價(jià)值 所以寫下提醒自己

posted on 2007-04-11 16:55 lele 閱讀(1509) 評論(15)  編輯 收藏 引用

評論

# re: 一個(gè)要引起注意的delete動作 2007-04-13 12:40 anthony

不知道你之前的代碼是不是只是while那里不一樣,
個(gè)人感覺不是temp的問題,如果照你以前的寫法,應(yīng)該是是最后的delete list_tail;的問題
void clear()

{

if( !isEmpty() )

{

list_item< type >* temp = list_head;

list_item< type >* delTemp;



while( temp != list_tail->back)//你以前的寫法

{

delTemp = temp;

temp = temp->back;


delete delTemp;//釋放空間

}



// delete list_tail; //這句不要了,因?yàn)閐elTemp 總是指向temp的前一個(gè),當(dāng)temp = list_tail->back時(shí)是在最后,此時(shí)delTemp = list_tail已刪除完整個(gè)鏈表,覺得如果你之前的語句只是while那里不一樣,應(yīng)該是這里出錯了,不知道有沒有理解你原來的意思。覺得有點(diǎn)疑問

list_head = NULL;

size = 0;

}

else

{

return;

}

}

  回復(fù)  更多評論   

# re: 一個(gè)要引起注意的delete動作 2007-04-14 00:09 lele

呵呵 謝謝你的疑問 我剛剛走查了一下就是我的那個(gè)問題
你可以自己試一試 當(dāng)執(zhí)行到delTemp指向尾節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn)時(shí) temp指向尾節(jié)點(diǎn) 此時(shí)還不滿足temp != list_tail->back 但是下一句是
delTemp = temp; 這句之后 temp = temp->back; 這句之后 temp滿足了退出循環(huán)的條件 但是它指向了尾節(jié)點(diǎn)的一部分(list_tail->back )而這個(gè)list_tail->back 經(jīng)過隨后的一步delete delTemp;就被刪除了 這樣在下一次循環(huán)入口條件判斷時(shí) temp已經(jīng)成了一個(gè)野指針 對它的引用當(dāng)然也是不正確的

不知道這樣說你清楚了嗎??  回復(fù)  更多評論   

# re: 一個(gè)要引起注意的delete動作 2007-04-14 10:53 anthony

你的意思是temp=list_tail->back ;時(shí),deltemp等于list_tail,然后刪除了deltemp,相當(dāng)于刪了list_tail,這樣我覺得應(yīng)該是list_tail變成了野指針吧(其實(shí)都一樣),我的想法是這樣的,如果list_tail->back = NULL ,temp就變成了NULL,而應(yīng)該是list_tail變成了野指針,我知道這是有點(diǎn)鉆死胡同的感覺(因?yàn)榻Y(jié)果是一樣的),我只是把為什么我不理解你的程序的那些注釋說出來而已,討論清楚而已,你覺得是不是應(yīng)該是list_tail是野指針,而不是temp?

不過說真的我光注意前面的temp了,而沒注意后面的tail_back(就while的條件里面),看來以后還得注意前后  回復(fù)  更多評論   

# re: 一個(gè)要引起注意的delete動作 2007-04-14 13:31 lele

list_tail是類的成員 這個(gè)類都被釋放了就不存在了 那么你說list_tail是什么?? 而temp是無關(guān)的局部變量 它在這個(gè)局部內(nèi)使我控制 除了這個(gè)局部就不是我能管理的了 但是類不同 temp要使用我類中的back成員 當(dāng)然得back存在啊 而我把back delete了 你說temp指向的list_tail的back是什么??  回復(fù)  更多評論   

# re: 一個(gè)要引起注意的delete動作 2007-04-14 13:32 lele

不過以后大家可以經(jīng)常討論 這是好事情 我要謝謝你的  回復(fù)  更多評論   

# re: 一個(gè)要引起注意的delete動作 2007-04-14 14:29 anthony

你的clear函數(shù)只是清空了鏈表的內(nèi)存空間listitem,并沒有刪除list這個(gè)對象,對象的刪除得由析構(gòu)函數(shù)來執(zhí)行
 

比如你執(zhí)行了一個(gè)LIST Object,只是一個(gè)鏈表對象,往里面加item,然后clear方法Object.Clear()只是刪除了里面的item的空間,而成員對象是否應(yīng)該還存在?就是List_tail還是一個(gè)指針,它還有它的值,它指向它原先的內(nèi)存地址,我的理解是比如List_tail現(xiàn)在是一個(gè)門牌號101,而item是里面的人,里面如果搬家了,執(zhí)行的是Clear,但門牌號還在,而只有把房子給拆了,才是把對象給釋放了,或者你可以試一下把List_tail設(shè)為公有,然后Clear()后,然后List_tail 0x16;這說明List_tail還是存在,它還指向那片內(nèi)存單元,或者你跟蹤一下,在執(zhí)行Clear之前,看下list_tail的地址,Clear之后,在看下那地址,是不是一樣的,temp也只是個(gè)指針,無論后面的list_tailback存不存在,它還是個(gè)內(nèi)存中的一個(gè)編號(門牌號),如果存在,程序正確,不存在,就是野指針,個(gè)人認(rèn)為只要它值為NULL它就不應(yīng)該是野指針,我說的應(yīng)該是list_tail是野指針,是因?yàn)楫?dāng)最后deltemp也指向list_tail時(shí),temp = list_tail->back = NULL;此時(shí)由于delete deltemp

list_tail空間就不存在了,但它還指向那個(gè)地址,但是后面就沒有back了,所以會出錯


如果改成
 

while(temp != list_tail->back && temp != NULL), 當(dāng)然這個(gè)沒你的算法好,這個(gè)得多做多個(gè)判斷,時(shí)間負(fù)責(zé)度比你原先的高,就是感覺要說引用了不存在的對象應(yīng)該是list_tail引用了不存在的對象,你覺得呢?(個(gè)人愚見)

  回復(fù)  更多評論   

# re: 一個(gè)要引起注意的delete動作 2007-04-14 23:11 lele

temp != list_tail->back && temp != NULL這里依然有個(gè)問題就是
先判斷temp != list_tail->back會出錯,還是把兩個(gè)語句調(diào)換一下位置
這樣就能保證安全性了 呵呵
你的想法挺好的 謝謝你的想法!  回復(fù)  更多評論   

# re: 一個(gè)要引起注意的delete動作 2007-04-16 09:41 anthony

以前倒還真沒注意過和順序有關(guān),又學(xué)到了,看來討論真的能有意外的收獲,謝謝你的指正

呵呵,聽你這么一說,然后覺得是不是while(temp != NULL)就可以了?  回復(fù)  更多評論   

# re: 一個(gè)要引起注意的delete動作 2007-04-17 18:09 lele

呵呵 我都被你誤導(dǎo)了 temp != list_tail->back 和 temp != NULL 這兩局并沒有區(qū)別 list_tail->back 就是NULL
List_tail指向的內(nèi)容被析構(gòu)之后 系統(tǒng)就會給List_tail分配一個(gè)我們無法得知的指向。
back不在了之后 我下一步要執(zhí)行的是判斷temp是不是back 你說它都沒有了怎么判斷呢?
你的編程想法真的很有意思。你怎么知道temp一定是NULL 那是你的機(jī)器 我的機(jī)器就不是 而且怎么可能呢? 我是在堆棧上面申請的。temp是靜態(tài)的。它指向的內(nèi)存被系統(tǒng)回收了,你怎么還可以用呢? 無論是不是NULL 只要你動用就是出錯。這樣編程不好 代碼可以說很差 太不安全 太隨意 還要依靠運(yùn)氣 你說呢?
  回復(fù)  更多評論   

# re: 一個(gè)要引起注意的delete動作 2007-04-17 21:45 anthony

對啊,所以你不是說要給它換個(gè)順序變成
while(temp != NULL && temp != list_tail->back )嗎?這樣不就安全了嗎?

如果你是這個(gè)意思,下面的就別看了,這樣不就安全了嗎?還能有什么問題嗎?

可能我理解NULL有問題,我覺得NULL就相當(dāng)于一個(gè)const變量,它永遠(yuǎn)指向內(nèi)存中的一個(gè)不存在的地方,“ list_tail->back 就是NULL ”沒錯,然后當(dāng)temp指向list_tail時(shí),然后根據(jù)while(temp!=NULL)進(jìn)入循環(huán)體,接著deltemp就指向了list_tail,然后temp = temp_back,就是此時(shí),
temp=NULL,然后刪除了list_tail,然后判斷時(shí),temp不是等于NULL了嗎?然后循環(huán)條件成立不了,

我的理解是NULL是指向一個(gè)相當(dāng)于CONST的地址空間,不管list_tail有沒有,我們都可以指向NULL,NULL和list_tail 沒關(guān)吧?

還有說的“List_tail指向的內(nèi)容被析構(gòu)之后 系統(tǒng)就會給List_tail分配一個(gè)我們無法得知的指向”,我覺得它還是指向原來那個(gè)地方吧?

我觀察了下面的代碼

int *p = NULL;//此時(shí)p指向0x00000000
p = new int [200];//此時(shí)p指向0x00441ac0
delete p;
cin>>a;//此時(shí)p還指向0x00441ac0


然后還有
temp != list_tail->back 和 temp != NULL

對于前面的節(jié)點(diǎn)時(shí)它們是一樣的,但在最后那個(gè)點(diǎn)時(shí),即deltemp = list_tail時(shí),然后temp = temp->back(就是NULL)了,然后系統(tǒng)把list_tail刪了,然后list_tail還指向那個(gè)系統(tǒng)單元(就是只是系統(tǒng)把房子里的人趕了出去,但門牌號還是那個(gè)),然后再進(jìn)入循環(huán)條件,然后此時(shí)list_tail->back 引用就會出錯了,因?yàn)閘ist_tail里面已經(jīng)沒“人”了,在加一個(gè)back相當(dāng)里面的一個(gè)人,所以會出錯,

不知道你能否明白我的意思,或者可能我沒明白你的意思,還有一個(gè)就是NULL的問題,就是temp的指向的內(nèi)容被回收,但它還是可以指向地址,現(xiàn)在就是指向NULL,只要temp!=NULL,只是判斷temp的數(shù)值而已,呵呵,寫著寫著就變很羅嗦了,呵呵   回復(fù)  更多評論   

# re: 一個(gè)要引起注意的delete動作 2007-05-09 00:41 lele

呵呵 這段時(shí)間有事離開了
我的意思就是感覺編程不能碰運(yùn)氣,還是以安全為上是好習(xí)慣
走查會根據(jù)編譯器不同而分配給你用的內(nèi)存的初始內(nèi)容不同。誰也不能控制。  回復(fù)  更多評論   

# re: 一個(gè)要引起注意的delete動作 2007-05-12 10:14 anthony

呵呵,同意編程不能靠運(yùn)氣。
 
可能我水平太低吧,不能理解指針的真正含義?也不能理解你的意思。
 
我實(shí)在不明白list_tail->back=null,然后temp=list_tail->back,然后temp不是指向了null嗎?對于一個(gè)指針我覺得可以對它進(jìn)行任何賦值,然后temp!=null只是拿存放指針本身的那塊內(nèi)存里面的數(shù)值去和0X0000000內(nèi)存地址比較,即使指向的內(nèi)容被析構(gòu)了,但指針?biāo)瑯诱贾膬?nèi)存空間,拿temp和null比只是存放temp指針那塊內(nèi)存里面的數(shù)值和null比,不是存放temp指針的那塊內(nèi)存里面的數(shù)值指向的內(nèi)存,怎么會出錯呢?
 
不過你的代碼看起來真的很舒服,不知道你是怎么做到的,就是我寫的時(shí)候縮排格式,我也一直在注意,按照《高質(zhì)量程序設(shè)計(jì)指南 C++/C語言》 上面的寫法來寫的,但還是感覺有點(diǎn)亂,是不是注釋寫得太多會顯得亂呢?這方面得向你請教,呵呵
  回復(fù)  更多評論   

# re: 一個(gè)要引起注意的delete動作 2007-06-07 14:25 lele

問題不是出在temp是出在list_tail->back
list_tail對back的操作
back已經(jīng)被釋放了,不可再訪問

呵呵 我水平很一般,前幾天ACM亞洲銀獎的同學(xué)敲代碼,半小時(shí)做三道題,我都崩潰了……
慢慢來吧,總是天外有天的。  回復(fù)  更多評論   

# re: 一個(gè)要引起注意的delete動作 2007-07-26 11:35 anthony

list_tail->back不就是null嗎?它沒有指向哪個(gè)對象,只是指向null那個(gè)地址0x00000000,而已,null就是0x00000000,沒有指向哪個(gè)對象,呵呵,

好長時(shí)間沒過來了,不知道你是否也還記得你所寫的,和我們討論的,我剛是從頭到尾又看了編。

acm亞洲銀獎?那很厲害的,同時(shí)呢我也參加過acm,也見過好多acm的同學(xué)的代碼,還有網(wǎng)上的一些比較厲害的人的代碼,因?yàn)樗麄冏非蟮氖撬俣龋还苁撬惴ㄐ剩€是敲程序的速度,所以我看過的acm代碼的風(fēng)格沒有你寫得好,我還記得我那時(shí)候見他們敲字得速度,驚訝得說不出話來了,呵呵  回復(fù)  更多評論   

# re: 一個(gè)要引起注意的delete動作 2007-07-26 11:53 anthony



哈哈,抱歉,終于知道我哪里出問題了,你看下是不是這里:

# re: 一個(gè)要引起注意的delete動作 2007-04-17 18:09 lele
呵呵 我都被你誤導(dǎo)了 temp != list_tail->back 和 temp != NULL
這兩局并沒有區(qū)別 list_tail->back 就是NULL


在list_tail沒被刪除前,這兩句的確是一樣的,可list_tail->back被刪后,這就不一樣了,因?yàn)閠emp沒有引用->back,而list_tail引用了back,而list_tail被刪除了,所以不能引用list_tail->back,而就像你前面告訴我的

# re: 一個(gè)要引起注意的delete動作 2007-04-14 23:11 lele
temp != list_tail->back && temp != NULL這里依然有個(gè)問題就是
先判斷temp != list_tail->back會出錯,還是把兩個(gè)語句調(diào)換一下位置
這樣就能保證安全性了 呵呵




還是你提醒了我

# re: 一個(gè)要引起注意的delete動作 2007-06-07 14:25 lele
問題不是出在temp是出在list_tail->back
list_tail對back的操作
back已經(jīng)被釋放了,不可再訪問


你是不是敲錯了,是list_tail被釋放了??呵呵



謝謝你的指點(diǎn)啊,經(jīng)過這樣討論,我覺得應(yīng)該對指針和鏈表的認(rèn)識又進(jìn)一步了,謝謝你啊,呵呵  回復(fù)  更多評論   


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


<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

導(dǎo)航

統(tǒng)計(jì)

常用鏈接

留言簿(1)

隨筆檔案

文章檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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久久久久久老狼 | 欧美精品日韩三级| 蜜臀99久久精品久久久久久软件| 国产精品久久久久久久久久ktv | 亚洲第一伊人| 欧美资源在线| 久久国产一区二区三区| 欧美视频久久| 一区二区三区欧美视频| 在线亚洲一区| 欧美日韩一区免费| 一区二区国产日产| 亚洲综合国产激情另类一区| 欧美日韩国产在线播放| 亚洲六月丁香色婷婷综合久久| 亚洲风情亚aⅴ在线发布| 久久久www成人免费精品| 久久天堂精品| 尤物精品在线| 每日更新成人在线视频| 欧美国产日韩二区| 亚洲日本中文字幕| 欧美大片一区二区三区| 亚洲精品黄色| 亚洲一本大道在线| 国产精品vvv| 性伦欧美刺激片在线观看| 欧美一区二区视频在线观看| 国产亚洲福利| 久久久一二三| 亚洲三级影院| 欧美亚洲视频一区二区| 韩国精品在线观看| 欧美成年人视频网站欧美| 亚洲毛片视频| 亚洲欧美久久| 韩日欧美一区二区| 欧美大胆a视频| 一区二区免费在线视频| 久久精品综合| 亚洲精选视频免费看| 欧美日韩在线免费观看| 亚洲欧美国产视频| 欧美黄色视屏| 亚洲欧美在线免费| 亚洲第一成人在线| 欧美四级在线观看| 久久久欧美一区二区| 亚洲日韩欧美一区二区在线| 性感少妇一区| 亚洲欧洲日本专区| 国产精品一区久久久| 免费成人性网站| 亚洲天堂久久| 欧美成年人视频| 性色av香蕉一区二区| 亚洲黄色毛片| 国产亚洲免费的视频看| 欧美区高清在线| 欧美一区91| 亚洲精品婷婷| 久久综合亚州| 亚洲欧美日韩区| 亚洲欧洲日本在线| 国内自拍一区| 国产精品夫妻自拍| 欧美黑人国产人伦爽爽爽| 欧美中在线观看| 这里只有精品电影| 最新高清无码专区| 毛片精品免费在线观看| 午夜精品影院| 中文有码久久| 亚洲国产精品尤物yw在线观看 | 亚洲欧美另类久久久精品2019| 国内精品久久久久影院优| 欧美日韩国语| 欧美激情按摩| 蜜桃久久av一区| 久久精品一区中文字幕| 亚洲免费中文| 中文欧美日韩| 一区二区三区精品视频在线观看| 欧美高清在线一区二区| 久久综合激情| 久久综合给合| 久久综合狠狠| 久久久亚洲欧洲日产国码αv| 欧美亚洲免费高清在线观看| 一区二区三区精品视频在线观看| 亚洲国产美女精品久久久久∴| 好吊色欧美一区二区三区四区| 国产欧美va欧美va香蕉在| 国产精品日韩精品| 国产精品麻豆成人av电影艾秋| 欧美日韩精品一区二区在线播放 | 国产一区二区三区观看 | 精品二区久久| 狠狠色狠狠色综合日日tαg| 国产一区二区黄色| 国产在线观看一区| 狠狠入ady亚洲精品经典电影| 国产视频一区在线观看一区免费| 国产精品日韩欧美| 国产欧美精品日韩区二区麻豆天美| 国产精品区免费视频| 国产精品看片资源| 国产精品一区在线观看| 国产亚洲精品久久飘花| 激情综合亚洲| 亚洲韩国一区二区三区| 亚洲精品视频一区| 正在播放亚洲| 午夜精品久久久久久久久| 久久成人免费网| 免费高清在线一区| 亚洲国产精品va在线观看黑人 | 日韩亚洲欧美在线观看| 亚洲天堂av在线免费| 欧美一区=区| 麻豆精品传媒视频| 欧美日韩国产影片| 国产午夜亚洲精品羞羞网站 | 欧美亚洲一级| 免费h精品视频在线播放| 亚洲国产成人一区| 在线亚洲激情| 久久久国产一区二区三区| 欧美国产精品久久| 国产精品日本| 亚洲高清视频一区二区| 国产精品99久久久久久人| 久久国产欧美精品| 亚洲国产高清自拍| 亚洲永久精品大片| 久久影视精品| 国产精品久久久久影院色老大 | 久久国产视频网站| 亚洲国产精品v| 亚洲欧美国产日韩天堂区| 久久综合色播五月| 欧美新色视频| 亚洲第一色在线| 午夜精品影院| 91久久在线播放| 久久电影一区| 国产精品剧情在线亚洲| 亚洲精品久久嫩草网站秘色 | 鲁大师影院一区二区三区| 国产精品大片wwwwww| 在线观看日韩欧美| 午夜一级在线看亚洲| 亚洲福利精品| 久久国产精品网站| 国产精品久久波多野结衣| 亚洲国产精品成人精品| 欧美一区二区三区视频| 亚洲肉体裸体xxxx137| 久久久综合网| 国产一区二区三区成人欧美日韩在线观看| 亚洲黄色影院| 免费不卡中文字幕视频| 亚洲欧美日韩在线| 国产精品xvideos88| 日韩亚洲国产精品| 欧美成年人网| 久久婷婷色综合| 国产一区久久| 欧美在线免费| 午夜精品视频一区| 国产精品日韩| 午夜精品美女自拍福到在线 | 亚洲日本中文字幕区| 久久伊人免费视频| 国产一区二区在线观看免费| 亚洲欧美成人一区二区三区| 99riav国产精品| 欧美伦理91i| 一区二区三区四区五区视频| 亚洲国产精品专区久久| 久久乐国产精品| 欲香欲色天天天综合和网| 另类av一区二区| 久久免费少妇高潮久久精品99| 国产一区久久久| 老司机67194精品线观看| 欧美在线影院在线视频| 好男人免费精品视频| 久久综合给合| 女主播福利一区| 亚洲精品视频在线观看免费| 亚洲国产清纯| 欧美日韩国产精品| 亚洲欧美日韩国产中文| 亚洲欧美激情四射在线日| 国产一区二区剧情av在线|