java任务缓存池,和消费过程
2012-05-11 19:23
246 查看
package queue;
import java.util.Queue;
import java.util.Timer;
import java.util.TimerTask;
import java.util.concurrent.ConcurrentLinkedQueue;
public class test {
private Queue<String> queue = new ConcurrentLinkedQueue<String>();
public static void main(String[] args) throws Exception {
test t = new test();
for(int i=0;i<100;i++){
t.insert("insert"+i);
}
t.ini();
}
public void ini() {
Timer timer = new Timer();
// sleep 1min, internal 1hour
timer.schedule(new TimerDo(), 1 * 1000L, 5 * 1000L); // 一秒后开始 没5秒执行一次
// run中的内容
}
public boolean insert(String str) throws Exception {
System.out.println(str);
queue.offer(str);
if (queue.size() > 20000) {
// do some thing
}
return true;
}
public class TimerDo extends TimerTask {
@Override
public void run() {
try {
String str = null;
while (true) {
if (queue.isEmpty()) {
try {
Thread.sleep(1000L);
} catch (InterruptedException e) {
e.printStackTrace();
}
} else {
str = queue.poll();
System.out.println("cosume=" + str);
}
}
} catch (Exception e) {
// do some thing
}
}
}
}
import java.util.Queue;
import java.util.Timer;
import java.util.TimerTask;
import java.util.concurrent.ConcurrentLinkedQueue;
public class test {
private Queue<String> queue = new ConcurrentLinkedQueue<String>();
public static void main(String[] args) throws Exception {
test t = new test();
for(int i=0;i<100;i++){
t.insert("insert"+i);
}
t.ini();
}
public void ini() {
Timer timer = new Timer();
// sleep 1min, internal 1hour
timer.schedule(new TimerDo(), 1 * 1000L, 5 * 1000L); // 一秒后开始 没5秒执行一次
// run中的内容
}
public boolean insert(String str) throws Exception {
System.out.println(str);
queue.offer(str);
if (queue.size() > 20000) {
// do some thing
}
return true;
}
public class TimerDo extends TimerTask {
@Override
public void run() {
try {
String str = null;
while (true) {
if (queue.isEmpty()) {
try {
Thread.sleep(1000L);
} catch (InterruptedException e) {
e.printStackTrace();
}
} else {
str = queue.poll();
System.out.println("cosume=" + str);
}
}
} catch (Exception e) {
// do some thing
}
}
}
}
相关文章推荐
- Hadoop运行mapreduce任务过程中报错:Error: Java heap space问题解决
- Java实时多任务调度过程中的安全监控设计
- Java实时多任务调度过程中的安全监控设计
- Java实时多任务调度过程中的安全监控设计
- Java实时多任务调度过程中的安全监控设计
- Java实时多任务调度过程中的安全监控设计
- Thinking in Java学习笔记 吐司的制作和消费过程
- java并发编程--Executor框架(一) 摘要: Eexecutor作为灵活且强大的异步执行框架,其支持多种不同类型的任务执行策略,提供了一种标准的方法将任务的提交过程和执行过程
- Java Executor并发框架(六)Executor框架线程池任务执行全过程(上)
- Java实时多任务调度过程中的安全监控设计
- Java实时多任务调度过程中的安全监控设计
- Java实时多任务调度过程中的安全监控设计
- Java实时多任务调度过程中的安全监控设计
- java 任务调度过程中的监控
- Java Executor并发框架(七)Executor框架线程池任务执行全过程(下)
- java 定时任务调用servlet
- Java 定时执行任务
- Dalvik虚拟机Java堆创建过程分析
- Java并发编程高级篇(六):在执行器中延时执行任务
- Java代码编译过程简述