`

并发变成学习三(对象的共享)

 
阅读更多

1.可见性:为了确保多个线程之间的内存写入操作的可见性,必须使用同步机制。在没有使用同步的情况下,编译器,处理器以及运行时等都有可能对操作的执行顺序进行一些意想不到的调整。

2.加锁可见性: a,内置锁可以用于确保某个线程以一种可预见的方式来查看另外一个线程的执行结果。
      b,java语言提供了一种稍弱的同步机制,即volatile变量,用来确保将变量的更新操作通知到其他线程,当把变量声明为volatile类型后,编译器与运行时都会注意到这个变量是共享的,因此不会将该变量上的操作与其他内存操作一起重排序。

3,线程封闭:当访问共享的可变数据时,通常需要使用同步,一种避免使用同步的方式就是不共享数据。如果仅在单线程内访问数据,就不需要使用同步,这种技术称为线程封闭。

ThreadLocal: ThreadLocal对象通常用于防止对可变的单实例变量(Singleleton)或全局变量进行共享。

4.不可变对象一定是线程安全的。不可变性并不等于将对象中的所有的域都申明为final类型,这个对象仍然是可变的。因为在final类型的域中可保存对可变对象的引用。

5.当满足以下条件时,对象才是不可变的:
    对象创建以后其状态就不能改变
    对象的所有域都是final类型
    对象是正确创建的(在对象创建期间,this引用没有逸出)

6.任何线程都可以在不需要额外同步的情况下安全的访问不可变对象,即使在发布这些对象时没有使用同步。

7.安全发布的常用模式:可变对象必须通过安全的方式发布,这通常都意味着在发布和使用该对象的线程时都必须使用同步。
要安全的发布一个对象,对象的引用以及对象的状态必须同时对其他线程可见,一个正确构造的对象可以通过以下方式来安全发布。
   a,在静态初始化函数中初始化一个对象引用
   b,将对象的引用保存在volatile类型或者AtomicReferance对象中
   c,将对象的引用保存到某个正确构造对象的final类型域中
   d,将对象的引用保存到一个由锁保护的域中
常用的线程安全集合:HashTable,SynchronizedMap,ConcurrentMap,Vector,CopyONWriteArrayList,CopyOnWriteArrayList,SynchronizedList,SynchronizedSet,BlockingQueue,ConcurrentLinkedQueue
将某个元素加入到这些集合中,则可以将该元素安全发布到任何访问这些元素的线程中。

8.通常要发布一个静态构造的对象,最简和最安全的方式是使用静态的初始化器。
eg:public static Holder holder = new  Holder(42);
静态初始化器由JVM在类的初始化阶段执行,由于在JVM内部存在着同步机制,因此通过这种方式初始化的任何对象都可以安全发布。











分享到:
评论

相关推荐

    java中的并发变成学习笔记1

    Java并发编程是Java开发中的一项重要技术,尤其在构建高性能、高并发的系统时不可或缺。在Java中,多线程编程允许程序同时执行多个任务,从而提高效率和响应性。然而,多线程环境下,线程安全问题成为了一个挑战。 ...

    Java并发编程(学习笔记).xmind

    正确协同多个对象中的共享状态 正确协同远程对象本身状态的访问 Swing和AWT 事件处理器与访问共享状态的其他代码都要采取线程安全的方式实现 框架通过在框架线程中调用应用程序代码将并发性引入...

    Java并发编程与高并发解决方案笔记-基础篇.docx

    Java并发编程与高并发解决方案是开发高性能应用的关键技术。在基础篇中,主要涉及以下几个重要知识点: 1. **并发编程基础** - **并发**:并发是指在一个时间段内,多个线程交替执行,使得系统看起来像是同时处理...

    Java并发编程与高并发解决方案-学习笔记

    ### Java并发编程与高并发解决方案知识点总结 #### 一、并发与高并发基本概念 ##### 1.1 并发 - **定义**: 指一个程序在同一时刻拥有两个或更多的线程,这些线程可以在单核或多核处理器上运行。 - **单核处理器上...

    java并发之并发工具类

    Java 并发工具类详解 Java 并发工具类是 Java 并发编程中的一种重要工具,用于协调线程之间的并发执行。 Java 并发工具类中有很多种,今天我们主要介绍四种:CyclicBarrier、CountDownLatch、Semaphore 和 ...

    java oracle并发官方教程

    总结来说,Java的并发编程涉及进程和线程的概念、线程的创建和管理、线程同步机制、活跃度问题的解决方法、不可变对象的使用以及高级并发工具的应用等多个方面。掌握这些知识点对于编写高性能和高可用性的Java程序至...

    java并发编程实践

    通过上述内容的学习,我们不仅掌握了Java并发编程的基本理论知识,还了解了如何在实际项目中应用这些技术来提升系统的并发处理能力。希望这些知识点能够帮助大家更好地理解和掌握Java并发编程的核心概念和技术要点。

    技术分享-JAVA并发库解读

    ### 技术分享-JAVA并发库解读 #### 重要概念:重排序 在现代计算机系统中,为了提高程序执行效率,编译器和处理器通常会对指令进行重新排序(简称“重排序”)。这一过程主要是基于两个目的:一是利用指令级并行...

    并发控制课后答案-简述并发控制.doc

    4. **封锁**:封锁是并发控制中最基本的方法,分为两种类型:排它锁(X锁)和共享锁(S锁)。X锁允许事务独占数据对象,进行读写操作,而S锁仅允许事务读取数据,不允许写入。事务在操作前需先申请相应的锁,并在...

    如何使用事件对象同步进程

    - 在并发编程中,事件对象可以作为生产者-消费者模型、读者-写者问题或其他并发设计模式的解决方案。 7. **注意事项** - 避免死锁:正确使用事件对象,确保所有进程都能最终获得执行机会。 - 错误处理:检查`...

    并发编程.txt

    #### 三、Java并发工具类 ##### 3.1 锁 - **synchronized**:Java中内置的关键字,用来实现互斥锁。它可以作用于方法或者代码块。 - **ReentrantLock**:显式锁,需要手动加锁和解锁,提供了比synchronized更...

    并发控制-生产者-消费者问题实验报告

    互斥对象初始状态为“未标记”,当被一个线程占有后变为“已标记”,此时其他线程无法访问该资源。 - **释放互斥对象**:通过`ReleaseMutex(hMutex);`函数来释放互斥对象,使其重新变回“未标记”状态,以便其他...

    探究在C++程序并发时保护共享数据的问题

    【C++并发编程中的共享数据保护】 在C++编程中,多线程环境下的并发执行可能导致数据不一致性问题,尤其是在处理共享数据时。共享数据是指多个线程都可以访问和修改的变量或对象。在上述例子中,我们创建了一个简单...

    多线程同步.(同步对象的用法)doc

    总结来说,多线程同步是通过各种内核对象和同步原语来实现的,它们提供了在并发环境中保护共享资源的机制。不同的同步方法适用于不同的情景,开发者需要根据实际需求选择合适的方法,以保证程序的正确性和性能。在...

    B站河北王校长-并发编程-深度核心面试知识汇总.pdf

    并发编程深度核心面试知识汇总 ...* 调用共享对象的notify()方法后,会唤醒一个在该共享变量上调用wait系列方法后被挂起的线程。 * 被唤醒的线程不能马上从wait()方法返回,需要重新获取锁并继续执行。

    Java并发面试题整理(答案).docx

    (5)死亡状态(Dead):线程执行完了或者因异常结束,此时线程从运行状态转变为死亡状态,一旦线程死亡,就不会再变为其他状态,同时,线程对象也变为垃圾收集的对象。 8、Java 中的 volatile 关键字volatile 是 ...

    线程与内核对象的同步

    理解这些对象及其工作原理对于编写多线程应用程序至关重要,特别是在处理并发和资源共享时,能有效防止死锁和竞态条件的发生。 总之,线程与内核对象的同步是Windows编程中不可或缺的一部分,通过合理利用内核对象...

    Java并发系列之AbstractQueuedSynchronizer源码分析(共享模式)

    《Java并发系列之AbstractQueuedSynchronizer源码分析(共享模式)》 AbstractQueuedSynchronizer(AQS)是Java并发编程中一个重要的工具,它是Java并发包`java.util.concurrent.locks`中的核心抽象类,用于构建锁...

    Java 多线程与并发(2-26)Java 并发 - 线程基础.pdf

    Java多线程与并发是Java编程中至关重要的一个领域,特别是在构建高性能、高并发的应用时。线程基础是理解并发编程的关键,它涉及到线程的状态转换、创建与使用方式、同步与协作机制等方面。 线程有五种基本状态: 1...

    使用CEvent对象实现线程同步

    在多线程编程中,线程同步是一种关键的技术,它确保了多个线程在访问共享资源时能够有序、安全地进行。MFC(Microsoft Foundation Classes)库为C++程序员提供了丰富的线程同步机制,其中CEvent类是常用的一种。本文...

Global site tag (gtag.js) - Google Analytics