`

java并发详解

    博客分类:
  • java
阅读更多
线程安全
1.什么是并发?
2.什么是线程安全
3.如何保证线程安全

参考书籍《java并发编程》
此篇博客是回答我懵懂骚年时代的一下疑问,希望可以帮助大家解惑,共勉!!

1.什么是并发?
  我喜欢用并行,串行,并发做比较
  并行:完全独立在不同CPU上的程序执行,完全平行,没有任何交叉
  串行:在同一个CPU上执行的程序,一个个排队执行
  并发:在同一个CPU上“同时”执行的程序,这个同时是感官上,其实可以理解为有交叉的意思,程序之前存在资源抢占的情况,

2.并发不一定指的是线程,但是在java中的并发目前只有线程一种形式,在java并发的情况下,总也逃脱不了线程安全性的问题 ,那么什么是线程安全?怎么保证线程安全性?
线程安全的在《java Concurrency In Pracitce》中定义:当多线程访问一个对象时,如果不考虑这些线程在运行时环境下的调度和交替执行,也不需要进行额外的同步,或者在调用方进行任何其他的协调操作,调用这个对象的行为都可以获得正确的结果,那么这个对象是线程安全的

其实线程安全更多指的是正确性,在多线程下的结果的正确性

2:怎么保证线程的安全
基本所有的线程安全都是基于对共享数据安全性,如果能保证共享数据的安全或不涉及到共享数据基本既可以保证,具体操作分为如下几种:1,不可变变量 2,线程封闭 3.线程同步机制 4,原子操作
1.不可变变量,是指数据对象被final修饰,其内部的状态(外界可访问的属性)也是被final修饰,此种变量被构造后,不能被修改,因此不存在数据安全的问题,都是要防止此数据在构造完成前的“发布逸出”,既才对象还没有被构造完成,就可以被其他对象引用,在逸出引用的地方会出现未知问题
2.线程封闭,其实就是不共享数据的问题,保证数据不被共享,或保存在线程本身内部(threadLocal)
3.线程同步机制,共享变量的同步,添加互斥锁,保证多线程下串行访问
4,原子操作,JVM 认为最小粒度的操作,也不存在并发的问题,如果AtomicInteger,

大概就这么多吧,想到再做补充,
参考书籍《深入jvm虚拟机》,《java Concurrency In Pracitce》
分享到:
评论

相关推荐

    《java 并发编程实战高清PDF版》

    《Java并发编程实战》是一本深入探讨Java平台并发编程的权威指南。这本书旨在帮助开发者理解和掌握在Java环境中创建高效、可扩展且可靠的多线程应用程序的关键技术和实践。它涵盖了从基本概念到高级主题的广泛内容,...

    Java 并发核心编程

    #### 一、Java并发概述 自Java诞生之初,其设计者就赋予了该语言强大的并发处理能力。Java语言内置了对线程和锁的支持,这使得开发者能够轻松地编写多线程应用程序。本文旨在帮助Java开发者深入理解并发的核心概念...

    java并发编程实战(英文版)

    #### 一、Java并发特性详解 在《Java并发编程实战》这本书中,作者深入浅出地介绍了Java 5.0和Java 6中新增的并发特性。这些特性旨在帮助开发者更高效、安全地编写多线程程序。书中通过实例解释了诸如`...

    java并发工具包详解

    1. java.util.concurrent - Java 并发工具包 2. 阻塞队列 BlockingQueue 3. 数组阻塞队列 ArrayBlockingQueue 4. 延迟队列 DelayQueue 5. 链阻塞队列 LinkedBlockingQueue 6. 具有优先级的阻塞队列 ...

    13-Java并发编程学习宝典.zip

    Java并发编程是软件开发中的重要领域,特别是在大型系统和高并发场景中不可或缺。"13-Java并发编程学习宝典.zip" 包含了一系列关于Java并发编程的学习资源,旨在帮助开发者掌握多线程编程的核心技术和最佳实践。以下...

    Java系统的高并发解决方法详解

    Java系统的高并发解决方法详解 Java系统的高并发解决方法详解主要介绍了Java系统的高并发解决方法,内容十分丰富,在这里分享给大家,需要的朋友可以参考。一个小型的网站,比如个人网站,可以使用最简单的html...

    java高并发程序设计(原版电子书)

    《Java高并发程序设计》是一本深入探讨Java平台上的并发编程技术的专业书籍,由葛一鸣等人编著。这本书旨在帮助读者理解并掌握在高并发环境下编写高效、稳定且可扩展的Java应用程序的关键技巧和最佳实践。以下是该书...

    java并发编程实践

    ### Java并发编程实践知识点详解 #### 一、Java并发编程基础 ##### 1.1 并发与并行概念区分 在Java并发编程实践中,首先需要理解“并发”与“并行”的区别。“并发”指的是多个任务同时进行,但实际上可能是在多...

    java并发工具包 java.util.concurrent中文版用户指南pdf

    1. java.util.concurrent - Java 并发工具包 2. 阻塞队列 BlockingQueue 3. 数组阻塞队列 ArrayBlockingQueue 4. 延迟队列 DelayQueue 5. 链阻塞队列 LinkedBlockingQueue 6. 具有优先级的阻塞队列 ...

    Java并发编程的艺术

    #### 八、Java并发工具类详解 第八章关注于Java提供的并发工具类,这些工具类包括CountDownLatch、CyclicBarrier、Semaphore等,它们是Java并发编程库的重要组成部分。本章不仅详细介绍了这些工具类的功能和用途,...

    龙果java并发编程完整视频

    第37节并发工具类CountDownLatch详解00:22:04分钟 | 第38节并发工具类CyclicBarrier 详解00:11:52分钟 | 第39节并发工具类Semaphore详解00:17:27分钟 | 第40节并发工具类Exchanger详解00:13:47分钟 | 第41节...

    最新Java 编程详解

    5. **多线程**:Java提供了Thread类和Runnable接口来实现并发,还有同步机制如synchronized关键字,wait()、notify()和notifyAll()方法,以及线程池(ExecutorService)。 6. **网络编程**:Socket编程用于创建...

    Java并发.pdf

    ### Java并发知识点详解 #### 一、多线程基础概念 **进程与线程的区别** - **进程**:是程序的一次动态执行过程,每个进程都有独立的内存空间,包括程序代码、数据以及操作系统分配的资源(如文件句柄、内存段等...

    Java 多线程与并发-Java并发知识体系详解.pdf

    Java并发编程是Java开发中的重要领域,涉及到多线程、并发控制、同步机制等多个知识点。以下是对Java并发知识体系的详细解析。 首先,我们要理解并发的理论基础。并发是为了提高系统资源利用率和处理能力,让多个...

    Java并发实践英文版(Java Concurrency in Practice)

    ### Java并发实践知识点详解 #### 一、书籍基本信息与作者介绍 - **书名**:《Java并发实践》(Java Concurrency in Practice) - **作者**:Brian Goetz, Tim Peierls, Joshua Bloch, Joseph Bowbeer, David ...

    Java并发编程原理与实战

    并发工具类CountDownLatch详解.mp4 并发工具类CyclicBarrier 详解.mp4 并发工具类Semaphore详解.mp4 并发工具类Exchanger详解.mp4 CountDownLatch,CyclicBarrier,Semaphore源码解析.mp4 提前完成任务之FutureTask...

    java高并发编程第一版

    9. **Java并发库的最新发展**:如果书籍更新至较新版本,可能会包含Java并发库的新特性,例如Java 8及以后版本引入的ForkJoinPool和CompletableFuture等高级并发工具。 10. **实战案例分析**:书中可能包含实际项目...

    JAVA高质量并发详解,多线程并发深入讲解

    ### JAVA高质量并发详解知识点概述 #### 一、Java并发编程基础 - **基础知识:** - **线程基本概念:** Java线程是程序执行流的最小单元,一个线程包含一个程序计数器(PC)、虚拟机栈、本地方法栈、线程私有的工作...

    java锁详解.pdf

    Java 锁详解 Java 锁是 Java 并发编程中的一种基本机制,用于确保线程安全和避免竞争条件。Java 锁可以分为两大类:synchronized 锁和 ReentrantLock 锁。 一、Synchronized 锁 1. 锁的原理:synchronized 锁是...

    Java并发之AQS详解.pdf

    Java并发之AQS详解 AbstractQueuedSynchronizer(AQS)是 Java 并发编程中的一个核心组件,提供了一套多线程访问共享资源的同步器框架。AQS 定义了两种资源共享方式:Exclusive(独占)和 Share(共享)。在 AQS 中...

Global site tag (gtag.js) - Google Analytics