因為我也曾經有過類似的需求
而寫了一套一系列的 linked list 容器
https://github.com/kevin-dong-nai-jia/OpenGC3
更加注重在 性能的優化和代碼的簡潔性
目前以 MIT License 發佈
我的實作與 Linux list_head 的差別如下:
1. 當前置定義 #define CC_STRICT
可以「完全遵守」使用 C99+ 標準規範
不使用任何 GCC C編譯器的擴展語法
但是 Linux 的實作不能
2. 提供多種 list 的資料結構
包含 doubly/singly/exclusive-or list
但是 Linux 的實作只有第一種
3. 使用 non-intrusive 容器的設計
宣告和操作 list 變得非常地容易
只需要使用 ccdll(int) list;
這與 Linux 使用方式的有巨大的改進
4. 最重要的是
它優異的的設計使得它的效能可以
在處理極大量資料時大大提升
https://i.imgur.com/ehK1uDZ.png
5. 另一個最重要的是
它的多種測資已經通過 valgrind 的檢查
不會造成內存外泄和非初始化資料存取
而且擁有詳細的 documentations
描述每個操作的使用方法和巨集依賴關係
這是 OpenGC3 專案被託管的地方
https://github.com/kevin-dong-nai-jia/OpenGC3
這是一個簡易的範例
介紹如何使用 ccdll 對檔案基於行的排序
./sort-by-lines <path-to-file> <strncmp-3rd-arg>
https://gist.github.com/kevin-dong-nai-jia/834e3d16c3c7f0f8496ef23945dbf7ca
希望你會喜歡 >皿<
喜歡並對你有幫助的話請幫我在上方點擊一顆星星!
這會是我最棒的過年禮物(燦笑
※ 引述《takesi5200 (小咪)》之銘言:
: 問題(Question):
: 不好意思,.NET有List<T>集合,
: 可以很方便把資料放入集合裡。
: 小妹因公司需求要在Linux平台上
: 也開發類似此方法。
: 請問Linux C有沒有類似方法呢?
: 懇請個位高手指導,謝謝