java多线程中同步的问题?

本文探讨了多线程环境下资源竞争导致的数据安全问题,通过使用synchronized关键字实现代码块锁定,确保了数据操作的原子性和一致性,避免了竞态条件的发生。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、通过模拟网络延迟,解决同步的问题、

package com.zxf.demo;

public class G01 implements Runnable{

    private int num=10;
    private int count=0;
    @Override
    public void run() {
        // TODO Auto-generated method stub
        while (true) {
        
            count++;
            num--;
            System.out.println(Thread.currentThread().getName()+"买到了第"+count+"条裤子,还剩"+num+"条裤子");
        
            
            //模拟网络延迟  让进程睡眠一会 1秒
            try {
                Thread.sleep(300);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            
            if (num<=0) {
                break;
            }
            
            
        }
    
    }
    public static void main(String[] args) {
        G01 g1 = new G01();
        
        Thread t1 = new Thread(g1,"卢本伟");
        Thread t2 = new Thread(g1,"马飞飞");
        Thread t3 = new Thread(g1,"大司马");
        Thread t4 = new Thread(g1,"骚男");
        
        t1.start();
        t2.start();
        t3.start();
        t4.start();
        
    }
    
    

}

这样写是有问题的  多个进程轮番执行,不能保证每个人买到的东西的唯一性

 

 

解决方式?

 1.把可能产生的数据安全问题的代码 锁起来, 被锁定的代码就变成单线程的!

 

package com.zxf.demo;

public class G01 implements Runnable{

    private int num=10;
    private int count=0;
    @Override
    public void run() {
        // TODO Auto-generated method stub
        while (true) {
            
            // 通过synchronized (this){}  将会出问题的部分 锁在这里  ,这里就变了单线程模式 就不会出错!
            synchronized (this) {
                if (num<=0) {
                    break;
                }    
                count++;
                num--;
                System.out.println(Thread.currentThread().getName()+"买到了第"+count+"条裤子,还剩"+num+"条裤子");
            }
            
        
            
            //模拟网络延迟  让进程睡眠一会 1秒
            try {
                Thread.sleep(300);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            
            
            
            
        }
    
    }
    public static void main(String[] args) {
        G01 g1 = new G01();
        
        Thread t1 = new Thread(g1,"卢本伟");
        Thread t2 = new Thread(g1,"马飞飞");
        Thread t3 = new Thread(g1,"大司马");
        Thread t4 = new Thread(g1,"骚男");
        
        t1.start();
        t2.start();
        t3.start();
        t4.start();
        
    }
    
    

}

 

2.同步方法  就是在方法的返回值类型前边加上 synchronize将该方法内部的代码  全部锁起来

 

package com.zxf.demo;

public class G01 implements Runnable{

    private int num=10;
    private int count=0;
    @Override
    public void run() {
        // TODO Auto-generated method stub
        while (true) {
            
            if (!buy()) {  // 调用buy的方法    不满足结果  结束循环
                break;
            }
    
            //模拟网络延迟  让进程睡眠一会 1秒
            try {
                Thread.sleep(300);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        
        }
    
    }
    //同步方法 定义一个方法  需要在方法的返回值类型 前边加上 synchronized 关键字。 
    public synchronized boolean buy() {
        
        if (num<=0) {
            return false;
        }
        num--;
        count++;
        System.out.println(Thread.currentThread().getName()+"买到了第"+count+"条裤子,还剩"+num+"条裤子");

        return true;
        
    }
    
    
    public static void main(String[] args) {
        G01 g1 = new G01();
        
        Thread t1 = new Thread(g1,"卢本伟");
        Thread t2 = new Thread(g1,"马飞飞");
        Thread t3 = new Thread(g1,"大司马");
        Thread t4 = new Thread(g1,"骚男");
        
        t1.start();
        t2.start();
        t3.start();
        t4.start();
        
    }
    
    

}

 

转载于:https://www.cnblogs.com/ZXF6/p/11122734.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值