本帖最后由 waruqi 于 2015-11-05 10:14 编辑
TBOX v1.5.0 发布,此版本更新内容如下: 更新:
重建整个编译架构,采用xmake跨平台自动构建工具进行构建。。 优化.pkg的依赖包机制,支持依赖库和接口的自动检测,针对libc、libm优先使用自动检测到的系统库接口实现,如果当前平台没有实现则使用tbox的自己实现版本,使得最大化性能和跨平台性。。 修复strlcpy等一些libc接口的实现bug 增加跨平台环境变量操作接口 完善和优化路径操作,增加相对路径、绝对路径的相互转换
简介TBOX是一个用c语言实现的多平台开发库,支持windows、linux、mac、ios、android以及其他嵌入式系统。 针对各个平台,封装了统一的接口,简化了各类开发过程中常用操作,使你在开发过程中,更加关注实际应用的开发,而不是把时间浪费在琐碎的接口兼容性上面,并且充分利用了各个平台独有的一些特性进行优化。
代码和文档见:https //github.com/waruqi/tbox/wiki
流库针对http、file、socket、data等流数据,实现统一接口进行读写,并且支持: 阻塞、非阻塞、异步 三种读写模式。 支持中间增加多层filter流进行流过滤,实现边读取,内部边进行解压、编码转换、加密等操作,极大的减少了内存使用。 主要提供以下特性: stream:通用非阻塞流,用于一般的单独io处理。 async_stream:利用asio实现的纯异步流,基于回调模式,可同时处理大量并发io。 transfer:传输器,维护两路流的传输,对async_stream的使用进行更上层的封装,用其可以很方便的实现下载、上传、复制等io传输操作。 transfer_pool:传输池,基于asio,维护大量并发的传输,可以用于实现爬虫、批量下载等等。 static_stream:针对静态数据buffer优化的静态流,用于轻量快速的数据解析。
asio库数据库xml库内存库参考linux内核内存管理机制的实现,并对其进行各种改造和优化,所实现的TBOX独有的一整套内存池管理架构。 调试模式下,可以轻松检测并定位内存泄露、内存越界溢出、内存重叠覆盖等常见内存问题,并对整体内存的使用进行了统计和简要分析。 针对大块数据、小块数据、字符串数据进行了充分的利用,避免了大量外部碎片和内部碎片的产生。分配操作进行了各种优化,96%的情况下,效率都是在O(1)。
容器库提供哈希、链表、数组、队列、堆栈、最小最大堆等常用容器。 支持各种常用成员类型,在原有的容器期初上,其成员类型还可以完全自定义扩展。 所有容器都支持迭代器操作。 大部分容器都可以支持基于stream的序列化和反序列化操作。
算法库网络库数学运算库libc库libm库object库轻量级类apple的CoreFoundation库,支持object、dictionary、array、string、number、date、data等常用对象,并且可以方便扩展自定义对象的序列化。 支持对xml、json、binary以及apple的plist(xplist/bplist)格式序列化和反序列化。 并且实现自有的binary序列化格式, 针对明文进行了简单的加密,在不影响性能的前提下,序列化后的大小比bplist节省30%。
平台库压缩库字符编码库实用工具库 |