Reactor反应器的实现方法详解
大多数应用都会使用ACE_Reactor::instance()提供的默认反应器实例。
但是你也可以选择自己的反应器,这是因为ACE使用了Bridge模式(使用两个不同的类:一个是编程接口,另一个是实现,第一个类会把各个操作传给第二个类)。
例如使用线程池反应器实现:
ACE_TP_Reactor* tp_reactor = new ACE_TP_Reactor;
ACE_Reactor* my_reactor = new ACE_Reactor(tp_reactor, 1);//1表示my_reactor销毁时也要删除tp_reactor
ACE_Reactor::instance(my_reactor, 1);//1表示在程序终止时删除my_reactor实例
反应器的实现
1)ACE_Select_Reactor
除了Windows之外的所有平台使用的默认反应器实现(select()函数)。
2)ACE_WFMO_Reactor
Windows上的默认反应器实现。
3)ACE_Msg_WFMO_Reactor
应用COM/DCOM服务器。
4)ACE_TP_Reactor
扩展了ACE_Select_Reactor,允许它同时在多个线程中运行:线程池。
Leader/Follower模板,线程之一将成为领导者,并获取反应器的所有权,以等待事件。
5)ACE_Priority_Reactor
也扩展了ACE_Select_Reactor。
使用了ACE_Event_Handler类中的priority()方法,使得优先级更高的事件会得到先处理。
6)GUI集成式反应器
用于X Window System,扩展了ACE_Select_Reactor。
单线程应用,但同时既能响应GUI时间(比如按钮按下),又能响应你自己的应用事件。
QuickTime Reactor
FastLight Reactor
Tk Reactor
Xt Reactor
相关推荐
-
angularJS中router的使用指南
这几天看了angularjs和backbone,大看了解了knockout和emberjs,刚刚上网看到了一个angular的router的demo,现在顺便记下来 复制代码 代码如下: <!--- DEMO_INDEX.html --> <!doctype html> <head> <meta charset="utf-8"> <title>route</title> </head><br>
-
深入理解JavaScript的React框架的原理
如果你在两个月前问我对React的看法,我很可能这样说: 我的模板在哪里?javascript中的HTML在做些什么疯狂的事情?JSX开起来非常奇怪!快向它开火,消灭它吧! 那是因为我没有理解它. 我发誓,React 无疑是在正确的轨道上, 请听我道来. Good old MVC 在一个交互式应用程序一切罪恶的根源是管理状态. "传统"的方式是MVC架构,或者一些变体. MVC提出你的模型是检验真理的唯一来源 - 所有的状态住在那里. 视图是源自模型,并且必须保持同步. 当模式的转变,
-
利用yarn实现一个webpack+react种子
一.初始化项目 首先确保你的node 版本 >=4.0.并且确保yarn可以正常工作,关于安装yarn,你可以看这里 我们先创建个空文件夹 比如yarn-react-webpack-seed,然后输入命令: yarn init yarn 如果没有安装,全程用 npm代替也没问题. 项目会初始化 package.json ,然后填写一些基本信息即可. 接下来我们开始安装依赖项,再 package.json 的添加下面内容 "dependencies": { "react&
-
Webpack 实现 AngularJS 的延迟加载
随着你的单页应用扩大,其下载时间也越来越长.这对提高用户体验不会有好处(提示:但用户体验正是我们开发单页应用的原因).更多的代码意味着更大的文件,直到代码压缩已经不能满足你的需求,你唯一能为你的用户做的就是不要再让他一次性下载整个应用.这时,延迟加载就派上用场了.不同于一次性下载所有文件,而是让用户只下载他现在需要的文件. 所以.如何让你的应用程序实现延迟加载?它基本上是分成两件事情.把你的模块拆分成小块,并实施一些机制,允许按需加载这些块.听起来似乎有很多工作量,不是吗?如果你使用 Webpa
-
webpack+vue.js实现组件化详解
简介 在vue中实现组件化用到了vue特有的文件格式.vue,在每一个.vue文件就是一个组件,在组件中我们将html,css,js全部写入,然后在webpack中配置vue-loader就可以了. 建立vue组件 在src目录下建立components文件夹,并在其中建立app.vue文件,这样我们项目的目录结构如下: |--dist //webpack打包后生成的文件夹 | |--build.js |--node_modules //项目的依赖所在的文件夹 |--src //文件入口 | |
-
利用React-router+Webpack快速构建react程序
本文主要介绍的是使用React-router和Webpack如何快速构建一个react程序,下面话不多说,感兴趣的可以一起学习学习. 初始化项目 我们先创建个空文件夹,然后初始化 package.json ,填写一些基本信息. $ npm init 接下来我们开始安装依赖项,我的 package.json 的依赖项如下 "devDependencies": { "babel": "^5.5.6", "babel-core":
-
webpack+vue.js快速入门教程
前言 vuejs--轻量.学习成本低.双向绑定.无dom的操作.组件的形式编写 vuejs是个轻量级的mvvm框架, 集合了angular的基本功能,却又比angular更为精简,功能上涵盖了双向绑定.指令.逻辑控制.过滤器.事件监听.函数等.框架的特点使得项目 在状态变更.分页的场景下可以拥有很大的便利--所有的操作只需要变更数组,没有任何的dom操作. webpack--CommonJS的引用和编写方式.loader非常的丰富,包括vue-loader.css-loader.less-loa
-
Webpack 实现 Node.js 代码热替换
这两天为了这个问题, Gitter 上问, Twitter 上问, GitHub 上问, 两天没反应 原来写博客的 jlongster 不理我, 我也不知道 Webpack 作者的联系方式 最后在 Gitter 上发的消息他似乎看到了, 就粗略地解释了一遍, 醍醐灌顶啊... https://github.com/webpack/docs/issues/45#issuecomment-149793458 Here is the process in short: Compile the serv
-
webpack中引用jquery的简单实现
1.首先需要添加项目中jquery的依赖 npm install jquery --save-dev 2.参考配置代码: var webpack = require("webpack"); var path = require("path"); module.exports = { entry:{ home:"./src/js/home.js", -- }, output:{ path:__dirname+"/dist/js"
-
ACE反应器(Reactor)模式的深入分析
反应器(Reactor):用于事件多路分离和分派的体系结构模式通常的,对一个文件描述符指定的文件或设备, 有两种工作方式: 阻塞与非阻塞.所谓阻塞方式的意思是指, 当试图对该文件描述符进行读写时, 如果当时没有东西可读,或者暂时不可写, 程序就进入等待状态, 直到有东西可读或者可写为止.而对于非阻塞状态, 如果没有东西可读, 或者不可写, 读写函数马上返回, 而不会等待. 在前面的章节中提到的Tcp通信的例子中,就是采用的阻塞式的工作方式:当接收tcp数据时,如果远端没有数据可以读,则会一直阻塞
随机推荐
- Python实现的使用telnet登陆聊天室实例
- 浅谈Redis在分布式系统中的协调性运用
- jQuery鼠标经过方形图片切换成圆边效果代码分享
- Bootstrap每天必学之日期控制
- php快递单号查询接口使用示例
- Python自动化开发学习之三级菜单制作
- 详解详解Python中writelines()方法的使用
- Android高仿IOS 滚轮选择控件
- CentOS7下MySQL5.7安装配置方法图文教程(YUM)
- 纯JavaScript实现获取onclick、onchange等事件的值
- javascript基本数据类型和转换
- JavaScript设置body高度为浏览器高度的方法
- php的文件上传入门教程(实例讲解)
- JS去除iframe滚动条的方法
- 保障WEB服务器安全的三方面的利器
- java通过共享变量结束run停止线程的方法示例
- Android应用中图片浏览时实现自动切换功能的方法详解
- php在文件指定行中写入代码的方法
- Ajax+PHP 边学边练 之二 实例
- C 语言环境设置详细讲解