- 浏览: 15762 次
- 性别:
- 来自: 上海
文章分类
最新评论
线程安全
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 619接触到一个经典的面试 ... -
java condition await() 与object wait()的区别
2017-09-07 14:42 2707java condition await() 与object ... -
一致性HASH
2016-11-10 15:54 0在我们做分布式的时候,难免会有一个路由的过程,比如说redis ... -
JVM stop the world
2016-11-09 23:03 407JVM 在进行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 515内存泄漏(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 3271.UML的重要性,推荐plant ... -
java学习路线图
2016-07-14 22:56 604这么长的时间,么有好好总结过自己的学习路线,今天和大家一起分享 ... -
threadLocal的使用场景--事务下的日志记录
2016-07-02 16:04 2833threadLocal在系统中的使 ...
相关推荐
自从java创建以来就已经支持并发的理念,如线程和锁。这篇指南主要是为帮助java多线程开发人员理解并发的核心概念以及如何应用这些理念。本文的主题是关于具有java语言风格的Thread、synchronized、volatile,以及...
1. java.util.concurrent - Java 并发工具包 2. 阻塞队列 BlockingQueue 3. 数组阻塞队列 ArrayBlockingQueue 4. 延迟队列 DelayQueue 5. 链阻塞队列 LinkedBlockingQueue 6. 具有优先级的阻塞队列 ...
是一本深入探讨Java并发编程的经典之作。本书全面解析了Java并发编程的核心概念、原理和实践,帮助读者深入理解多线程并发编程的精髓,提升编程能力和系统性能。 书中首先介绍了并发编程的基础知识,包括线程的基本...
主要介绍了Java系统的高并发解决方法,内容十分丰富,在这里分享给大家,需要的朋友可以参考。
1. java.util.concurrent - Java 并发工具包 2. 阻塞队列 BlockingQueue 3. 数组阻塞队列 ArrayBlockingQueue 4. 延迟队列 DelayQueue 5. 链阻塞队列 LinkedBlockingQueue 6. 具有优先级的阻塞队列 ...
Java并发之AQS详解.pdf
Java 多线程与并发-Java并发知识体系详解
实战java高并发程序设计 分章 高清 带作业, 葛一鸣等人编著
第37节并发工具类CountDownLatch详解00:22:04分钟 | 第38节并发工具类CyclicBarrier 详解00:11:52分钟 | 第39节并发工具类Semaphore详解00:17:27分钟 | 第40节并发工具类Exchanger详解00:13:47分钟 | 第41节...
并发工具类CountDownLatch详解.mp4 并发工具类CyclicBarrier 详解.mp4 并发工具类Semaphore详解.mp4 并发工具类Exchanger详解.mp4 CountDownLatch,CyclicBarrier,Semaphore源码解析.mp4 提前完成任务之FutureTask...
阿里专家级并发编程架构师级课程,完成课程的学习可以帮助同学们解决非常多的JAVA并发编程疑难杂症,极大的提高JAVA并发编程的效率。课程内容包括了JAVA手写线程池,UC线程池API详解,线程安全根因详解,锁与原子类...
龙果 java并发编程原理实战 第2节理解多线程与并发的之间的联系与区别 [免费观看] 00:11:59分钟 | 第3节解析多线程与多进程的联系以及上下文切换所导致资源浪费问题 [免费观看] 00:13:03分钟 | 第4节学习并发的四...
Java高并发程序设计模式
java内存屏障与JVM并发详解实用.pdf
详细的讲述了并发、高并发、CPU Cache、CPU多级缓存、CPU多级缓存 - 缓存一致性(MESI)、CPU多级缓存-乱序执行优化、Java内存模型(Java Memory Model,JMM)、并发的优势和风险...等等图文并茂详解
java高并发编程
Nginx高性能Web服务器详解
包含了java多线程基础介绍,多线程设计模式详解,juc包内对象详解,作为自己学习的记录,持续更新中
Java并发编程:设计原则与模式(第二版)