面经 - 【多线程】在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
目录
相关文章
|
18天前
|
Java Go 开发工具
【Java】(9)抽象类、接口、内部的运用与作用分析,枚举类型的使用
抽象类必须使用abstract修饰符来修饰,抽象方法也必须使用abstract修饰符来修饰,抽象方法不能有方法体。抽象类不能被实例化,无法使用new关键字来调用抽象类的构造器创建抽象类的实例。抽象类可以包含成员变量、方法(普通方法和抽象方法都可以)、构造器、初始化块、内部类(接 口、枚举)5种成分。抽象类的构造器不能用于创建实例,主要是用于被其子类调用。抽象类中不一定包含抽象方法,但是有抽象方法的类必定是抽象类abstract static不能同时修饰一个方法。
159 1
|
28天前
|
算法 安全 Java
除了类,Java中的接口和方法也可以使用泛型吗?
除了类,Java中的接口和方法也可以使用泛型吗?
82 11
|
2月前
|
存储 缓存 安全
Java集合框架(二):Set接口与哈希表原理
本文深入解析Java中Set集合的工作原理及其实现机制,涵盖HashSet、LinkedHashSet和TreeSet三大实现类。从Set接口的特性出发,对比List理解去重机制,并详解哈希表原理、hashCode与equals方法的作用。进一步剖析HashSet的底层HashMap实现、LinkedHashSet的双向链表维护顺序特性,以及TreeSet基于红黑树的排序功能。文章还包含性能对比、自定义对象去重、集合运算实战和线程安全方案,帮助读者全面掌握Set的应用与选择策略。
190 23
|
2月前
|
存储 安全 Java
Java集合框架(一):List接口及其实现类剖析
本文深入解析Java中List集合的实现原理,涵盖ArrayList的动态数组机制、LinkedList的链表结构、Vector与Stack的线程安全性及其不推荐使用的原因,对比了不同实现的性能与适用场景,帮助开发者根据实际需求选择合适的List实现。
|
5月前
|
机器学习/深度学习 消息中间件 存储
【高薪程序员必看】万字长文拆解Java并发编程!(9-2):并发工具-线程池
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发编程中的强力并发工具-线程池,废话不多说让我们直接开始。
211 0
|
8月前
|
Linux
Linux编程: 在业务线程中注册和处理Linux信号
通过本文,您可以了解如何在业务线程中注册和处理Linux信号。正确处理信号可以提高程序的健壮性和稳定性。希望这些内容能帮助您更好地理解和应用Linux信号处理机制。
141 26
|
8月前
|
Linux
Linux编程: 在业务线程中注册和处理Linux信号
本文详细介绍了如何在Linux中通过在业务线程中注册和处理信号。我们讨论了信号的基本概念,并通过完整的代码示例展示了在业务线程中注册和处理信号的方法。通过正确地使用信号处理机制,可以提高程序的健壮性和响应能力。希望本文能帮助您更好地理解和应用Linux信号处理,提高开发效率和代码质量。
148 17
|
10月前
|
存储 安全 Java
Java多线程编程秘籍:各种方案一网打尽,不要错过!
Java 中实现多线程的方式主要有四种:继承 Thread 类、实现 Runnable 接口、实现 Callable 接口和使用线程池。每种方式各有优缺点,适用于不同的场景。继承 Thread 类最简单,实现 Runnable 接口更灵活,Callable 接口支持返回结果,线程池则便于管理和复用线程。实际应用中可根据需求选择合适的方式。此外,还介绍了多线程相关的常见面试问题及答案,涵盖线程概念、线程安全、线程池等知识点。
618 2
|
11月前
|
设计模式 Java 开发者
Java多线程编程的陷阱与解决方案####
本文深入探讨了Java多线程编程中常见的问题及其解决策略。通过分析竞态条件、死锁、活锁等典型场景,并结合代码示例和实用技巧,帮助开发者有效避免这些陷阱,提升并发程序的稳定性和性能。 ####
|
11月前
|
缓存 Java 开发者
Java多线程编程的陷阱与最佳实践####
本文深入探讨了Java多线程编程中常见的陷阱,如竞态条件、死锁和内存一致性错误,并提供了实用的避免策略。通过分析典型错误案例,本文旨在帮助开发者更好地理解和掌握多线程环境下的编程技巧,从而提升并发程序的稳定性和性能。 ####