线程
** *解决线程安全的第二种方法:使用同步方法
*使用步骤:
*1.把访问了共享数据代码块抽取出来,放到一个方法中
*1、在方法上添加synchronized修饰符
*/
**
*package Demo01;
public class RunnableImpl implements Runnable{
private int ticket=100;
//Object obj=new Object
@Override
public void run() {
while(true) {
payTicket();
}
}
public synchronized void payTicket() {
if(ticket>0) {
try {
Thread.sleep(10);
}catch(InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+"-->正在卖第"+ticket+"票");
ticket--;
}
}
}
package Demo01;
public class RunnableImpl implements Runnable{
private int ticket=100;
//Object obj=new Object
@Override
public void run() {
while(true) {
payTicket();
}
}
public synchronized void payTicket() {
if(ticket>0) {
try {
Thread.sleep(10);
}catch(InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+"-->正在卖第"+ticket+"票");
ticket--;
}
}
}
package Demo01;
public class Demo01Ticket {
public static void main(String[] args) {
RunnableImpl run =new RunnableImpl();
Thread t0=new Thread(run);
Thread t1=new Thread(run);
Thread t2=new Thread(run);
t0.start();
t1.start();
t2.start();
}
}
运行结果
package Demo02;
public class Demo01Ticket {
public static void main(String[] args) {
RunnableImpl run=new RunnableImpl();
Thread t0=new Thread(run);
Thread t1=new Thread(run);
Thread t2=new Thread(run);
t0.start();
t1.start();
t2.start();
}
}
package Demo02;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
public class RunnableImpl implements Runnable{
private int ticket=100;
//1.在成员位置创建了一个Reentrantlock对象
Lock l=new ReentrantLock();
@Override
public void run() {
while(true) {
//2.在可能会出现线程安全的地方,调用Lock借口中的lock方法,获取锁
lock();
if(ticket>0) {
try {
Thread.sleep(10);
}catch (InterruptedException e) {
e.printStackTrace();
System.out.println(Thread.currentThread().getName()+"-->正在卖第"+ticket+"张票");
ticket--;
}
}
}
//3.在可能出现线程安全问题的代码快调用过后,使用unlock释放锁
}
private void lock() {
// TODO 自动生成的方法存根
}
}
package Demo03;
/*
- 创建第一个顾客线程:告知老板要的包子种类,用wait()方法等待,放弃cup执行
- 创建一个老板线程:花5秒做一个包子,做好后,用notif通知顾客吃包子
*/
public class Demo03WatiAndNotify {
public static void main(String[] args) {
Object obj=new Object();
//创建第一个消费者
new Thread() {
@Override
public void run() {
while(true) {
synchronized(obj){
System.out.println("消费者1,告知老板包子要的种类");
try {
obj.wait();
}catch(InterruptedException e) {
e.printStackTrace();
}
System.out.println("消费者1,包子已经做好了,开吃");
System.out.println("=========");
}
}
}
}.start();
new Thread() {
@Override
public void run() {
while(true) {
synchronized(obj){
System.out.println("消费者2,告知老板包子要的种类");
try {
Thread.sleep(2000);
}catch(InterruptedException e) {
e.printStackTrace();
}
System.out.println("消费者2,包子已经做好了,开吃");
System.out.println("=========");
}
}
}
}.start();
}
}
![在这里插入图片描述](https://img-blog.csdnimg.cn/20210527124836657.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/20210527124847904.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L20wXzU1Njg5MzI5,size_16,color_FFFFFF,t_70)
![在这里插入图片描述](https://img-blog.csdnimg.cn/20210527124858329.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L20wXzU1Njg5MzI5,size_16,color_FFFFFF,t_70)