作者DonaldTrunnp (The US President)
看板C_and_CPP
標題Re: [問題] 請問Linux C有類似List<T>的用法嗎?
時間Mon Feb 12 13:20:50 2018
因為我也曾經有過類似的需求
而寫了一套一系列的 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