Linux內(nèi)核大量使用面向?qū)ο蟮脑O(shè)計(jì)思想,通過(guò)追蹤源碼,我們甚至可以使用面向?qū)ο笳Z(yǔ)言常用的UML類圖來(lái)分析Linux設(shè)備管理的"類"之間的關(guān)系。這里以4.8.5內(nèi)核為例從kobject,kset,ktype的分析入手,進(jìn)而一探內(nèi)核對(duì)于設(shè)備的管理方式
container_of宏
這個(gè)宏幾乎是linux數(shù)據(jù)結(jié)構(gòu)的基礎(chǔ),Linux中的鏈表與傳統(tǒng)的鏈表不同,其鏈表的節(jié)點(diǎn)本身并不包含任何數(shù)據(jù),任何想要插入到鏈表的數(shù)據(jù)只需要包含一個(gè)事先寫好的節(jié)點(diǎn)
//include/linux/types.h184 struct list_head { 185 struct list_head *next, *prev; 186 };