脏读

简介: 对于对象的同步和异步的方法,我们在设计自己程序的时候,一定要考虑问题的整体性,不然就会出现数据不一致的错误,脏读。看代码/** * 业务整体需要使用完整的synchronized,保持业务的原子性。

对于对象的同步和异步的方法,我们在设计自己程序的时候,一定要考虑问题的整体性,不然就会出现数据不一致的错误,脏读。

看代码

/**
 * 业务整体需要使用完整的synchronized,保持业务的原子性。
 */
public class DirtyRead {

    private String username = "helei";
    private String password = "123";
    
    public synchronized void setValue(String username, String password){
    //传两个参数,对成员变量修改
        this.username = username;
        
        try {
            Thread.sleep(2000);//先对用户名进行了一个设置,2秒钟以后,又对密码进行设置一次
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        
        this.password = password;
        
        System.out.println("setValue最终结果:username = " + username + " , password = " + password);
    }
    
    public void getValue(){
        System.out.println("getValue方法得到:username = " + this.username + " , password = " + this.password);
    }
    
    
    public static void main(String[] args) throws Exception{
        
        final DirtyRead dr = new DirtyRead();//实例化一个对象,启动一个t1线程,
        Thread t1 = new Thread(new Runnable() {
            @Override
            public void run() {
                dr.setValue("helei", "456");        
            }
        });
        t1.start();
        Thread.sleep(1000);
        
        dr.getValue();
    }
}

打印结果如下

那好我们分析下

主要有两个纵向线程,首先是一个主线程main,还有一个t1线程,t1执run方法,等待两秒钟

如果打印是 helei 123的话,代码中的逻辑刚执行一半,我不希望有其他线程进来,那么我们应该考虑问题的时候考虑问题的整体性, 也就是在setValue不允许getValue执行,就把两个方法上都加上synchronized

总结:在我们对一个对象的方法加锁的时候,需要考虑业务的整体性,即为setValuegetValue同时加锁synchronized同步关键字,保证业务的原子性,不然会出现业务错误。(也从侧面保证业务的一致性)

关系型数据库的四个特性

  • A原子性
  • C一致性


  • I隔离性
  • D永久性
相关文章
|
1月前
|
数据库
脏读、幻读、不可重复读的定义?
脏读、不可重复读和幻读是数据库事务处理中的三种异常现象。脏读指读取未提交的修改数据;不可重复读指同一事务中多次读取数据不一致;幻读指读取记录范围时,前后读取结果数量不一致。这些现象通常由并发事务操作引起。
47 7
|
3月前
|
数据库
脏读,幻读,不可重复读
脏读,幻读,不可重复读
112 2
|
3月前
|
运维 监控 数据库
脏读的问题是什么
【10月更文挑战第17天】脏读的问题是什么
|
存储 关系型数据库 MySQL
幻读的探讨
幻读是数据库中常见的一种问题,它指的是在一个事务中,由于并发操作而导致同一个查询多次读取的结果不一致的现象。在这篇博客文中,我将详细探讨幻读的概念、原因和解决办法。
102 0
|
8月前
|
SQL 关系型数据库 MySQL
对数据库事务理解以及脏读、不可重复读以及幻读问题
对数据库事务理解以及脏读、不可重复读以及幻读问题
|
8月前
|
SQL 数据库
|
8月前
|
存储 SQL 关系型数据库
不可重复读
不可重复读
|
数据库
脏读、幻读、不可重复读
脏读是指在数据库事务中,一个事务读取了另一个事务未提交的数据。当一个事务进行数据修改但还未提交时,另一个事务读取了这个未提交的数据。如果发生了回滚操作,读取到的数据将是无效的。脏读可能会导致数据的不一致性和错误的结果。
80 0
|
数据库
数据库事务的并发问题 (脏读、幻读、不可重复读)
数据库事务的并发问题 (脏读、幻读、不可重复读)
149 0
|
SQL 关系型数据库 MySQL
MySQL 事务隔离级别以及脏读,不可重复读,幻读
MySQL 事务隔离级别以及脏读,不可重复读,幻读
128 0