thread01.start();
thread02.start();
}
}
class Yield implements Runnable {
@Override
public void run() {
for (int i = 1; i <= 100; i++) {
System.ou.println(String.format(“%s:当前是第%s次循环”, Thread.currentThread().getName(), i));
if(i % 10 == 0) {
System.out.println(String.format(“%s:让步”, Thread.currentThread.getName()));
Thread.yield();
}
}
}
}
运行结果:
thread02:当前是第1次循环
thread01:当前是第1次循环
thread02:当前是第2次循环
.
.
thread02:让步
thread02:当前是第10次循环
thread02:当前是第11次循环
thread02:当前是第12次循环
.
.
thread01:让步
thread01:当前是第10次循环
thread01:当前是第11次循环
thread01:当前是第12次循环
由于thread01和thread02不属于相同优先级的线程,所以不能获得让步以后的CPU时间片。
三、线程中断
线程中断涉及到三个方法,分别是:interrupt(中断线程) 、**[interrupted]( )(**测试当前线程是否已经中断**)、[isInterrupted]( )(** 测试线程是否已经中断**)。**
interrupt()方法用于中断线程,通常的理解来看,只要某个线程启动后,调用了该方法,则该线程不能继续执行了,来看个小例子:
public class InterruptTest {
public static void main(String[] args) throws InterruptedException {
MyThread t = new MyThread(“MyThread”);
t.start();
Thread.sleep(100);// 睡眠100毫秒
t.interrupt();// 中断t线程
}
}
class MyThread extends Thread {
int i = 0;
public MyThread(String name) {
super(name);
}
public void run() {
while(true) {// 死循环,等待被中断
System.out.println(getName() + getId() + “执行了” + ++i + “次”);
}
}
}
运行后,我们发现,线程t一直在执行,没有被中断,原来interrupt()是骗人的,汗!其实interrupt()方法并不是中断线程的执行,而是为调用该方法的线程对象打上一个标记,设置其中断状态为true,通过isInterrupted()方法可以得到这个线程状态,我们将上面的程序做一个小改动:
public class InterruptTest {
public static void main(String[] args) throws InterruptedException {
MyThread t = new MyThread(“MyThread”);
t.start();
Thread.sleep(100);// 睡眠100毫秒
t.interrupt();// 中断t线程
}
}
class MyThread extends Thread {
int i = 0;
public MyThread(String name) {
super(name);
}
public void run() {
while(!isInterrupted()) {// 当前线程没有被中断,则执行
System.out.println(getName() + getId() + “执行了” + ++i + “次”);
}
}
}
这样的话,线程被顺利的中断执行了。很多人实现一个线程类时,都会再加一个flag标记,以便控制线程停止执行,其实完全没必要,通过线程自身的中断状态,就可以完美实现该功能。如果线程在调用 Object 类的 wait()、wait(long) 或 wait(long, int) 方法,或者该类的 join()、join(long)、join(long, int)、sleep(long) 或 sleep(long, int) 方法过程中受阻,则其中断状态将被清除,它还将收到一个 InterruptedException。 我们可以捕获该异常,并且做一些处理。另外,Thread.interrupted()方法是一个静态方法,它是判断当前线程的中断状态,需要注意的是,线程的中断状态会由该方法清除。换句话说,如果连续两次调用该方法,则第二次调用将返回 false(在第一次调用已清除了其中断状态之后,且第二次调用检验完中断状态前,当前线程再次中断的情况除外)。
四、线程合并
线程合并是优先执行调用该方法的线程,再执行当前线程,来看一个小例子:
public class JoinTest {
public static void main(String[] args) throws InterruptedException {
JoinThread t1 = new JoinThread(“t1”);
JoinThread t2 = new JoinThread(“t2”);
t1.start();
t2.start();
t1.join();
t2.join();
System.out.println(“主线程开始执行!”);
}
}
class JoinThread extends Thread {
public JoinThread(String name) {
super(name);
}
public void run() {
for(int i = 1; i <= 10; i++) {
System.out.println(getName() + “执行了” + i + “次”);
}
}
}
运行结果:
t11执行了1次
t11执行了2次
t11执行了3次
.
.
t11执行了10次
t12执行了1次
t12执行了2次
.
.
t12执行了10次
五、线程优先级
线程最低优先级为1,普通优先级是5,最高优先级为10,Thread类中提供了优先级的三个常量。
代码如下:
/**
-
@Description:线程睡眠、唤醒、让步、合并
-
@Author:zhangzhixaing
-
@CreateDate:2018/12/23 14:23:56
-
@Version:1.0
*/
public class ThreadTest {
public static void main(String[] args) {
Thread thread01 = new Thread(() -> {}, “thread01”);
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。


既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
总结
总的来说,面试是有套路的,一面基础,二面架构,三面个人。
最后,小编这里收集整理了一些资料,其中包括面试题(含答案)、书籍、视频等。希望也能帮助想进大厂的朋友


《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门即可获取!
254671a72faed303032d36.jpg" alt=“img” style=“zoom: 33%;” />
总结
总的来说,面试是有套路的,一面基础,二面架构,三面个人。
最后,小编这里收集整理了一些资料,其中包括面试题(含答案)、书籍、视频等。希望也能帮助想进大厂的朋友
[外链图片转存中…(img-5AbPKMVO-1712435662622)]
[外链图片转存中…(img-jRmaAT5B-1712435662623)]
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门即可获取!
文章详细介绍了Java中的多线程概念,包括线程的启动、yield让步操作、线程中断机制(interrupt()方法的作用和使用场景)、线程合并(join()方法),以及线程优先级的设定。作者通过示例展示了如何在实际编程中运用这些特性。
801

被折叠的 条评论
为什么被折叠?



