面经 - 【多线程】在Java中Lock接口比synchronized块的优势是什么?你需要实现一个高效的缓存,它允许多个用户读,但只允许一个用户写,以此来保持它的完整性,你会怎样去实现它?

简介: 面经 - 【多线程】在Java中Lock接口比synchronized块的优势是什么?你需要实现一个高效的缓存,它允许多个用户读,但只允许一个用户写,以此来保持它的完整性,你会怎样去实现它?

解析:lock接口在多线程和并发编程中最大的优势是它们为读和写分别提供了锁,它能满足你写像 ConcurrentHashMap 这样的高性能数据结构和有条件的阻塞。Java线程面试的问题越来越会根据面试者的回答来提问。我强烈建议在你去参加多线程的面试之前认真读一下Locks,因为当前其大量用于构建电子交易终统的客户端缓存和交易连接空间。Lock读写锁机制可以实现! 在Java中Lock接口比synchronized块的优势是什么?


Lock接口最大的优势是为读和写分别提供了锁。

packagetech.luxsun.interview.luxinterviewstarter.thread;
importjava.time.LocalDateTime;
importjava.util.concurrent.ThreadLocalRandom;
importjava.util.concurrent.locks.ReadWriteLock;
importjava.util.concurrent.locks.ReentrantReadWriteLock;
/*** @author Lux Sun* @date 2021/4/11*/publicclassLockDemo {
publicstaticvoidmain(String[] args) {
// 初始化Cachecache=newCache();
// 读取for (inti=0; i<5; i++) {
newThread(() ->cache.get()).start();
        }
// 写入for (inti=0; i<5; i++) {
newThread(() ->cache.put(ThreadLocalRandom.current().nextInt(1000))).start();
        }
    }
}
classCache {
privateIntegerdata=0;
privateReadWriteLockrwLock=newReentrantReadWriteLock();
publicvoidget() {
// try...catch...finally 防止死锁try {
// 读锁开启, 读进程均可进入rwLock.readLock().lock();
System.out.println(Thread.currentThread().getName() +"read lock is ready..."+LocalDateTime.now());
Thread.sleep(1000);
System.out.println(Thread.currentThread().getName() +"read data is "+data);
        } catch (InterruptedExceptione) {
e.printStackTrace();
        } finally {
// 读锁解锁rwLock.readLock().unlock();
        }
    }
publicvoidput(Integerdata) {
try {
// 写锁开启, 写进程只允许进一个rwLock.writeLock().lock();
System.out.println(Thread.currentThread().getName() +"write lock is ready..."+LocalDateTime.now());
Thread.sleep(1000);
this.data=data;
System.out.println(Thread.currentThread().getName() +"write data is "+data);
        } catch (InterruptedExceptione) {
e.printStackTrace();
        } finally {
// 写锁解锁rwLock.writeLock().unlock();
        }
    }
}
Thread-4readlockisready...2021-04-11T17:44:57.733Thread-0readlockisready...2021-04-11T17:44:57.733Thread-3readlockisready...2021-04-11T17:44:57.733Thread-1readlockisready...2021-04-11T17:44:57.733Thread-2readlockisready...2021-04-11T17:44:57.733Thread-0readdatais0Thread-3readdatais0Thread-2readdatais0Thread-1readdatais0Thread-4readdatais0Thread-8writelockisready...2021-04-11T17:44:58.735Thread-8writedatais118Thread-9writelockisready...2021-04-11T17:44:59.735Thread-9writedatais560Thread-5writelockisready...2021-04-11T17:45:00.736Thread-5writedatais333Thread-7writelockisready...2021-04-11T17:45:01.737Thread-7writedatais685Thread-6writelockisready...2021-04-11T17:45:02.737Thread-6writedatais507
目录
相关文章
|
8月前
|
算法 安全 Java
除了类,Java中的接口和方法也可以使用泛型吗?
除了类,Java中的接口和方法也可以使用泛型吗?
249 11
|
7月前
|
Java Go 开发工具
【Java】(9)抽象类、接口、内部的运用与作用分析,枚举类型的使用
抽象类必须使用abstract修饰符来修饰,抽象方法也必须使用abstract修饰符来修饰,抽象方法不能有方法体。抽象类不能被实例化,无法使用new关键字来调用抽象类的构造器创建抽象类的实例。抽象类可以包含成员变量、方法(普通方法和抽象方法都可以)、构造器、初始化块、内部类(接 口、枚举)5种成分。抽象类的构造器不能用于创建实例,主要是用于被其子类调用。抽象类中不一定包含抽象方法,但是有抽象方法的类必定是抽象类abstract static不能同时修饰一个方法。
324 1
|
9月前
|
存储 缓存 安全
Java集合框架(二):Set接口与哈希表原理
本文深入解析Java中Set集合的工作原理及其实现机制,涵盖HashSet、LinkedHashSet和TreeSet三大实现类。从Set接口的特性出发,对比List理解去重机制,并详解哈希表原理、hashCode与equals方法的作用。进一步剖析HashSet的底层HashMap实现、LinkedHashSet的双向链表维护顺序特性,以及TreeSet基于红黑树的排序功能。文章还包含性能对比、自定义对象去重、集合运算实战和线程安全方案,帮助读者全面掌握Set的应用与选择策略。
1051 23
|
9月前
|
存储 安全 Java
Java集合框架(一):List接口及其实现类剖析
本文深入解析Java中List集合的实现原理,涵盖ArrayList的动态数组机制、LinkedList的链表结构、Vector与Stack的线程安全性及其不推荐使用的原因,对比了不同实现的性能与适用场景,帮助开发者根据实际需求选择合适的List实现。
|
12月前
|
缓存 NoSQL 关系型数据库
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
|
7月前
|
缓存 负载均衡 监控
135_负载均衡:Redis缓存 - 提高缓存命中率的配置与最佳实践
在现代大型语言模型(LLM)部署架构中,缓存系统扮演着至关重要的角色。随着LLM应用规模的不断扩大和用户需求的持续增长,如何构建高效、可靠的缓存架构成为系统性能优化的核心挑战。Redis作为业界领先的内存数据库,因其高性能、丰富的数据结构和灵活的配置选项,已成为LLM部署中首选的缓存解决方案。
792 25
|
缓存 NoSQL Java
Redis+Caffeine构建高性能二级缓存
大家好,我是摘星。今天为大家带来的是Redis+Caffeine构建高性能二级缓存,废话不多说直接开始~
1575 0
|
8月前
|
存储 缓存 NoSQL
Redis专题-实战篇二-商户查询缓存
本文介绍了缓存的基本概念、应用场景及实现方式,涵盖Redis缓存设计、缓存更新策略、缓存穿透问题及其解决方案。重点讲解了缓存空对象与布隆过滤器的使用,并通过代码示例演示了商铺查询的缓存优化实践。
352 1
Redis专题-实战篇二-商户查询缓存
|
7月前
|
缓存 运维 监控
Redis 7.0 高性能缓存架构设计与优化
🌟蒋星熠Jaxonic,技术宇宙中的星际旅人。深耕Redis 7.0高性能缓存架构,探索函数化编程、多层缓存、集群优化与分片消息系统,用代码在二进制星河中谱写极客诗篇。
1392 3
|
8月前
|
缓存 NoSQL 关系型数据库
Redis缓存和分布式锁
Redis 是一种高性能的键值存储系统,广泛用于缓存、消息队列和内存数据库。其典型应用包括缓解关系型数据库压力,通过缓存热点数据提高查询效率,支持高并发访问。此外,Redis 还可用于实现分布式锁,解决分布式系统中的资源竞争问题。文章还探讨了缓存的更新策略、缓存穿透与雪崩的解决方案,以及 Redlock 算法等关键技术。