停止
在java中,一个线程对象也有自己的生命周期,
有以下三个方法
- suspend()暂时挂起线程
- resume()方法,恢复挂起的线程
- stop()方法停止线程
但这三个方法并不推荐使用,从jdk.12之后就开始废除了,主要原因是这三个方法在操作时,会产生死锁的问题
如果想要实现线程的停止,应该是使用设置标志位的方式停止一个线程的运行.
public class Main {
public static boolean flag=true;
public static void main(String[] args) throws InterruptedException {
new Thread(()->{
long num=0;
while (flag){
try {
Thread.sleep(50);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+"正在运行,num="+num--);
}
},"执行线程").start();
Thread.sleep(200);//运行200毫秒
flag=false;//停止线程
}
}
以上程序的执行结果
执行线程正在运行,num=0
执行线程正在运行,num=-1
执行线程正在运行,num=-2
执行线程正在运行,num=-3
后台守护线程
1.Thread.setDaemon(boolean on):设置为守护线程或者用户线程。
2.通过Thread.setDaemon(false)设置为用户线程,用于为系统中的其它对象和线程提供服务;通过Thread.setDaemon(true)设置为守护线程,在没有用户线程可服务时会自动离开;如果不设置此属性,默认为用户线程。
3.setDaemon需要在start方法调用之前使用
4.用Thread.isDaemon()来返回是否是守护线程
5.如果jvm中都是守护进程,当前jvm将退出。
public class Main {
public static void main(String[] args) throws InterruptedException {
Thread userThread=new Thread(()->{
for (int x=0;x<1000;x++){
System.out.println(Thread.currentThread().getName()+"正在运行,x="+x);
}
},"用户线程");
Thread daemonThread=new Thread(()->{
for (int x=0;x<Integer.MAX_VALUE;x++){
System.out.println(Thread.currentThread().getName()+"正在运行,x="+x);
}
},"守护线程");
daemonThread.setDaemon(true);//设置为守护线程
userThread.start();
daemonThread.start();
}
}
在整个jvm中最大的守护线程就是gc(垃圾回收)线程
volatile
再多线程定义之中,volatile关键字主要是在属性定义上使用的,表示此属性为直接数据操作,而不进行副本的拷贝处理(并非同步属性)
在正常进行变量运算的处理的时候,旺旺会经理如下的几个步骤
- 获取变量原有的数据内容
- 为变量进行数学计算
- 将计算之后的变量,保存到原始空间之中
而如果属性伤追加了volatile关键字,表示的就是副使用副本,而是直接操作原始变量,相当于节约了:拷贝副本
,重新保存的步骤.
与synchronized区别
volatile主要在属性伤使用.而synchronized是在代码块与方法上使用的
volatile无法描述同步的处理,它只是一种直接内存的处理,避免了副本的操作,而synchronized是一种同步锁的机制