Java 并发编程基础概念

本贴最后更新于 1867 天前,其中的信息可能已经水流花落

Java 并发编程基础概念

线程安全性

1、什么是线程安全性?
  • 当多个线程访问某个状态变量并且其中有一个线程执行写入操作时,必须采用同步机制来协同这些线程对变量的访问。
  • 如果当多个线程访问同一个可变的状态变量时没有使用合适的同步,那么程序就会出现错误,这也就是所谓的线程不安全。

怎么解决这些不安全的问题呢?

  1. 不在线程之间共享该状态变量
  2. 将状态变量修改为不可变的变量
  3. 在访问状态变量时没有使用同步

当多个线程对同一共享变量进行操作时就有可能导致线程安全问题,那什么又是线程安全性呢?

当多个线程访问某个类时,不管运行时环境采用何种调度方式或者这些线程将如何交替执行,并且在主调代码中不需要任何额外的同步或协同,这个类都能表现出正确的行为,那么就称这个类是线程安全的。

2、竞态条件

如果多个线程对同一个数据进行“读取---修改---写入”的操作序列的话,如果对这个共享变量的操作没有进行同步的话,在多次调用中可能会导致严重的数据完整性问题。
在这里引出竞态条件的定义:

由于不恰当的执行时序而出现不正确的结果,这种情况被称为竞态条件。

竞态条件 很容易会与 数据竞争 相混淆,下面给出数据竞争的定义。

数据竞争是指,如果在访问共享的非 final 类型的域时没有采取同步来进行协同,那么就会出现数据竞争。

当某个计算的正确性取决于多个线程交替执行时序时,那么就会发生竞态条件。竞态条件又有哪些类型呢?

  • 先检查后执行 基于一种可能失效的观察结果来做出判断或者执行某个计算
3、加锁机制

在介绍锁之前,先要介绍原子性相关的几个概念

  • 原子操作:对于访问同一个状态的所有操作(包括该操作本身)来说,这个操作时一个以原子方式执行的操作
  • 复合操作:包含了一组必须以原子方式执行的操作以确保线程安全性
内置锁

同步代码块:java 为支持原子性的一种内置的锁机制
同步代码块包括俩个部分,一个作为锁的对象引用,一个作为由这个锁保护的代码块

synchronized(lock){
//访问或修改由锁保护的共享状态
}
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3187 引用 • 8213 回帖
  • 基础知识
    13 引用 • 6 回帖
  • 并发
    75 引用 • 73 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...