推 lausai:mem_free裡把ptr1設為NULL 並不影響ptr 去dereference一個 12/30 19:33
→ lausai:一個NULL pointer會出錯 但是ptr並不是NULL pointer(即使 12/30 19:33
→ lausai:在mem_free執行完之後) 12/30 19:34
推 VictorTom:承接樓上, 在mem_free後的*ptr1=5會馬上出錯, 是因為你 12/30 22:34
→ VictorTom:企圖對NULL寫值; main裡在mem_free不會出錯, 1是因為在 12/30 22:35
→ VictorTom:mem_free()裡給的NULL並不影響到main裡的ptr, 只是mem 12/30 22:35
→ VictorTom:manager已經記錄了該記憶體已被還掉, 只要該位址尚未做 12/30 22:36
→ VictorTom:其他用途, *ptr=5; 暫時有可能不會出錯, 但是對一塊不屬 12/30 22:37
→ VictorTom:於你可以合法使用的記憶體做讀寫, 都是不應該的:) 12/30 22:37
推 althon:那free(ptr1)時,為什麼不會把ptr所指向的空間釋放??? 12/30 23:14
→ althon:我不太懂free(ptr1)釋放那一塊空間? 12/30 23:14
→ althon:void mem_free(int *ptr1)會建立*ptr1指標,指向ptr所指空 12/30 23:15
→ althon:間不是嗎? >"< 我越來越迷網了XD 12/30 23:15
→ akasan:你可以在main裡加mem_free前後加printf("%d\n",ptr); 12/30 23:27
→ akasan:就會知道大概發生什麼事了 12/30 23:27
推 althon:不是%p嗎? 我看過都一樣=.= 12/30 23:39
推 VictorTom:malloc回來的空間有沒有被釋放, 跟指標是否重設成NULL是 12/31 00:18
→ VictorTom:兩件不同的事, malloc回來賦值的指標直接重設成NULL, 這 12/31 00:19
→ VictorTom:個空間也不會被free; 你free(ptr)了malloc來的空間, ptr 12/31 00:19
→ VictorTom:也不會自動變成NULL; 唯一相關的是, 你如果沒把ptr存好 12/31 00:20
→ VictorTom:就在free前又重給值, 就會有memory leak的問題發生. 12/31 00:20
→ VictorTom:至於印出ptr值都一樣, 其實是pass by value或者pass by 12/31 00:21
→ VictorTom:reference的問題; 請試想寫一個func由caller傳入callee 12/31 00:22
→ VictorTom:兩數使其能夠在caller看到交換的結果, 大概就是這樣:) 12/31 00:22
→ johnhmj:請記得在主程式 int *ptr = NULL 要加初值~ 12/31 01:22