1.守护线程是为了守护用户线程而存在的,当用户线程结束后,守护线程就没必要存在了。
2.线程休眠的两种方式:
①sleep: Thread.sleep( xxx秒 );
②TimeUnit.DAYS.sleep(数字);
3.线程的六种状态:
①NEW:新建,还未启动
②RUNNABLE:运行状态(可细化为运行和就绪两种,区别于是否得到时间片)
③BLOCKED:阻塞状态,遇到锁了
④WAITING:无限等待状态
⑤TIME_WAITING:有时间限制的等待
⑥TERMINATED:销毁状态,线程执行完毕。
线程安全的主要原因:
1.抢占式执行
2.多个线程同时修改了同一个变量
3.操作是非原子性的操作
4.内存可见性问题
5.指令重排序
其中使用 volatile 可以解决 内存可见性 和 指令重排序问题,但不能解决原子性问题;
使用锁 是解决线程安全的最主要的方法:
1.内置锁 :synchronized
2.可重入锁:Lock(TrrntantLock)
对于同一个业务的多个线程来说,使用synchronized 进行加锁时,要使用同一个对象
synchronized修饰 静态代码块时,用静态类(XXX.class)来修饰锁
修饰普通代码时,可以使用this来修饰
特性:
a.互斥性:只能进入一个线程
b.刷新内存:解决内存不可见
c.可重入:锁中可以再来一个锁
面试题:synchronized是如何实现的??
从JVM层面来看,synchronized是依靠 监视器Monitor 实现的
从操作系统层面来看,synchronized是基于操作系统的 互斥锁(Mutex)实现的