Re: [問題] 基礎Pointer問題 LC2807

看板C_and_CPP (C/C++)作者 (可愛的小松鼠)時間6月前 (2024/06/07 19:32), 編輯推噓8(808)
留言16則, 8人參與, 6月前最新討論串2/2 (看更多)
function中 透過 Type obj(); 建立的物件 會被放在stack區段,視為區域變數。 該物件的生命週期只存在function內,離開後,就無法被存取。 function中 透過 Type* ptr = new Type(); 建立的物件 會被放在heap區段,視為動態分配的物件,離開function後,物件仍然存在 直到被delete 呼叫解構子銷毀為止。 [也就是說,動態物件建立與銷毀(歸還記憶體)的責任落在寫code的人身上] 為什麼local variable 區域變數的寫法不行? 因為Leetcode測試平台會在背景執行別支驗證的function, 去檢查這條串列是否符合預期中的答案, 這時候已經離開insertGreatestCommonDivisors當初宣告的function, 也就是說,ListNode n(c, ptr->next); 所宣告的物件已經看不到了, 就算硬是要是access那塊記憶體位置,也是非法存取。 可以在Debug console看到如下類似的資訊 ERROR: AddressSanitizer: stack-use-after-return on address 0x7f9823700028 at pc 0x55ac5f4a030c bp 0x7ffd0c8f6130 sp 0x7ffd0c8f6128 READ of size 8 at 0x7f9823700028 thread T0 #0 0x55ac5f4a030b in __ListNodeUtils__::hasCycle(ListNode*) (solution+0x19030b) ※ 引述《CppGod (CPP IS GOD)》之銘言: : 開發平台(Platform): (Ex: Win10, Linux, ...) : Windows : 編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台不同的話需列出) : VS : 額外使用到的函數庫(Library Used): (Ex: OpenGL, ...) : 問題(Question): : 程式碼中的(1)是正確的寫法,但不了解為什麼(2)的寫法不行 : 想法是ListNode n()完後,讓ptr=&n,但結果是錯的 : 餵入的資料(Input): : 預期的正確結果(Expected Output): : 錯誤結果(Wrong Output): : https://ideone.com/Gb60BJ : 程式碼(Code): : https://ideone.com/i5eC0B : 補充說明(Supplement): : 先謝謝各位前輩了! -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 114.37.204.145 (臺灣) ※ 文章網址: https://www.ptt.cc/bbs/C_and_CPP/M.1717759960.A.A87.html

06/07 22:06, 6月前 , 1F
(已跪)講解得很清楚 非常感謝您!!!
06/07 22:06, 1F

06/08 14:12, 6月前 , 2F
平常寫程式開著asan就可以避免這種錯了
06/08 14:12, 2F

06/09 21:37, 6月前 , 3F
或是改寫 Rust 也可以(欸
06/09 21:37, 3F

06/11 08:03, 6月前 , 4F
Rust 要寫 linked list 意外地難喔! XD
06/11 08:03, 4F

06/14 16:00, 6月前 , 5F
樓上為啥?
06/14 16:00, 5F

06/17 21:32, 6月前 , 6F
它的 Linked list 要用 enum 去做,所以沒那麼直覺
06/17 21:32, 6F

06/20 22:56, 6月前 , 7F
主要是 Rust 把指標和 null 都包裝起來,想要有效操作就
06/20 22:56, 7F

06/20 22:56, 6月前 , 8F
是很麻煩的事,動不動就會踩到 borrow checker 的雷。如
06/20 22:56, 8F

06/20 22:56, 6月前 , 9F
果想做雙向鏈接、再加上要提供 iterator,那就更恐怖了
06/20 22:56, 9F

06/20 23:00, 6月前 , 10F
我當年寫 Exercism 的 Rust 題庫,唯一一題寫不出來的就
06/20 23:00, 10F

06/20 23:00, 6月前 , 11F
是實作雙向鏈結。題目提示說可以用 unsafe 去操作指標,
06/20 23:00, 11F

06/20 23:00, 6月前 , 12F
但就算知道,還是寫不出來……
06/20 23:00, 12F

06/21 15:01, 6月前 , 13F
統統只用unsafe當C可以寫吧
06/21 15:01, 13F

06/21 22:42, 6月前 , 14F

06/21 22:42, 6月前 , 15F
Rust的雙向鏈結會卡到所有權問題,會超級麻煩。
06/21 22:42, 15F

06/24 08:32, 6月前 , 16F
Option<Rc<RefCell<T>>>
06/24 08:32, 16F
文章代碼(AID): #1cOk_Og7 (C_and_CPP)
討論串 (同標題文章)
文章代碼(AID): #1cOk_Og7 (C_and_CPP)