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

作者: cuteSquirrel (松鼠)   2024-06-07 19:32:38
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):
: 先謝謝各位前輩了!
作者: CppGod (CPP IS GOD)   2024-06-07 22:06:00
(已跪)講解得很清楚 非常感謝您!!!
作者: tomsawyer (安安)   2024-06-08 14:12:00
平常寫程式開著asan就可以避免這種錯了
作者: lc85301 (pomelocandy)   2024-06-09 21:37:00
或是改寫 Rust 也可以(欸
作者: closer76 (克樓瑟)   2024-06-11 08:03:00
Rust 要寫 linked list 意外地難喔! XD
作者: j0958322080 (Tidus)   2024-06-14 16:00:00
樓上為啥?
作者: lc85301 (pomelocandy)   2024-06-17 21:32:00
它的 Linked list 要用 enum 去做,所以沒那麼直覺
作者: closer76 (克樓瑟)   2024-06-20 22:56:00
主要是 Rust 把指標和 null 都包裝起來,想要有效操作就是很麻煩的事,動不動就會踩到 borrow checker 的雷。如果想做雙向鏈接、再加上要提供 iterator,那就更恐怖了我當年寫 Exercism 的 Rust 題庫,唯一一題寫不出來的就是實作雙向鏈結。題目提示說可以用 unsafe 去操作指標,但就算知道,還是寫不出來……
作者: wulouise (在線上!=在電腦前)   2024-06-21 15:01:00
統統只用unsafe當C可以寫吧
作者: Richun (解放左手的OO之力)   2024-06-21 22:42:00
https://rust-unofficial.github.io/too-many-lists/Rust的雙向鏈結會卡到所有權問題,會超級麻煩。
作者: lycantrope (阿寬)   2024-06-24 08:32:00
Option<Rc<RefCell<T>>>

Links booklink

Contact Us: admin [ a t ] ucptt.com