netty HashedWheelTimer

本文介绍了一个基于环形结构的定时器HashWheelTimer的工作原理及其实现。它通过将时间划分为多个槽,每个槽代表一定的时间间隔,用以存放在这个时间间隔内需要执行的任务。适用于大量定时任务且对时间精度要求不高的场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一个Hash Wheel Timer是一个环形结构,可以想象成时钟,分为很多格子,一个格子代表一段时间(越短Timer精度越高),并用一个List保存在该格子上到期的所有任务,同时一个指针随着时间流逝一格一格转动,并执行对应List中所有到期的任务。
这个类一般用来处理大量的定时任务且任务对时间精度要求相对不高,  比如链接超时管理等场景, 缺点是,  内存占用相对较高.该类中有两个重要的参数
Tick Duration:即一个格子代表的时间,默认为100ms,因为IO事件不需要那么精确;

Ticks per Wheel (Wheel Size):一个Wheel含有多少个格子,默认为512个,如果任务较多可以增大这个参数.

package com.netty.demo001;

import java.util.concurrent.TimeUnit;

import org.jboss.netty.util.HashedWheelTimer;
import org.jboss.netty.util.Timeout;
import org.jboss.netty.util.TimerTask;

public class NettyTimerTask {
	//定义HashedWheelTimer对象
	//1000毫秒跳到下一个solt,一共有512个solt
	static HashedWheelTimer  timer=new HashedWheelTimer(5000L, TimeUnit.MILLISECONDS, 512);
	
	public static void main(String[] args) {
		TimerTask task=new  TimerTask() {
			@Override
			public void run(Timeout timeout) throws Exception {
				System.out.println("---run service-----");
				//任务执行完成后再把自己添加到任务solt上
				addTask(this);
			}
		};
		addTask(task);
	}
	
	public static void addTask(TimerTask task){
		//根据时长把task任务放到响应的solt上
		timer.newTimeout(task, 500, TimeUnit.MILLISECONDS);
	}
}


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值