Java多线程中的延时队列DelayQueue

慢慢进入JAVA的内心世界,

今天也一直在和JAVA的语法作斗争,

到周三,写的一个基于SPRING BOOT的日志小模块,

成型啦~~


关于DelayQueue,书上是这样说的:

1fe7345ef71b1c557c63390ea5a11fda618586fb


Student.java


package demo.thread;

import java.util.concurrent.Delayed;
import java.util.concurrent.TimeUnit;

public class Student implements Delayed{
	
	private String name;
	private long workTime;
	private long submitTime;
	
	public String getName() {
		return this.name + "交卷,用时  " + workTime;
	}
	
	public Student(String name, long submitTime) {
		this.name = name;
		this.workTime = submitTime;
		this.submitTime = TimeUnit.NANOSECONDS.convert(submitTime, TimeUnit.MILLISECONDS ) 
				+ System.nanoTime();
		System.out.println(this.name + " 交卷, 用时 " + workTime);
	}

	@Override
	public int compareTo(Delayed o) {
		// TODO Auto-generated method stub
		Student that = (Student) o;
		return submitTime > that.submitTime? 1 :(submitTime < that.submitTime ? -1 :0);
	}

	@Override
	public long getDelay(TimeUnit unit) {
		// TODO Auto-generated method stub
		return unit.convert(submitTime - System.nanoTime(), unit.NANOSECONDS);
	}

}


ThreadMain.java


package demo.thread;

import java.util.concurrent.DelayQueue;

public class ThreadMain {

	public static void main(String[] args) throws Exception {
		final DelayQueue<Student> bq = new DelayQueue<Student>();
		for (int i = 0; i < 5; i++) {
			Student student = new Student("学生" + i, Math.round((Math.random()*10 + i)));
			bq.put(student);
		}
		System.out.println("bq.peek();" + bq.peek().getName());
	}
}


输出样子:

7b08cba3c8efb6918a3ff739998bc335ea12ab22

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值