TBOX v1.5.1 發布,輕量級跨平臺 C 開發庫
TBOX v1.5.1 發布,更新信息如下:
v1.5.1 更新
優化 stream ,支持對字符設備文件的讀寫
自動檢測所有系統 libc 接口,優先使用系統版本
修復 android 下的一些 bug
修改 tb_init 接口,增加 allocator 自定義內存分配器參數,實現用戶的侵入式內存管理
重構內存管理,完全采用分配器 allocator 模式,可以靈活切換內存管理,支持原生系統內存、靜態 buffer 內存、內存池等各種分配方式
支持自定義內存分配器,并且能夠在 debug 模式下,獲取每次分配的代碼位置信息,用于自定義追蹤
增加輕量級 static_pool 來維護整塊 buffer 的內存分配,適合局部管理部分內存, pool 雖然也能維護,但是底層基于 large_pool ,比較重量級,適合全局管理內存
修復 stream 的 seek 問題
增加 stream 快速讀取全部數據到 string 的接口
增加 adler32 hash 算法
增加 tb_memmem 接口
重定義 assert , debug 模式遇到 assert 直接 abort 執行
采用 pcre/pcre2/posix regex 實現正則表達式庫
簡介
TBOX是一個用c語言實現的多平臺開發庫,支持 windows、linux、mac、ios、android 以及其他嵌入式系統。
針對各個平臺,封裝了統一的接口,簡化了各類開發過程中常用操作,使你在開發過程中,更加關注實際應用的開發,而不是把時間浪費在瑣碎的接口兼容性上面,并且充分利用了各個平臺獨有的一些特性進行優化。
-
在線文檔:https://github.com/waruqi/tbox/wiki/%E7%9B%AE%E5%BD%95
-
在線手冊:http://tboox.github.io/doc/tbox/html/index.html
-
在線源碼:https://github.com/waruqi/tbox
-
OSC@GIT:http://git.oschina.net/tboox/tbox
流庫
針對http、file、socket、data等流數據,實現統一接口進行讀寫,并且支持: 阻塞、非阻塞、異步 三種讀寫模式。
支持中間增加多層filter流進行流過濾,實現邊讀取,內部邊進行解壓、編碼轉換、加密等操作,極大的減少了內存使用。
主要提供以下特性:
-
stream:通用非阻塞流,用于一般的單獨io處理。
-
async_stream: 利用asio實現的純異步流,基于回調模式,可同時處理大量并發io。
-
transfer: 傳輸器,維護兩路流的傳輸,對async_stream的使用進行更上層的封裝,用其可以很方便的實現下載、上傳、復制等io傳輸操作。
-
transfer_pool: 傳輸池,基于asio,維護大量并發的傳輸,可以用于實現爬蟲、批量下載等等。
-
static_stream: 針對靜態數據buffer優化的靜態流,用于輕量快速的數據解析。
asio庫
-
支持reactor和proactor兩種模型,針對不同平臺,采用epoll/poll/select/kqueue/iocp接口,最大化異步操作的性能。
-
并且對http、ssl、dns也提供了純異步模式的實現。基于此庫完全可以很方便的寫出一個高性能的小型服務器。
數據庫
-
統一并簡化數據庫操作接口,適配各種數據源,通過統一的url來自動連接打開支持的數據庫,數據的枚舉采用迭代器模型。
-
目前支持sqlite3以及mysql兩種關系型數據庫,也可自定義擴展使用其他關系型數據庫。
xml庫
-
針對xml提供DOM和SAX兩種解析模式,SAX方式采用外部迭代模式,靈活性和性能更高,并且可以選擇指定路徑,進行解析。
-
解析過程完全基于stream,所以是高度流化的,可以實現邊下載、邊解壓、邊轉碼、邊解析一條龍服務,使用較低的內存也可以解析大規模數據。
-
提供xml writer以支持對xml生成
內存庫
-
參考linux內核內存管理機制的實現,并對其進行各種改造和優化,所實現的TBOX獨有的一整套內存池管理架構。
-
調試模式下,可以輕松檢測并定位內存泄露、內存越界溢出、內存重疊覆蓋等常見內存問題,并對整體內存的使用進行了統計和簡要分析。
-
針對大塊數據、小塊數據、字符串數據進行了充分的利用,避免了大量外部碎片和內部碎片的產生。分配操作進行了各種優化,96%的情況下,效率都是在O(1)。
容器庫
-
提供哈希、鏈表、數組、隊列、堆棧、最小最大堆等常用容器。
-
支持各種常用成員類型,在原有的容器期初上,其成員類型還可以完全自定義擴展。
-
所有容器都支持迭代器操作。
-
大部分容器都可以支持基于stream的序列化和反序列化操作。
算法庫
-
提供各種排序算法:冒泡排序、堆排序、快速排序、插入排序。提供各種查找算法:線性遍歷、二分法搜索。
-
提供各種遍歷、刪除、統計算法。
-
以迭代器為接口,實現算法和容器的分離,類似stl,但是c實現的,更加輕量。
-
網絡庫
-
實現http、cookies、dns解析與緩存、ipv4、url的封裝。
數學運算庫
-
提供各種精度的定點運算支持
-
提供隨機數生成器
libc庫
-
libc的一個輕量級實現,完全跨平臺,并且針對不同架構進行了優化。
-
支持大部分字符串、寬字符串操作。
-
擴展字符串、寬字符串的各種大小寫不敏感操作接口
-
擴展memset_u16、memset_u32等接口,并對其進行高度優化,尤其適合圖形渲染程序
libm庫
-
libm的一個輕量級實現,完全跨平臺,并且針對不同架構進行了優化。
-
擴展部分常用接口,增加對sqrt、log2等常用函數的整數版本計算,進行高度優化,不涉及浮點運算,適合嵌入式環境使用。
object庫
-
輕量級類apple的CoreFoundation庫,支持object、dictionary、array、string、number、date、data等常用對象,并且可以方便擴展自定義對象的序列化。
-
支持對xml、json、binary以及apple的plist(xplist/bplist)格式序列化和反序列化。
-
并且實現自有的binary序列化格式, 針對明文進行了簡單的加密,在不影響性能的前提下,序列化后的大小比bplist節省30%。
平臺庫
-
提供file、directory、socket、thread、time等常用系統接口
-
提供atomic、atomic64接口
-
提供高精度、低精度定時器
-
提供高性能的線程池操作
-
提供event、mutex、semaphore、spinlock等事件、互斥、信號量、自旋鎖操作
-
提供獲取函數堆棧信息的接口,方便調試和錯誤定位
-
提供跨平臺動態庫加載接口(如果系統支持的話)
壓縮庫
-
支持zlib/zlibraw/gzip的壓縮與解壓(需要第三方zlib庫支持)。
字符編碼庫
-
支持utf8、utf16、gbk、gb2312、uc2、uc4 之間的互相轉碼,并且支持大小端格式。
實用工具庫
-
提供base64/32編解碼、crc32、md5、sha等hash算法、日志輸出、斷言、url編解碼
來自: http://www.oschina.net//news/70255/tbox-v-1-5-1