TBOX

TBOX是一个用c语言实现的多平台开发库,支持windows、linux、mac、ios、android以及其他嵌入式系统。

针对各个平台,封装了统一的接口,简化了各类开发过程中常用操作,使你在开发过程中,更加关注实际应用的开发,而不是把时间浪费在琐碎的接口兼容性上面,并且充分利用了各个平台独有的一些特性进行优化。

流库

针对http、file、socket、data等流数据,实现统一接口进行读写,并且支持: 阻塞、非阻塞、异步 三种读写模式。 支持中间增加多层filter流进行流过滤,实现边读取,内部边进行解压、编码转换、加密等操作,极大的减少了内存使用。

主要提供以下特性:

  1. stream:通用非阻塞流,用于一般的单独io处理。
  2. async_stream:利用asio实现的纯异步流,基于回调模式,可同时处理大量并发io。
  3. transfer:传输器,维护两路流的传输,对async_stream的使用进行更上层的封装,用其可以很方便的实现下载、上传、复制等io传输操作。
  4. transfer_pool:传输池,基于asio,维护大量并发的传输,可以用于实现爬虫、批量下载等等。
  5. static_stream:针对静态数据buffer优化的静态流,用于轻量快速的数据解析。

asio库

  1. 支持reactor和proactor两种模型,针对不同平台,采用epoll/poll/select/kqueue/iocp接口,最大化异步操作的性能。
  2. 并且对http、ssl、dns也提供了纯异步模式的实现。基于此库完全可以很方便的写出一个高性能的小型服务器。

数据库

  1. 统一并简化数据库操作接口,适配各种数据源,通过统一的url来自动连接打开支持的数据库,数据的枚举采用迭代器模型。
  2. 目前支持sqlite3以及mysql两种关系型数据库,也可自定义扩展使用其他关系型数据库。

xml库

  1. 针对xml提供DOM和SAX两种解析模式,SAX方式采用外部迭代模式,灵活性和性能更高,并且可以选择指定路径,进行解析。
  2. 解析过程完全基于stream,所以是高度流化的,可以实现边下载、边解压、边转码、边解析一条龙服务,使用较低的内存也可以解析大规模数据。
  3. 提供xml writer以支持对xml生成

内存库

  1. 参考linux内核内存管理机制的实现,并对其进行各种改造和优化,所实现的TBOX独有的一整套内存池管理架构。
  2. 调试模式下,可以轻松检测并定位内存泄露、内存越界溢出、内存重叠覆盖等常见内存问题,并对整体内存的使用进行了统计和简要分析。
  3. 针对大块数据、小块数据、字符串数据进行了充分的利用,避免了大量外部碎片和内部碎片的产生。分配操作进行了各种优化,96%的情况下,效率都是在O(1)。

容器库

  1. 提供哈希、链表、数组、队列、堆栈、最小最大堆等常用容器。
  2. 支持各种常用成员类型,在原有的容器期初上,其成员类型还可以完全自定义扩展。
  3. 所有容器都支持迭代器操作。
  4. 大部分容器都可以支持基于stream的序列化和反序列化操作。

算法库

  1. 提供各种排序算法:冒泡排序、堆排序、快速排序、插入排序。
  2. 提供各种查找算法:线性遍历、二分法搜索。
  3. 提供各种遍历、删除、统计算法。
  4. 以迭代器为接口,实现算法和容器的分离,类似stl,但是c实现的,更加轻量。

网络库

  1. 实现http、cookies、dns解析与缓存、ipv4、url的封装。

数学运算库

  1. 提供各种精度的定点运算支持
  2. 提供随机数生成器

libc库

  1. libc的一个轻量级实现,完全跨平台,并且针对不同架构进行了优化。
  2. 支持大部分字符串、宽字符串操作。
  3. 扩展字符串、宽字符串的各种大小写不敏感操作接口
  4. 扩展memsetu16、memsetu32等接口,并对其进行高度优化,尤其适合图形渲染程序

libm库

  1. libm的一个轻量级实现,完全跨平台,并且针对不同架构进行了优化。
  2. 扩展部分常用接口,增加对sqrt、log2等常用函数的整数版本计算,进行高度优化,不涉及浮点运算,适合嵌入式环境使用。

object库

  1. 轻量级类apple的CoreFoundation库,支持object、dictionary、array、string、number、date、data等常用对象,并且可以方便扩展自定义对象的序列化。
  2. 支持对xml、json、binary以及apple的plist(xplist/bplist)格式序列化和反序列化。 并且实现自有的binary序列化格式, 针对明文进行了简单的加密,在不影响性能的前提下,序列化后的大小比bplist节省30%。

平台库

  1. 提供file、directory、socket、thread、time等常用系统接口
  2. 提供atomic、atomic64接口
  3. 提供高精度、低精度定时器
  4. 提供高性能的线程池操作
  5. 提供event、mutex、semaphore、spinlock等事件、互斥、信号量、自旋锁操作
  6. 提供获取函数堆栈信息的接口,方便调试和错误定位
  7. 提供跨平台动态库加载接口(如果系统支持的话)

压缩库

  1. 支持zlib/zlibraw/gzip的压缩与解压(需要第三方zlib库支持)。

字符编码库

  1. 支持utf8、utf16、gbk、gb2312、uc2、uc4 之间的互相转码,并且支持大小端格式。

实用工具库

  1. 提供base64/32编解码、crc32、md5、sha等hash算法、日志输出、断言、url编解码

XMake

XMake是一个跨平台自动构建工具,支持在各种主流平台上构建项目,类似cmake、automake、premake,但是更加的方便易用,工程描述语法更简洁直观,支持平台更多,并且集创建、配置、编译、打包、安装、卸载、运行于一体。

支持特性

  1. 支持windows、mac、linux、ios、android等平台,自动检测不同平台上的编译工具链(也可手动配置) 编译windows项目采用原生vs的工具链,不需要使用cygwin、mingw(当然这些也支持)

  2. 支持自定义平台编译配置,可以很方便的扩展第三方平台支持

  3. 采用lua脚本语法描述项目,描述规则简单高效,逻辑规则可灵活修改,并且不会生成相关平台的工程文件,是工程更加简单明了

  4. 支持创建模板工程、配置项目、编译项目、运行、打包、安装和卸载等常用功能(后续还会增加:自动生成文档、调试等模块)

  5. 支持编译c/c++/objc成静态库、动态库、命令行可执行程序(后续还会增加:mac、ios、android的app的生成规则)

  6. 提供丰富的工程描述api,使用简单灵活,例如添加编译文件只需(还支持过滤排除):

    add_files("src/*.c", "src/asm/**.S", "src/*.m")

  7. 支持头文件、接口、链接库依赖、类型的自动检测,并可自动生成配置头文件config.h

  8. 支持自定义编译配置开关,例如如果在工程描述文件中增加了enable_xxx的开关,那么配置编译的时候就可以手动进行配置来启用它:

    xmake config --enable_xxx=true

  9. 提供一键打包功能,不管在哪个平台上进行打包,都只需要执行一条相同的命令,非常的方便

  10. 支持自定义编译工具和规则,例如想要增加对masm/yasm的编译规则,只需将自己写的masm.lua/yasm.lua规则文件,放到当前项目目录下即可。。

  11. 支持全局配置,一些常用的项目配置,例如工具链、规则描述等等,都可以进行全局配置,这样就不需要每次编译不同工程,都去配置一遍

  12. 除了可以自动检测依赖模块,也支持手动强制配置模块,还有各种编译flags。

后续工作

  1. 完善打包模块,支持对ios、mac、android的app进行一键打包和签名,生成.ipa、.apk、.app的应用程序文件
  2. 完善安装功能,支持对ios、android的app进行安装到设备
  3. 实现调试功能
  4. 实现自动生成doxygen文档功能
  5. 增加一些实用的工程描述api,例如:下载api,可以自动下载缺少的依赖库等等。。
  6. 解析automake、cmake的工程,并自动生成xmake的描述文件,实现无缝编译(如果这个实现成功的话,以后移植编译一些开源代码就更方便了)