C_and_CPP 板


LINE

編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台不同的話需列出) GCC 額外使用到的函數庫(Library Used): (Ex: OpenGL, ...) 問題(Question): 在linux中,他的雙向鏈結串列因為要可以儲存不同的資料型態,所以他的鏈結串列和資 料是分開來的,要使用時在將資料加到鏈結串列上   例如這樣 struct list_head { struct list_head *next, *prev; };   要使用時再這樣 struct num { int number; //data struct list_head list; };   但是這樣要如何實作? 像是如果我想要新增一個節點   但list的資料型態是list_head,意思是我只能新增一個list_head的節點,而這個結點無 法儲存資料   如果我新增一個num型態的節點,但是我的list並不能指向一個num型態的節點 而我新增了一個num型態的節點,我用list_head的指標去指向這個num型態的節點,我原 本預期應該是錯誤的(可能直接編譯錯誤或是在執行階段當掉),但居然成功運作了 但我完全不知道為何會這樣 餵入的資料(Input):程式碼(Code):(請善用置底文網頁, 記得排版,禁止使用圖檔) https://ideone.com/dQZkIq --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 59.126.109.77
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1522599114.A.D56.html
1F:推 LPH66: 你是在看侵入式鍊結串列 (intrusive linked list) 嗎? 04/02 00:31
2F:→ wei115: 沒有欸,我是看jserv的影片才知道這東西的 04/02 00:33
3F:→ stupid0319: list指向num結構,num結構中有list資訊 04/02 00:43
不太懂,我用list指向num,那我存取的方式應該是用list的方式阿,但是list 並沒有number的資料阿 ※ 編輯: wei115 (59.126.109.77), 04/02/2018 00:56:52
4F:推 Bencrie: 就噴警告而已吧。說你 assign 不相容型別的指標 04/02 01:03
5F:→ wei115: 我知道不相容,但是為什麼不相容卻可以讀出正確的資料? 04/02 01:05
6F:推 ss1h2a3tw: 因為指到struct的指標在存取member的時候是用指標內容+ 04/02 02:55
7F:→ ss1h2a3tw: member offset, 所以你用什麼型態的指標它就會用那個定 04/02 02:56
8F:→ ss1h2a3tw: 義內的member的offset存取,還有list_head不是這樣用的 04/02 02:57
9F:→ ss1h2a3tw: 去看看container_of這個macro吧,我建議你先弄懂C的運作 04/02 02:58
10F:→ ss1h2a3tw: 再去看linux kernel,因為裡面有各式各樣的神奇技巧 04/02 02:59
11F:推 ss1h2a3tw: 例如這個 https://goo.gl/Ejcs47 04/02 03:02
12F:→ ss1h2a3tw: 為什麼定義一個 struct upid numbers[1]; 這樣的東西 04/02 03:03
感謝回覆 後來我想了一下 發現其實有隱式轉型的發生(struct list_head *) => (struct num *) 所以我一開始用(struct list_head *) 指向下一個節點 但我在存取member時是轉型成(struct num *),自然就能存取struct num 的 member 看不懂container_of.....看來我對C真的不熟="=,有沒有什麼推薦的資料嗎?謝謝 還有其實我不是想看linux kernel(沒那麼厲害...) 只是正事做得有點崩潰,所以來找個感覺比較有趣的問題來看看XD 所以我只是想知道這個linked list是怎麼的東西 ※ 編輯: wei115 (120.109.132.88), 04/02/2018 12:21:33 ※ 編輯: wei115 (120.109.132.88), 04/02/2018 12:21:52
13F:推 stupid0319: 有些有做好的link list Api可以直接套用 04/02 12:36
14F:→ stupid0319: 就像是原PO的num結構使用上差不多 04/02 12:37
15F:→ stupid0319: del ins等等方法直接就有function可以套用 04/02 12:38
16F:→ wei115: 不能這樣說拉,這樣要怎麼學習拉XD 04/02 12:41
17F:推 cphe: 在你指向下一個node時已經有隱含做casting了,而且在malloc 04/02 13:11
18F:→ cphe: 時你要的memory夠大,所以能讀到你要的element 04/02 13:12
19F:→ cphe: 另外如上面所說,linux kernel的確有很多神奇的用法… 04/02 13:13
20F:→ MOONRAKER: 學習不一定要從做開始 也可以從用開始 04/02 14:53
21F:推 tjjh89017: 去網路上找中央資工許富皓老師的Linux kernel課程 04/02 16:15
22F:→ tjjh89017: 有錄影可以看,之前jserv也有要學生看許老師影片寫筆記 04/02 16:16
23F:→ wei115: 好的,謝謝你 04/02 16:33
24F:推 Ryspon: Google list.h 會有許多不錯的資料~ 04/03 04:44
25F:推 LPH66: 其實我原本是想先推我這篇講 container_of 的→#1N99YX7u 04/03 06:46
26F:→ LPH66: 不過因為看起來你這裡有上面提到的指標轉型問題所以才暫緩 04/03 06:47
27F:→ LPH66: 才會改來問說你是不是在看 ilist 的 C 實作 04/03 06:48
28F:→ LPH66: 因為這種用法加上 container_of 確實可以拿來實作 ilist 04/03 06:48







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:WOW站內搜尋

TOP