- 浏览: 16611 次
- 性别:
- 来自: 上海
文章分类
最新评论
线程安全
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》
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》
发表评论
-
知识点
2017-11-13 18:16 0happen befor: 线程 star before 线程 ... -
ConcurrentHashMap 精髓
2017-11-02 15:13 0ConcurrentHashMap 精髓: 1.s ... -
经典面试题
2017-09-28 16:58 676接触到一个经典的面试 ... -
java condition await() 与object wait()的区别
2017-09-07 14:42 2775java condition await() 与object ... -
一致性HASH
2016-11-10 15:54 0在我们做分布式的时候,难免会有一个路由的过程,比如说redis ... -
JVM stop the world
2016-11-09 23:03 450JVM 在进行GC的时候,需要做两个事情,一个是GC root ... -
java Thread 解析
2016-10-27 21:31 0/* * Copyright (c) 1994, 20 ... -
悲观锁 乐观锁,公平锁,非公平锁
2016-10-27 13:55 0悲观锁 乐观锁,公平锁,非公平锁 d 他们的区别 悲观锁与乐 ... -
java LockSupport
2016-10-26 20:33 0/* * ORACLE PROPRIETARY/CONFI ... -
AbstractQueuedSynchronizer 的 CLH
2016-10-26 09:19 0/** * Wait queue node ... -
java 中的wait 与 await
2016-10-25 20:16 0java中wait() 与 await() wait() 方 ... -
java中内存泄漏
2016-09-01 07:43 555内存泄漏(memory leak):该被回收的对象没有被回收, ... -
线程性能与可伸缩性
2016-08-25 23:06 0对性能的思考 性能与可伸缩性 评估各种性能的权衡因素 am ... -
怎么平衡线程并发中的活跃性和安全性
2016-08-25 23:02 0线程的活跃性 活跃性:线程的处理速度 安全性:加锁保证数据的正 ... -
java线程的取消和关闭
2016-08-25 22:55 0java的线程取消和关闭 在正常的业务操作中,碰到进行中的任 ... -
Java 线程池
2016-08-25 09:24 0线程池工作原理 线程池的原理解析 线程池代码解析 -
研发分级
2016-07-27 11:54 0研发分级 今天老大问了一个问题:怎么区分 -
编程建议(持续更新)
2016-07-18 11:01 3741.UML的重要性,推荐plant ... -
java学习路线图
2016-07-14 22:56 670这么长的时间,么有好好总结过自己的学习路线,今天和大家一起分享 ... -
threadLocal的使用场景--事务下的日志记录
2016-07-02 16:04 2867threadLocal在系统中的使 ...
相关推荐
《Java并发编程实战》是一本深入探讨Java平台并发编程的权威指南。这本书旨在帮助开发者理解和掌握在Java环境中创建高效、可扩展且可靠的多线程应用程序的关键技术和实践。它涵盖了从基本概念到高级主题的广泛内容,...
#### 一、Java并发概述 自Java诞生之初,其设计者就赋予了该语言强大的并发处理能力。Java语言内置了对线程和锁的支持,这使得开发者能够轻松地编写多线程应用程序。本文旨在帮助Java开发者深入理解并发的核心概念...
#### 一、Java并发特性详解 在《Java并发编程实战》这本书中,作者深入浅出地介绍了Java 5.0和Java 6中新增的并发特性。这些特性旨在帮助开发者更高效、安全地编写多线程程序。书中通过实例解释了诸如`...
1. java.util.concurrent - Java 并发工具包 2. 阻塞队列 BlockingQueue 3. 数组阻塞队列 ArrayBlockingQueue 4. 延迟队列 DelayQueue 5. 链阻塞队列 LinkedBlockingQueue 6. 具有优先级的阻塞队列 ...
Java并发编程是软件开发中的重要领域,特别是在大型系统和高并发场景中不可或缺。"13-Java并发编程学习宝典.zip" 包含了一系列关于Java并发编程的学习资源,旨在帮助开发者掌握多线程编程的核心技术和最佳实践。以下...
Java系统的高并发解决方法详解 Java系统的高并发解决方法详解主要介绍了Java系统的高并发解决方法,内容十分丰富,在这里分享给大家,需要的朋友可以参考。一个小型的网站,比如个人网站,可以使用最简单的html...
《Java高并发程序设计》是一本深入探讨Java平台上的并发编程技术的专业书籍,由葛一鸣等人编著。这本书旨在帮助读者理解并掌握在高并发环境下编写高效、稳定且可扩展的Java应用程序的关键技巧和最佳实践。以下是该书...
### Java并发编程实践知识点详解 #### 一、Java并发编程基础 ##### 1.1 并发与并行概念区分 在Java并发编程实践中,首先需要理解“并发”与“并行”的区别。“并发”指的是多个任务同时进行,但实际上可能是在多...
1. java.util.concurrent - Java 并发工具包 2. 阻塞队列 BlockingQueue 3. 数组阻塞队列 ArrayBlockingQueue 4. 延迟队列 DelayQueue 5. 链阻塞队列 LinkedBlockingQueue 6. 具有优先级的阻塞队列 ...
#### 八、Java并发工具类详解 第八章关注于Java提供的并发工具类,这些工具类包括CountDownLatch、CyclicBarrier、Semaphore等,它们是Java并发编程库的重要组成部分。本章不仅详细介绍了这些工具类的功能和用途,...
第37节并发工具类CountDownLatch详解00:22:04分钟 | 第38节并发工具类CyclicBarrier 详解00:11:52分钟 | 第39节并发工具类Semaphore详解00:17:27分钟 | 第40节并发工具类Exchanger详解00:13:47分钟 | 第41节...
5. **多线程**:Java提供了Thread类和Runnable接口来实现并发,还有同步机制如synchronized关键字,wait()、notify()和notifyAll()方法,以及线程池(ExecutorService)。 6. **网络编程**:Socket编程用于创建...
### Java并发知识点详解 #### 一、多线程基础概念 **进程与线程的区别** - **进程**:是程序的一次动态执行过程,每个进程都有独立的内存空间,包括程序代码、数据以及操作系统分配的资源(如文件句柄、内存段等...
Java并发编程是Java开发中的重要领域,涉及到多线程、并发控制、同步机制等多个知识点。以下是对Java并发知识体系的详细解析。 首先,我们要理解并发的理论基础。并发是为了提高系统资源利用率和处理能力,让多个...
### Java并发实践知识点详解 #### 一、书籍基本信息与作者介绍 - **书名**:《Java并发实践》(Java Concurrency in Practice) - **作者**:Brian Goetz, Tim Peierls, Joshua Bloch, Joseph Bowbeer, David ...
并发工具类CountDownLatch详解.mp4 并发工具类CyclicBarrier 详解.mp4 并发工具类Semaphore详解.mp4 并发工具类Exchanger详解.mp4 CountDownLatch,CyclicBarrier,Semaphore源码解析.mp4 提前完成任务之FutureTask...
9. **Java并发库的最新发展**:如果书籍更新至较新版本,可能会包含Java并发库的新特性,例如Java 8及以后版本引入的ForkJoinPool和CompletableFuture等高级并发工具。 10. **实战案例分析**:书中可能包含实际项目...
### JAVA高质量并发详解知识点概述 #### 一、Java并发编程基础 - **基础知识:** - **线程基本概念:** Java线程是程序执行流的最小单元,一个线程包含一个程序计数器(PC)、虚拟机栈、本地方法栈、线程私有的工作...
Java 锁详解 Java 锁是 Java 并发编程中的一种基本机制,用于确保线程安全和避免竞争条件。Java 锁可以分为两大类:synchronized 锁和 ReentrantLock 锁。 一、Synchronized 锁 1. 锁的原理:synchronized 锁是...
Java并发之AQS详解 AbstractQueuedSynchronizer(AQS)是 Java 并发编程中的一个核心组件,提供了一套多线程访问共享资源的同步器框架。AQS 定义了两种资源共享方式:Exclusive(独占)和 Share(共享)。在 AQS 中...