多线程中一些常用方法

sleep()

让调用它的线程暂停多长时间再执行该线程,由运行状态变为阻塞状态,可以调节每个线程什么时候执行,且不会释放资源。当调用Thread.sleep(long millis)睡眠方法时,就会使当前线程进入阻塞状态。milis参数指定了线程睡眠的时间,单位是毫秒。当时间结束之后,线程会重新进入就绪状态。注意,如果当前线程获得了一把同步锁,则sleep方法阻塞期间,是不会释放锁的。

join()

当线程调用另外一个线程的join方法时,当前线程就会进入阻塞状态。直到另外一个线程执行完毕,当前线程才会由阻塞状态转为就绪状态。

public class Test {
	public static void main(String[] args) {
		Thread t1 = new Thread("t1线程") {
			@Override
			public void run() {
				try {
					//t1线程睡眠1秒钟
					Thread.sleep(1000);
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
				System.out.println("t1线程结束");
			}
		};
		Thread t2 = new Thread("t2线程") {
			@Override
			public void run() {
				try {
					//t2线程调用t1.join方法
					//t2线程进入阻塞状态
					//t2线程要等到t1线程运行结束,才能恢复到RUNNABLE状态
					t1.join();
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
				System.out.println("t2线程结束");
			}
		};
		t1.start();
		t2.start();
		//让主线程休眠500毫秒,目的是为了给t1和t2点时间,让他们俩个线程进入状态
		try {
			Thread.sleep(500);
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
		System.out.println(t2.getState());
	}
}

//运行结果
//WAITING
//t1线程结束
//t2线程结束


yield()

Thread.yield 方法会使当前线程放弃CPU时间片,把执行机会让给相同或更高优先级的线程(yield英文意思就是屈服,放弃的意思嘛,可以理解为当前线程暂时屈服于别人了)。

注意,此时当前线程不会阻塞,只是进入了就绪状态,随时可以再次获得CPU时间片,从而进入运行状态。也就是说,其实yield方法,并不能保证,其它相同或更高优先级的线程一定会获得执行权,也有可能,再次被当前线程拿到执行权。

yield方法和sleep方法一样,也是不释放锁资源的。

yield一般用于不存在锁竞争的多线程环境中。如果当前线程执行的任务时间可能比较长,就可以选择用yield方法,暂时让出CPU执行权。让其它线程也有机会执行任务,而不至于让CPU资源一直消耗在当前线程。

wait()、notify()、notifyAll()

首先,它们都是Object类中的方法。需要配合 synchronized关键字来使用。

调用线程的wait方法会使当前线程等待,直到其它线程调用此对象的notify/notifyAll方法。如果,当前对象锁有N个线程在等待,则notify方法会随机唤醒其中一个线程,而notifyAll会唤醒对象锁中所有的线程。需要注意,唤醒时,不会立马释放锁,只有当前线程执行完之后,才会把锁释放。

另外,wait方法和sleep方法不同之处,在于sleep方法不会释放锁,而wait方法会释放锁。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 在Java,创建多线程有几种常用方法。其一种方法是继承Thread类并重写其run()方法。通过创建一个继承自Thread类的子类,并在子类重写run()方法来定义线程的执行逻辑。然后可以通过创建该子类的实例并调用start()方法来启动线程。例如,可以创建一个名为TestThread的类,继承自Thread类,并在其run()方法定义线程的执行逻辑。然后可以创建TestThread的实例,并调用start()方法来启动线程。\[1\] 另一种常用方法是实现Runnable接口。通过创建一个实现了Runnable接口的类,并实现其run()方法来定义线程的执行逻辑。然后可以创建该类的实例,并将其作为参数传递给Thread类的构造函数。最后,调用Thread类的start()方法来启动线程。例如,可以创建一个名为TestRunnable的类,实现了Runnable接口,并在其run()方法定义线程的执行逻辑。然后可以创建TestRunnable的实例,并将其作为参数传递给Thread类的构造函数,最后调用start()方法来启动线程。\[2\] 此外,还可以使用Lambda表达式来创建Runnable线程目标类。通过使用Lambda表达式,可以更简洁地定义线程的执行逻辑。例如,可以使用Lambda表达式创建一个匿名的Runnable实例,并在其定义线程的执行逻辑。然后可以将该实例作为参数传递给Thread类的构造函数,并调用start()方法来启动线程。\[3\]这种方法可以减少代码的冗余,并提高代码的可读性。 总结起来,Java常用多线程方法包括继承Thread类并重写run()方法、实现Runnable接口并实现run()方法,以及使用Lambda表达式创建Runnable线程目标类。这些方法都可以用来定义线程的执行逻辑,并通过调用start()方法来启动线程。 #### 引用[.reference_title] - *1* *2* [java实现多线程的三种方式](https://blog.csdn.net/Mao_yafeng/article/details/126089335)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Java多线程之四种方法创建线程](https://blog.csdn.net/liu320yj/article/details/125703535)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值