polytope

多进程多线程编程框架
授权协议 GPL
开发语言 C/C++
所属分类 程序开发、 高性能网络开发库
软件类型 开源软件
地区 国产
投 递 者 范浩宕
操作系统 Linux
开源组织
适用人群 未知
 软件概览

polytope (多面体)是一套多进程多线程编程框架,快速构建产品软件。

  • abnormal_exit(异常退出保护):防止多线程程序异常退出时fd未关闭、锁未释放等问题。
  • async_io(异步IO):针对大数据量的eMMC存取。
  • confmgr(配置管理):基于jsoncpp的配置文件参数管理
  • data_recorder:用于二进制数据记录及查找。
  • fd:用于cdev、socket、fifo、pipe的IO监视
  • inotify:支持fd机制的文件或目录监视,非常灵活。
  • log_server/log_client:本地日志和网络日志
  • event/msg基于eventfd的线程间事件通知和消息通知机制。
  • parallel_task(并行任务流):针对复杂分层算法的拆解。
  • shm_reader:共享内存状态监视,针对跨进程大批量数据通信,基于posix shm + inotify实现。
  • shm_manager:共享内存管理器,头部建立共享型pthread_rwlock,保证数据一致性、安全性。
  • tcp_server/tcp_client:TCP通信,注册回调形式。
  • udp_server/udp_client:UDP通信,注册回调形式。
  • unix_server/unix_client:跨进程通信,注册回调形式。
  • threadpool(线程池):针对阻塞任务和耗时任务。
  • timer:基于timerfd的定时器,针对延后执行和周期执行任务。
  • async_task(异步任务):针对阻塞型函数,如tcp建立链接connect()等。
  • __attribute((constructor(*))):多线程管理、多进程管理。
  • eqmq:去中心化、零协议、无序组网的订阅和发布服务。
  • eqmq2.0:分布式版本。
 相关资料
  • 其实创建线程之后,线程并不是始终保持一个状态的,其状态大概如下: New 创建 Runnable 就绪。等待调度 Running 运行 Blocked 阻塞。阻塞可能在 Wait Locked Sleeping Dead 消亡 线程有着不同的状态,也有不同的类型。大致可分为: 主线程 子线程 守护线程(后台线程) 前台线程 简单了解完这些之后,我们开始看看具体的代码使用了。 1、线程的创建 Pyt

  • 如果以下代码在多线程应用程序中可以工作,您可以帮助我吗。 这是我的Java脚本,将由Nashorn评估 这就是我创建脚本引擎的方式 在使用Testng进行测试时,此操作不会出现任何错误 测试结果1-请注意,有些数据是重复的 但是,如果我添加"并行=true"到@DataProvider我的脚本开始失败 测试结果2-请注意,重复一些数据,以表明相同的参考编号可能在测试过程中随机失败 有人可以确认我是

  • 本文向大家介绍linux多线程编程(五),包括了linux多线程编程(五)的使用技巧和注意事项,需要的朋友参考一下 线程   线程是计算机中独立运行的最小单位,运行时占用很少的系统资源。可以把线程看成是操作系统分配CPU时间的基本单元。一个进程可以拥有一个至多个线程。它线程在进程内部共享地址空间、打开的文件描述符等资源。同时线程也有其私有的数据信息,包括:线程号、寄存器(程序计数器和堆栈指针)、堆

  • 本文向大家介绍Linux多线程编程(二),包括了Linux多线程编程(二)的使用技巧和注意事项,需要的朋友参考一下 引言 条件变量是利用线程间共享的全局变量进行同步的一种机制,主要包括两个动作:一个线程等待条件变量的条件成立而挂起(此时不再占用cpu);另一个线程使条件成立(给出条件成立信号)。为了防止竞争,条件变量的使用总是和一个互斥锁结合在一起。 函数原型 1. 定义条件变量 2. 初始化和销

  • 本文向大家介绍Linux多线程编程(一),包括了Linux多线程编程(一)的使用技巧和注意事项,需要的朋友参考一下 一、什么是线程?       线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位。线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的全部资源。 二、什

  • 9.3.4 Python 多线程编程 很多编程语言都支持多线程编程,Python 语言亦然。与其他编程语言相比,Python 的 多线程编程是非常简单的。 Python 提供了两个支持线程的模块,一个是较老的 thread 模块,另一个是较新的 threading 模块。其中 threading 采用了面向对象实现,功能更强,建议读者使用。 thread 模块的用法 任何程序一旦开始执行,就构成了

  • 我正在开发应用程序(Matt的traceroute windows版本http://winmtr.net/),它创建了多线程,每个线程都有自己的进程(执行ping命令)。 使用阻塞队列(在任务执行之前保留任务) 平丝。JAVA 现在如果我创建多个线程,比如在一个循环中超过500个线程,并在池执行器中执行 执行线程 我确实知道LinkedBlockingQueue在执行任务之前持有任务。每个线程的进

  • 并发是什么?引用Rob Pike的经典描述: 并发是同一时间应对多件事情的能力 其实在我们身边就有很多并发的事情,比如一边上课,一边发短信;一边给小孩喂奶,一边看电视,只要你细心留意,就会发现许多类似的事。相应地,在软件的世界里,我们也会发现这样的事,比如一边写博客,一边听音乐;一边看网页,一边下载软件等等。显而易见这样会节约不少时间,干更多的事。然而一开始计算机系统并不能同时处理两件事,这明显满