设为首页 收藏本站
查看: 766|回复: 0

[软件发布] TBOX v1.5.0 发布,轻量级跨平台开发库

[复制链接]

尚未签到

发表于 2015-11-2 09:51:43 | 显示全部楼层 |阅读模式
欢迎加入运维网交流群:263444886   DSC0000.jpg
  TBOX v1.5.0 发布,此版本更新内容如下:
  更新
  

  •   重建整个编译架构,采用xmake跨平台自动构建工具进行构建。。
  •   优化.pkg的依赖包机制,支持依赖库和接口的自动检测,针对libc、libm优先使用自动检测到的系统库接口实现,如果当前平台没有实现则使用tbox的自己实现版本,使得最大化性能和跨平台性。。
  •   修复strlcpy等一些libc接口的实现bug
  •   增加跨平台环境变量操作接口
  •   完善和优化路径操作,增加相对路径、绝对路径的相互转换
简介
  TBOX是一个用c语言实现的多平台开发库,支持windows、linux、mac、ios、android以及其他嵌入式系统。
  针对各个平台,封装了统一的接口,简化了各类开发过程中常用操作,使你在开发过程中,更加关注实际应用的开发,而不是把时间浪费在琐碎的接口兼容性上面,并且充分利用了各个平台独有的一些特性进行优化。

  •   在线文档
  •   在线手册
  •   在线源码
流库
  针对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编解码

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-133912-1-1.html 上篇帖子: Android Studio 1.5 Preview 2 发布 下篇帖子: secilog 1.16 发布 增加了集群.日志导入,日志过滤和归并等
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表