java 高并发 之 锁

本文探讨了Java中的锁机制,包括synchronized的声明式加锁,ReentrantLock的显式锁及其公平非公平选择,以及ReentrantReadWriteLock的读写分离特性。还介绍了StampedLock的乐观读策略和避免写线程饥饿的CLH锁实现。根据并发量和需求,可以选择不同的锁策略。
摘要由CSDN通过智能技术生成

synchronized

synchronized 是属于声明式加锁,可以修饰一个代码块、一个方法、一个类,一个静态方法。

	// 修饰一个代码块
    public void test1(int j) {
   
        synchronized (this) {
   
            for (int i = 0; i < 10; i++) {
   
                log.info("test1 {} - {}", j, i);
            }
        }
    }
	// 修饰一个方法
    public synchronized void test2(int j) {
   
        for (int i = 0; i < 10; i++) {
   
            log.info("test2 {} - {}", j, i);
        }
    }
	// 修饰一个类
    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);
        }
    }

synchronized 是在jvm层面实现的,不但可以通过一些监控工具监控,而且出现系统异常了,jvm也会自动的解锁,所以jvm会自动的做加锁与解锁操作,其用法对开发人员是完全透明的。

ReentrantLock

ReentrantLock 是对象层面的锁,需要手动的加锁和解锁。在加解锁时机有了更灵活的选择,并且提供了公平选择和非公平选择。

	// 请求总数
    public static int clientTotal = 5000;

    // 同时并发执行的线程数
    public static int threadTotal = 200;

    public static int count = 0;

    private final static Lock
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值