Java并发编程 - 线程安全性之原子性(三)(下)

简介: Java并发编程 - 线程安全性之原子性(三)(下)

案例三


package com.mmall.concurrency.example.sync;
import lombok.extern.slf4j.Slf4j;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
@Slf4j
public class SynchronizedExample2 {
    // 修饰一个类
    public static void test1(int j) {
        synchronized (SynchronizedExample2.class) {
            for (int i = 0; i < 10; i++) {
                log.info("test1 {} - {}", j, i);
            }
        }
    }
    // 修饰一个静态方法
    public static synchronized void test2(int j) {
        for (int i = 0; i < 10; i++) {
            log.info("test2 {} - {}", j, i);
        }
    }
    public static void main(String[] args) {
        SynchronizedExample2 example1 = new SynchronizedExample2();
        SynchronizedExample2 example2 = new SynchronizedExample2();
        ExecutorService executorService = Executors.newCachedThreadPool();
        executorService.execute(() -> {
            example1.test1(1);
        });
        executorService.execute(() -> {
            example2.test1(2);
        });
    }
}

image.png


案例四


package com.mmall.concurrency.example.sync;
import lombok.extern.slf4j.Slf4j;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
@Slf4j
public class SynchronizedExample2 {
    // 修饰一个类
    public static void test1(int j) {
        synchronized (SynchronizedExample2.class) {
            for (int i = 0; i < 10; i++) {
                log.info("test1 {} - {}", j, i);
            }
        }
    }
    // 修饰一个静态方法
    public static synchronized void test2(int j) {
        for (int i = 0; i < 10; i++) {
            log.info("test2 {} - {}", j, i);
        }
    }
    public static void main(String[] args) {
        SynchronizedExample2 example1 = new SynchronizedExample2();
        SynchronizedExample2 example2 = new SynchronizedExample2();
        ExecutorService executorService = Executors.newCachedThreadPool();
        executorService.execute(() -> {
            example1.test1(1);
        });
        executorService.execute(() -> {
            example2.test2(2);
        });
    }
}

image.png


案例3 & 案例4 分析


锁的是方法,而不是对象。什么意思呢?也就是说不同对象调用同一个被锁的方法之间执行按顺序来,所以为什么说其实是锁所有的对象,这个说法是有歧义的,应该还是说是锁所有调用该方法的对象。

那么问题来了,不同的对象调用不同的静态sychronized方法也是按先后顺序来?!虽然我测试的结果是支持按顺序来的,不过不知读者有何见解?

目前测试出的结论:在案例3和案例4的基础上,不同对象调用不同sync静态方法,把它看成是一个单元的话,单元之间的执行顺序是不一定的,但是好像执行了很多次又一直是一个规律,个人目测应该是线程池里面的影响。当然内部是不会交错的噢~


image.png


对比

  • synchronized 适合竞争不激烈时使用,可读性好,竞争激烈时性能下降很快。
  • lock 适合竞争激烈时使用,能维持常态。
  • atomic 竞争激烈时也能维持常态,性能比lock好,但是只能同步一个值。
目录
相关文章
|
22小时前
|
缓存 Java
【Java基础】简说多线程(上)
【Java基础】简说多线程(上)
5 0
|
1天前
|
Java API 调度
[Java并发基础]多进程编程
[Java并发基础]多进程编程
|
1天前
|
Java API 调度
[AIGC] 深入理解Java并发编程:从入门到进阶
[AIGC] 深入理解Java并发编程:从入门到进阶
|
1天前
|
前端开发 Java 测试技术
Java从入门到精通:4.1.1参与实际项目,锻炼编程与问题解决能力
Java从入门到精通:4.1.1参与实际项目,锻炼编程与问题解决能力
|
1天前
|
Dubbo Java 应用服务中间件
Java从入门到精通:3.2.2分布式与并发编程——了解分布式系统的基本概念,学习使用Dubbo、Spring Cloud等分布式框架
Java从入门到精通:3.2.2分布式与并发编程——了解分布式系统的基本概念,学习使用Dubbo、Spring Cloud等分布式框架
|
1天前
|
SQL Java 数据库连接
Java从入门到精通:2.3.2数据库编程——了解SQL语言,编写基本查询语句
Java从入门到精通:2.3.2数据库编程——了解SQL语言,编写基本查询语句
|
1天前
|
SQL Java 数据库连接
Java从入门到精通:2.3.1数据库编程——学习JDBC技术,掌握Java与数据库的交互
ava从入门到精通:2.3.1数据库编程——学习JDBC技术,掌握Java与数据库的交互
|
1天前
|
并行计算 算法 安全
Java从入门到精通:2.1.3深入学习Java核心技术——掌握Java多线程编程
Java从入门到精通:2.1.3深入学习Java核心技术——掌握Java多线程编程
|
1月前
|
存储 Java 程序员
Java并发编程:深入理解线程池
【2月更文挑战第14天】 在现代软件开发中,高效地处理并发任务已成为提升性能和响应速度的关键。Java作为广泛使用的编程语言,其内置的并发工具特别是线程池机制,为开发者提供了强大的支持。本文将深入探讨Java线程池的核心概念、工作机制以及如何合理配置线程池以适应不同的应用场景。我们将通过理论解析与实践案例相结合的方式,使读者不仅理解线程池的工作原理,还能掌握其在复杂系统中的高效应用。
24 0
|
17天前
|
Java
Java 并发编程:深入理解线程池
【4月更文挑战第8天】本文将深入探讨 Java 中的线程池技术,包括其工作原理、优势以及如何使用。线程池是 Java 并发编程的重要工具,它可以有效地管理和控制线程的执行,提高系统性能。通过本文的学习,读者将对线程池有更深入的理解,并能在实际开发中灵活运用。