博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java并发编程开发笔记——2线程安全性
阅读量:6866 次
发布时间:2019-06-26

本文共 554 字,大约阅读时间需要 1 分钟。

在构建稳健的并发程序时,必须正确地使用线程和锁。但这些终归只是一些机制。要编写线程安全的代码,其核心在于要对状态访问操作进行管理,特别是对共享的(Shared)和可变的(Mutable)状态的访问。

“共享”意味着变量可以由多个线程同时访问,而“可变”则意味着变量的值在其生命周期内可以发生变化。我们将像讨论代码那样讨论线程安全性,但更侧重于如何防止在数据上发生不可控的并发访问。
一个对象是否需要是线程安全的,取决于它是否被多个线程访问。这指的是在程序中访问对象的方式,而不是对象要实现的功能。要使得对象是线程安全的,需要采用同步机制来协同对对象可变状态的访问。如果无法实现协同,那么可能会导致数据破坏以及其他不该出现的结果。
当多个线程访问某个状态变量并且其中一个线程执行写入操作时,必须采用同步机制来协同这些线程对变量的访问。Java中的主要同步机制是关键字synchronized,它提供了一种独占的加锁方式,但“同步”这个术语还包括volatile类型的变量,显式锁(Explicit Lock)以及原子变量。
在上述规则中并不存在一些想象中的“例外”情况。即使在某个程序中省略了必要同步机制并且看上去似乎能正确执行,而且通过了测试并在随后几年时间里都能正确地执行,但程序仍可能在某个时刻发生错误。
_
_
_

转载地址:http://vgkfl.baihongyu.com/

你可能感兴趣的文章
苹果开发者账号团队代理转移
查看>>
JS 总结之原型继承的几种方式
查看>>
Android微信分享多张图片和文字(发朋友圈)
查看>>
社交电商的 “比基尼”,被云集跑出会员的力量
查看>>
60 Permutation Sequence
查看>>
创建和销毁对象
查看>>
vue中引入.svg图标
查看>>
Django3-打包自己的应用程序
查看>>
[译] 正确实现 linkedPurchaseToken 以避免重复订阅
查看>>
SpringBoot2.0 整合 RocketMQ ,实现请求异步处理
查看>>
Verdaccio 搭建私有 NPM
查看>>
常用前端工具
查看>>
java11新特性---Nest-Based Access Control(嵌套访问控制)
查看>>
中专毕业生的前端面试经验分享
查看>>
(七)微服务分布式云架构spring cloud - common-service 项目构建过程
查看>>
嘴对嘴教你:用VS Code写Dart的hello world
查看>>
Node.js买卖比特币 教程
查看>>
python判断给定的数是否是回文数的代码
查看>>
一位Android大牛的BAT面试心得与经验总结
查看>>
一步步了解线程池之按需创建-CachedThreadPool
查看>>