没写完就读产生脏读(写操作加锁读操作不加锁产生脏读)synchronized-多线程与高并发

本文通过模拟银行账户操作,探讨了在多线程环境下,未对读方法加锁可能导致的脏读问题。当写操作加锁但读操作不加锁时,读取到的数据可能是写操作的中间状态。解决方法是对读方法同样使用synchronized关键字,确保读写互斥,从而防止脏读。
摘要由CSDN通过智能技术生成

 

 

模拟银行账户, 对业务写方法加锁, 对业务读方法不加锁,这样有什么后果?

因为这种情况不能保证写操作完成后再进行读操作,没写完就读容易读到不准确的中间态数据,即产生脏读。

/**
 * 模拟银行账户
 * 对业务写方法加锁
 * 对业务读方法不加锁
 * 这样行不行?
 *
 * 容易产生脏读问题(dirtyRead)
 */

package main.java.basic._synchronized;

import java.util.concurrent.TimeUnit;

public class Account {
	String name;
	double balance;
	
	public synchronized void set(String name, double balance) {
		this.name = name;

		try {
			Thread.sleep(2000);
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
		System.out.println("sleep 2000 end");
		
		this.balance = balance;
	}
	
	public /*synchronized*/ double getBalance(String name) {
		return this.balance;
	}
	
	
	public static void main(String[] args) {
		Account a = new Account();
		new Thread(()->a.set("zhangsan", 100.0)).start();

		//保证上面线程能够初始化完成并执行
		try {
			TimeUnit.SECONDS.sleep(1);
		} catch (In
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值