`

ReadWriterLock 和 synchronize 的区别

 
阅读更多

           对象的方法中一旦加入synchronized修饰,则任何时刻只能有一个线程访问synchronized修饰的方法。假设有个数据对象拥有写方法与读 方法,多线程环境中要想保证数据的安全,需对该对象的读写方法都要加入 synchronized同步块。这样任何线程在写入时,其它线程无法读取与改变 数据;如果有线程在读取时,其他线程也无法读取或写入。这种方式在写入操作远大于读操作时,问题不大,而当读取远远大于写入时,会造成性能瓶颈,因为此种 情况下读取操作是可以同时进行的,而加锁操作限制了数据的并发读取。  

         ReadWriteLock解决了这个问题,当写操作时,其他线程无法读取或写入数据,而当读操作时,其它线程无法写入数据,但却可以读取数据 。

package demo.readwritelock;

import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;

public class ReadWriteLockDemo  {
	
	static SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
	
	
	public static void main(String[] args) throws InterruptedException {
		Data data = new Data();
		
		Worker worker1 = new Worker(data, true);
		Worker worker2 = new Worker(data, false);
		worker1.start();
		worker2.start();
	}
	
	
	static class Worker extends Thread{
		Data data;
		boolean read;
		
	public Worker(Data data, boolean read){
		this.data = data;
		this.read = read;
	}
	
	public void run(){
		if(read){
			data.get();
		}
		else {
			data.set();
		}
	}
	
	}
	
	
	
	static class Data{
		ReadWriteLock lock = new ReentrantReadWriteLock();
		Lock read = lock.readLock();
		Lock write = lock.writeLock();
		
		public void set(){
			write.lock();
			System.out.println(Thread.currentThread().hashCode()+"set:begin"+sdf.format(new Date()));
			try{
				Thread.sleep(5000);
			}catch(Exception e){
				
			}finally{
				System.out.println(Thread.currentThread().hashCode()+"set:end"+sdf.format(new Date()));
				write.unlock();
			}
		}
		
		public int get(){
			read.lock();
			System.out.println(Thread.currentThread().hashCode()+"get:begin"+sdf.format(new Date()));
			try{
				Thread.sleep(5000);
			}catch(Exception e){
				
			}finally{
				System.out.println(Thread.currentThread().hashCode()+"get:end"+sdf.format(new Date()));
				read.unlock();
			}
			return 1;
		}
	}

}

 运行结果:

1043636732get:begin2016-01-26 10:26:42
1043636732get:end2016-01-26 10:26:47
1125883825set:begin2016-01-26 10:26:47
1125883825set:end2016-01-26 10:26:52

 上面是当读数据的时候,写数据是不被允许的。下面展示可以同时读取同一个对象的数据的情况实例:

public static void main(String[] args) {
		Data data = new Data();
		Worker worker1 = new Worker(data, true);
		Worker worker2 = new Worker(data, true);
		worker1.start();
		worker2.start();
	}

 运行结果如下:

1981440623set:begin2016-01-26 10:38:35
332711452set:begin2016-01-26 10:38:35
332711452set:end2016-01-26 10:38:40
1981440623set:end2016-01-26 10:38:40

 

 

 

 

分享到:
评论

相关推荐

    delphi vcl线程同步synchronize

    Synchronize方法是Delphi中用于在主线程和工作线程之间进行通信的关键工具,确保对用户界面(UI)的操作是安全的。本文将深入探讨Delphi VCL线程同步以及Synchronize方法的工作原理、使用场景和最佳实践。 ### 1. ...

    Synchronize It 3.5文件夹同步器 简体中文界面

    Synchronize It!还有其他特点如下: 1.可以自订许多的项目,包括过滤器、专案、颜色等等。 2.可以进行多种同步任务独立保存和点用,也可组合多个任务一次同步搞定。 3.支持压缩文件的同步。 4.内建二进位文件的比较...

    FTP_synchronize_0_9_6_1_dll

    这个文件很可能包含了关于如何选择和使用这两个DLL文件的说明,例如何时使用FTP_synchronize.dll,何时使用FTP_synchronizeA.dll,或者它们之间的差异。在实际操作前,你应该仔细阅读这个文本文件以了解正确的用法。...

    Synchronize和ReentrantLock区别.png

    Synchronize(同步锁)和ReentrantLock(可重入锁)都是Java中的常用锁,都是用来保证线程安全的。两者都是同步锁,且都是阻塞同步。阻塞同步:当一个线程获取锁后,其他线程只能等待(进入阻塞态),等待获取锁的...

    CALL RFC synchronize and asychronize Examples

    以下是关于"CALL RFC synchronize and asychronize Examples"的详细解释。 **同步调用 (Synchronize Call)** 同步调用是立即执行并等待结果返回的方式。在提供的示例`SAPBC415_RFCSYNC_S1`中,我们看到如何通过`...

    java synchronize 线程同步

    Java中的`synchronized`关键字是用于实现线程同步的关键机制,主要目的是解决多线程环境下的数据安全问题。当多个线程访问共享资源时,...正确理解和使用`synchronized`可以帮助我们编写出更加安全、可靠的多线程程序。

    Java synchronize线程安全测试

    Java中synchronize关键字的使用与线程安全测试 Java语言中,synchronize关键字是一个非常重要的概念,它主要用于解决线程...同时,需要遵循一定的规则和原则来使用synchronize关键字,以确保程序的正确性和可靠性。

    Java synchronize底层实现原理及优化

    在 JVM 中,synchronize 底层实现原理是通过 monitorenter 和 monitorexit 两个字节码指令来实现的。monitorenter 代表尝试获取对象的锁,如果成功获取到锁,锁的值将被加 1,否则线程将等待。如果线程重入,锁的值...

    vnc.rar_Computers_file synchronize

    simple configure file to synchronize the connection between two computers (using vnc)

    bcb6多线程计数器

    在实际开发中,除了Synchronize,还有其他同步原语,如临界区(CriticalSection)、互斥量(Mutex)和信号量(Semaphore)。这些工具可以帮助开发者控制对共享资源的访问,防止竞态条件的发生。临界区和互斥量适用于...

    synchronize底层实现原理

    synchronize底层实现原理 Java文件想要看字节码通常使用 javap 命令将java的class文件反汇编,具体操作步骤如下: 1. 先写好一个SynchronizedTest.java文件(下面贴出) 2. 在java文件的目录下,使用命令 javac ...

    Java之Synchronize学习

    Synchronize的几种实现 Synchronize有三种实现。 同步方法,修饰实例方法,作用于当前实例加锁,进入同步代码前要获得当前实例的锁 静态方法,作用于当前类对象加锁,进入同步代码前要获得当前类对象的锁 修饰代码块...

    4-Synchronize Robots_高清 720P.mp4

    4-Synchronize Robots_高清 720P.mp4

    synchronize.zip

    在IT行业中,尤其是在Java编程领域,`synchronize.zip`这个文件名可能暗示着一个与同步相关的项目或代码库。从提供的文件列表来看,我们可以推测这是一个关于处理店铺操作任务的系统,比如更新店铺任务...

    BCB多线程实例BCB多线程实例

    BCB的TThread::Synchronize方法可以在主线程上下文中安全地执行代码,确保与界面交互的正确性。 当线程不再需要时,记得正确地终止和释放资源。使用TThread的Terminate方法结束线程,然后等待线程完成(WaitFor方法...

    Synchronize Your System Time with a Network Time Protocol (N

    在描述中,“Synchronize Your System Time with a Network Time Protocol (NTP) Server”是关于如何使用NTP来更新和维护系统时间的实践。这通常涉及配置客户端软件,使其定期与NTP服务器通信,获取准确的时间戳,并...

    synchronize.pdf

    标题 "synchronize.pdf" 和描述 "synchronize详解" 显示该文档专注于Java编程语言中关键字 synchronized 的使用和机制。Synchronized 关键字是Java中用于控制多线程并发访问共享资源的一个核心关键字,确保同一时间...

    GTM_ATOM_PWM_DTM_Synchronize_KIT_TC364_TRB.zip

    综上所述,"GTM_ATOM_PWM_DTM_Synchronize_KIT_TC364_TRB.zip" 包含的资源可能包括示例代码、配置文件、用户手册等,旨在帮助开发者理解和实现GTM在TC364上的PWM和DTM同步功能。通过这个工具包,开发者能够更好地...

    Java对象锁和类锁全面解析(多线程synchronize

    Java对象锁和类锁是Java多线程编程中至关重要的概念,它们是通过`synchronized`关键字来实现的,用于确保代码在并发环境下的线程安全。在这个全面解析中,我们将深入探讨这两个锁机制,理解它们的工作原理以及如何在...

    Java 中synchronize函数的实例详解

    这有助于避免数据不一致性和竞态条件等问题。 在提供的代码示例中,`MySyn` 类有两个`synchronized`修饰的方法:`funcA` 和 `funcB`。这意味着在同一时间,只有一个线程能够执行这两个方法中的任意一个。如果两个...

Global site tag (gtag.js) - Google Analytics