看板 C_and_CPP 關於我們 聯絡資訊
因為我也曾經有過類似的需求 而寫了一套一系列的 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有沒有類似方法呢? : 懇請個位高手指導,謝謝 -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 82.196.1.179 ※ 文章網址: https://www.ptt.cc/bbs/C_and_CPP/M.1518412852.A.7E6.html ※ 編輯: DonaldTrunnp (146.185.185.122), 02/12/2018 13:29:06
chrishappy11: 推~~ 02/12 13:28
galic: 總統先生的容器 02/12 13:55
damody: 好猛 02/12 14:28
la8day: 厲害了這 02/12 14:35
ggBird: 偉大的祖國統領 02/12 14:48
Sirctal: 你是不是在WWE的摔角擂台上寫出來的?? 02/12 16:02
Neisseria: 總統級的 container,已跪 02/12 16:03
uranusjr: 可是瑞凡, C# 通常是用 array list 不是 linked list 02/12 16:07
dzwei: 跪了 02/12 16:19
dannypsnl: 點進去才發現按過了XE 02/12 16:49
dannypsnl: XD 02/12 16:49
chrishappy11: 沒想到在C#簡單的List拿到C/C++竟然這麼複雜 02/12 20:47
LPH66: 不, 只有 C 而已, C++ 的 STL 有 std::list<T> 02/12 20:57
Ommm5566: c++還有boost MPL庫的list工具 02/12 21:27
y3k: 已給星 02/12 22:00
DonaldTrunnp: 謝謝 >皿< 02/12 22:36
oiu850714: 這不是專題特優的大大嗎 02/12 23:26
descent: 不知道為什麼, c 標準不加入這些資料結構 02/12 23:26
hunandy14: 各種黑魔法 已跪 02/13 01:49
oiu850714: 用macro幹出container,超醉... 02/13 02:37
cashlalala: 強~~~~~~ 02/13 23:40
andrew000129: 推 02/15 15:15
Neisseria: 補給星了,拜讀 macro 語法中 >_< 02/15 17:57