线程操作的相关方法
public final void join() 调用该方法的线程强制执行,其他线程处于阻塞状态,该线程执行完毕后其他线程再执行
public static void sleep(long millis) 使用当前执行的线程休眠millis秒,线程处于阻塞状态
(13条消息) Java中关于Thread.sleep()与 线程对象.sleep()的思考_YuanOo。的博客-CSDN博客
public static void yield() 当前正在执行的线程暂停一次,允许其他线程执行,不阻塞,线程进入就绪状态,如果没有其他等待执行的线程,这个时候当前线程就会马上恢复执行
public final void stop() 强迫线程停止执行,已过时。不推荐使用
注意:
在多线程的时候,可以实现唤醒和等待的过程,但是唤醒和等待操作不是thread,而是我们设置的共享对象和共享变量
解决方式:
1.同步代码块
synchronized(共享资源、共享对象、需要是Object的子类){ 具体实行的代码 }
2.同步方法
将核心的代码逻辑定义到这个方法,使用synchronized关键词进行修饰,此时不需要指定共享对象
死锁
同步可以保证资源共享操作的正确性,但是过多同步也会产生死锁
死锁一般情况下表示互相等待,是程序运行时出现的一种问题
线程的生产者与消费者
生产者不断生产,消费者不断取走生产者生产的产品
生产者生产产品放到一个区域(共享资源)中,之后消费者从此区域里取出产品