JAVA:定时器的三种方法(详细注解)

第一种:

        创建一个thread,然后让它在while循环里一直运行着,通过sleep方法来达到定时任务的效果,代码如下:

public class Task1 {
	public static void main(String[] args) {
		// run in a second
		// 每一秒钟执行一次
		final long timeInterval = 1000;
		Runnable runnable = new Runnable() {
			public void run() {
				while (true) {
					// ------- code for task to run
					// ------- 要运行的任务代码
					System.out.println("Hello, stranger");
					// ------- ends here
					try {
						// sleep():同步延迟数据,并且会阻塞线程
						Thread.sleep(timeInterval);
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
				}
			}
		};
		//创建定时器
		Thread thread = new Thread(runnable);
		//开始执行
		thread.start();
	}
}

第二种:

        启动和去取消任务时可以控制,可以指定你想要的delay(开始执行的等待时间)时间,在实现时,Timer类可以调度任务,TimerTask则是通过在run()方法里实现具体任务。 Timer实例可以调度多任务,它是线程安全的。 当Timer的构造器被调用时,它创建了一个线程,这个线程可以用来调度任务。代码如下:

// 调用的工具
import java.util.Timer;
import java.util.TimerTask;

public class Task2 {
	public static void main(String[] args) {
		/**
		 * Timer:是一个定时器工具,用来执行指定任务
		 * TimerTask:是一个抽象类,他的子类可以代表一个被Timer计划的任务
		 */
		TimerTask task = new TimerTask() {
			@Override
			public void run() {
				// task to run goes here
				// 执行的输出的内容
				System.out.println("Hello, stranger");
			}
		};
		Timer timer = new Timer();
		// 定义开始等待时间  --- 等待 5 秒
		// 1000ms = 1s
		long delay = 5000;
		// 定义每次执行的间隔时间
		long intevalPeriod = 5 * 1000;
		// schedules the task to be run in an interval
		// 安排任务在一段时间内运行
		timer.scheduleAtFixedRate(task, delay, intevalPeriod);
	} // end of main
}

第三种:       

        相比于上两个方法,它有以下好处:
        1.相比于Timer的单线程,它是通过线程池的方式来执行任务的 
        2.可以很灵活的去设定第一次执行任务delay时间
        3.提供了良好的约定,以便设定执行的时间间隔

//调用的工具
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;

public class Task3 {
	public static void main(String[] args) {
		/**
		 * Runnable:实现了Runnable接口,jdk就知道这个类是一个线程  
		 */
		Runnable runnable = new Runnable() {
			//创建 run 方法
			public void run() {
				// task to run goes here
				System.out.println("Hello, stranger");
			}
		};
		// ScheduledExecutorService:是从Java SE5的java.util.concurrent里,
		// 做为并发工具类被引进的,这是最理想的定时任务实现方式。
		ScheduledExecutorService service = Executors
				.newSingleThreadScheduledExecutor();
		// 第二个参数为首次执行的延时时间,第三个参数为定时执行的间隔时间
		// 10:秒   5:秒
		// 第一次执行的时间为10秒,然后每隔五秒执行一次
		service.scheduleAtFixedRate(runnable, 10, 5, TimeUnit.SECONDS);
	}
}

因为本身自己也是小白,如果有错误的地方,请及时留言指正,谢谢   【一起学习,一起进步,加油!!】

  • 49
    点赞
  • 214
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 11
    评论
Java WebSocket API 提供了 javax.websocket.Session 接口,该接口定义了用于 WebSocket 会话的方法。在该接口中提供了一个用于定时器方法: ```java public Future<Void> setTimer(long milliseconds); ``` 可以通过该方法设置 WebSocket 会话的定时器,以便在指定的时间后执行某些操作。该方法返回一个 Future 对象,可以使用该对象来控制定时器的行为,例如取消定时器。 以下是一个简单的示例,演示如何在 Java WebSocket 中使用定时器: ```java import javax.websocket.*; import java.net.URI; import java.util.concurrent.Future; @ClientEndpoint public class WebSocketClient { private Session session; @OnOpen public void onOpen(Session session) { this.session = session; try { Future<Void> future = session.setTimer(5000); future.get(); // 阻塞当前线程,等待定时器执行完成 } catch (Exception e) { e.printStackTrace(); } } @OnMessage public void onMessage(String message) { System.out.println("Received message: " + message); } @OnError public void onError(Throwable t) { t.printStackTrace(); } public static void main(String[] args) { WebSocketContainer container = ContainerProvider.getWebSocketContainer(); try { container.connectToServer(WebSocketClient.class, URI.create("ws://localhost:8080")); } catch (Exception e) { e.printStackTrace(); } } } ``` 在上面的示例中,我们在 WebSocketClient 类中实现javax.websocket.ClientEndpoint 注解,这是 Java WebSocket API 的一部分,用于标识 WebSocket 客户端。 在 onOpen() 方法中,我们通过 session.setTimer() 方法设置了一个定时器定时器将在 5 秒后触发。在定时器执行完成后,我们可以在 onMessage() 方法中接收到服务端发送的消息。 需要注意的是,在使用 Future.get() 方法时,当前线程会被阻塞,直到定时器执行完成。如果不想阻塞当前线程,可以使用 CompletableFuture 的异步方式来处理定时器事件。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

平凡的人类

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值