[NIO]dawn之Task具体解释
在上篇文章中,我们设置好了开发环境,接下来。我们将在了解了Task以及Buffer之后,再開始了解网络编程。我们首先来看看Task
task简单介绍
package zhmt.dawn; import kilim.Pausable;
import kilim.Scheduler;
import kilim.Task; //继承kilim.Task
public class HelloWorld extends Task{
//覆盖execute,注意这里的Pausable异常,这个异常必须抛出。不能捕捉(实际上也不会捕捉到这个异常)
@Override
public void execute() throws Pausable, Exception {
System.out.println("hello world");
} public static void main(String[] args) {
//创建调度器,并启动
Scheduler sch = new Scheduler();
sch.start(); //new 我们写的Task
HelloWorld task = new HelloWorld();
//让task在sch中运行
task.startOn(sch); System.out.println("task started.");
}
}
注意Pausable这个异常。这个异常不须要catch,必须抛出,假设你的函数调用了一个抛出Pausable异常的函数,那么你的函数也必须抛出Pausable异常。为什么不须要catch呢?由于这个异常仅仅是起到一个标记的作用。标记当前函数是能够暂停的(也就是指协程的挂起、恢复)。假设一个函数是可暂停的,那么全部调用它的函数也都是可暂停的,因此他们也都须要标记自己是Pausable的。那么这个标记是什么时候起作用呢?是在执行weaver.xml的时候,这时。织入程序会扫描全部方法,假设标记了Pausable,就会插入挂起、恢复相关的代码。所以这个标记是编译时用的。真正执行的时候没什么用,执行的时候不会抛出这个异常,我们也捕捉不到。
啰嗦了一堆,代码侍奉:
package zhmt.dawn; import kilim.Pausable;
import kilim.Scheduler;
import kilim.Task; public class SleepTest extends Task{
//覆盖execute,注意这里的Pausable异常,这个异常必须抛出,不能捕捉(实际上也不会捕捉到这个异常)
@Override
public void execute() throws Pausable, Exception {
System.out.println("I am tired.");
sleepOneSecond();
//1秒后打印
System.out.println("I am refreshed.");
} //sleepOneSecond调用了sleep,而sleep是可暂停的。所以,sleepOneSecond抛出了Pausable异常
private void sleepOneSecond() throws Pausable{
sleep(1000);
} public static void main(String[] args) {
//创建调度器,并启动
Scheduler sch = new Scheduler();
sch.start(); //new 我们写的Task
SleepTest task = new SleepTest();
//让task在sch中运行
task.startOn(sch); }
}
你可能会想假设sleepOneSecond捕捉了Pausable异常,会如何呢?你能够试试,熟悉一下这个错误场景吧,它是我们的老朋友的。以后会常遇到。
注意这里的task.startOn(sch)。这里指定了task由谁来调度。这里明白指定scheduler的原因是当前的代码是在main线程而非scheduler中运行的。假设是在scheduler中运行的代码,启动task时是不能要指定调度器的,由于会默认在当前调度器中运行。
dawn程序一般启动方法
ok。以上我们了解了task基本使用方法。以下。我从项目的有用角度来看看一看。dawn程序通常是怎样启动、初始化的(我在项目中就是这么用的):
1、创建一个主调度器,能够保存在全局变量上,方便外部线程向主调度器公布任务。
2、创建一个用于初始化的Task。把我们的整个程序从用这个task载入起来。
3、启动这个初始化task
示比例如以下,这个程序实现了这么个功能,启动若干任务。累加一个全局变量,另外一个变量打印累加速度(每秒累加几次):
/* Copyright (c) 2006, Sriram Srinivasan
*
* You may distribute this software under the terms of the license
* specified in the file "License"
*/ package zhmt.dawn; //import kilim.Mailbox;
import kilim.Pausable;
import kilim.Scheduler;
import kilim.Task; public class TestScheduler extends Task { public static void main(String[] args) throws Exception {
final Scheduler sch = new Scheduler();
sch.start(); new Task(){
public void execute() throws Pausable ,Exception {
for (int i = 0; i < 6000; i++) {
TestScheduler s = new TestScheduler();
s.start();
}
new Task() {
public void execute() throws Pausable, Exception {
while (true) {
acc = 0;
sleep(1000);
System.out.println("spd:"+acc); //打印累加速度
}
}
}.start();
};
}.startOn(sch);
} static long acc = 0; /**
* The entry point. mb.get() is a blocking call that yields the thread
* ("pausable")
*/ public void execute() throws Pausable {
for (int i = 0; i < 100000000; i++) {
acc++;//1毫秒累加一次
sleep(1);
}
}
}
注意:构造函数函数不能抛出Pausable异常,会导致程序不能执行。原因我也不是十分明确。我仅仅是确保了自己的程序不犯这个错。
假设你能执行以上程序,也欢迎你把执行的结果贴出来。同一时候贴出你的操作系统以及cpu配置。让我评估一下这个程序在不同平台上执行的结果。
[NIO]dawn之Task具体解释的更多相关文章
- [nio]dawn的基本概念
1.dawn是单线程的: 为什么单线程?现实中非常多程序都是单线程的.比方redis,memcache,nodejs.mmorpgserver..... . 採用单线程有两大优点,首先,不须要使用锁, ...
- java nio(一)buffer
概述 常见的网络io分为两种情况,BIO(block-io)和NIO(non-block-io),分别位于java.io和java.nio. BIO,是阻塞的io,采用一个线程处理一个连接的方式,就算 ...
- C#深度学习のTask(基于任务的异步模型)
一.Task关键字解释 Task 类的表示的单个操作不会返回一个值,通常以异步方式执行. Task 对象是一种的中心思想 基于任务的异步编程模式 首次引入.NET Framework 4 中. 因为由 ...
- Activity学习(一)——状态转变
(转自:http://blog.csdn.net/flowingflying/article/details/6415323) Android很大的应用场景是手机,有一些应用具有特别的优先级别,例如电 ...
- Airflow使用入门指南
Airflow能做什么 关注公众号, 查看更多 http://mp.weixin.qq.com/s/xPjXMc_6ssHt16J07BC7jA Airflow是一个工作流分配管理系统,通过有向非循环 ...
- windows上使用VsCode开发C/C++
使用VsCode+makefile开发C/C++ 1. 介绍 vscode作为现在越来越受欢迎的编辑器之一,因为可以使用插件让vscode支持几乎市面上所有的编程语言,由于笔者主要接触的是 C/C++ ...
- 入门大数据---Flink核心概念综述
一.Flink 简介 Apache Flink 诞生于柏林工业大学的一个研究性项目,原名 StratoSphere .2014 年,由 StratoSphere 项目孵化出 Flink,并于同年捐赠 ...
- 彻底搞懂C#异步编程 async和await的原理
1.前提 熟练掌握Task并行编程. 2.用Task并行解释async和await异步 因为控制台有多线程操作的优化,因此这里选择winform来做示例. 测试代码如下所示: 有三个textbox,一 ...
- [NIO]用dawn发送接收HTTP请求
HTTP协议的下层使用的是tcp.所以我们建立一个tcp连接就能发送接收http请求.dawn底层使用了nio.可是经过dawn的封装之后,我们在编写代码的时候,就和使用普通的堵塞式socket一样 ...
随机推荐
- unity3d Pathfinding插件使用
Overview The central script of the A* Pathfinding Project is the script 'astarpath.cs', it acts as a ...
- DNS递归查询和迭代查询的差别
转载地址:http://blog.csdn.net/wuchuanpingstone/article/details/6720723 递归查询和迭代查询的差别 (1)递归查询 递归查询是一种DNS s ...
- ubuntu16.04安装配置mysql数据库,分割视频为帧图像
参考http://wiki.ubuntu.org.cn/MySQL%E5%AE%89%E8%A3%85%E6%8C%87%E5%8D%97 版本为5.7 一.安装 安装命令sudo apt-get i ...
- Linux中文件上传使用rz
1.首先,要是服务器不支持rz命令的话,需要安装执行 sudo yum -y install lrzsz 2.再输入rz -be命令,选择需要上传的本地文件 sudo rz 从服务端发送文件到客户端: ...
- BZOJ 4358 坑 莫队+线段树 死T
这是一个坑 竟然卡nsqrt(n)logn T死 等更 //By SiriusRen #include <cmath> #include <cstdio> #include & ...
- ffmpeg x264编译与使用介绍
问题1:我用的是最新版本的ffmpeg和x264,刚刚编译出来,编译没有问题,但是在linux 环境使用ffmpeg的库时发现报错error C3861: 'UINT64_C': identifier ...
- Java基础——StringBuffer和StringBuilder
本节讲述2个字符串容器的区别 StringBuffer和StringBuilder区别: 1.相同点 两者都是容器(可变的字符序列),都可以对字符串进行基本的“增删改查”操作. 2.不同点 Strin ...
- 浅谈SpringCloud (二) Eureka服务发现组件
上面学习到了如何由一个程序访问另一个程序,那么如果使用SpringCloud来进行访问,该如何访问呐? 可以借助Eureka服务发现组件进行访问. 可以借助官方文档:https://spring.io ...
- Django开发之路 一(django安装并测试运行)
安装Django与测试 1.虚拟环境的安装 一般来说Django的开发最好是在虚拟环境上进行,这样的好处是可以将不同的Django的项目的环境分割开来,相互不影响.比如说项目一用到Python2.x和 ...
- 在应用层通过spring特性解决数据库读写分离
如何配置mysql数据库的主从? 单机配置mysql主从:http://my.oschina.net/god/blog/496 常见的解决数据库读写分离有两种方案 1.应用层 http://neore ...