java最新面试题及答案,Java面试知识点总结宝典助你通关

一、前言

k8s全称kubernetes,是目前大热的一个可移植容器的编排管理工具,像AWS、Azure、Google、阿里云、腾讯云等主流的公有云提供的都是基于k8s的容器服务,很多其他厂商也在努力跟进中,所以说“kubernetes”是目前容器行业中最为热门的也毫不为过!

但是大家都是知道的,kubernetes虽然比较热门,但是学习的门槛相对来说也是比较高的,所以这份笔记也是因此而生的,一经发布,瞬间上了周榜双Top1,已评钻级!

image

这份笔记有着以下两个重要的特点:

  • 系统的讲解当前最流行的容器编排引擎kubernetes,包括安装部署、应用管理、网络、储存、监控、日志管理等多个方面。
  • 重实践并兼顾理论,通过大量试验和操作带领大家学习kubernetes。

锁种类

Mysql中锁的分类按照不同类型的划分可以分成不同的锁,按照**「锁的粒度」划分可以分成:「表锁、页锁、行锁」;按照「使用的方式」划分可以分为:「共享锁」「排它锁」;按照思想的划分:「乐观锁」「悲观锁」**。

下面我们对着这几种划分的锁进行详细的解说和介绍,在了解设计者设计锁的概念的同时,也能深入的理解设计者的设计思想。

**「表锁」**是粒度最大的锁,开销小,加锁快,不会出现死锁,但是由于粒度太大,因此造成锁的冲突几率大,并发性能低。

Mysql中**「MyISAM储存引擎就支持表锁」,MyISAM的表锁模式有两种:「表共享读锁」「表独占写锁」**。

当一个线程获取到MyISAM表的读锁的时候,会阻塞其他用户对该表的写操作,但是不会阻塞其它用户对该用户的读操作。

相反的,当一个线程获取到MyISAM表的写锁的时候,就会阻塞其它用户的读写操作对其它的线程具有排它性。

**「页锁」**的粒度是介于行锁和表锁之间的一种锁,因为页锁是在BDB中支持的一种锁机制,也很少没人提及和使用,所以这里制作概述,不做详解。

**「行锁」**是粒度最小的锁机制,行锁的加锁开销性能大,加锁慢,并且会出现死锁,但是行锁的锁冲突的几率低,并发性能高。

行锁是InnoDB默认的支持的锁机制,MyISAM不支持行锁,这个也是InnoDB和MyISAM的区别之一。

行锁在使用的方式上可以划分为:「共享读锁(S锁)「和」排它写锁(X锁)」

当一个事务对Mysql中的一条数据行加上了S锁,当前事务不能修改该行数据只能执行度操作,其他事务只能对该行数据加S锁不能加X锁。

若是一个事务对一行数据加了X锁,该事物能够对该行数据执行读和写操作,其它事务不能对该行数据加任何的锁,既不能读也不能写。

「悲观锁和乐观锁是在很多框架都存在的一种思想,不要狭义地认为它们是某一种框架的锁机制」

数据库管理系统中为了控制并发,保证在多个事务执行时的数据一致性以及事务的隔离性,使用悲观锁和乐观锁来解决并发场景下的问题。

Mysql中**「悲观锁的实现是基于Mysql自身的锁机制实现,而乐观锁需要程序员自己去实现的锁机制」,最常见的乐观锁实现就锁机制是「使用版本号实现」**。

乐观锁设计思想的在CAS的运用也是比较经典,之前我写过一篇关于CAS的文章,大家感兴趣的可以参考这一篇[]。

从上面的介绍中说了每一种锁的概念,但是很难说哪一种锁就是最好的,锁没有最好的,只有哪种业务场景最适合哪种锁,具体业务具体分析。

下面我们就具体基于Mysql的存储引擎详细的分析每一种锁在存储引擎中的运用和实现。

MyISAM

MyISAM中默认支持的表级锁有两种:**「共享读锁」

点击领取2024完整开源项目《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》

「独占写锁」**。表级锁在MyISAM和InnoDB的存储引擎中都支持,但是InnoDB默认支持的是行锁。

Mysql中平时读写操作都是隐式的进行加锁和解锁操作,Mysql已经自动帮我们实现加锁和解锁操作了,若是想要测试锁机制,我们就要显示的自己控制锁机制。

Mysql中可以通过以下sql来显示的在事务中显式的进行加锁和解锁操作

惊喜

最后还准备了一套上面资料对应的面试题(有答案哦)和面试时的高频面试算法题(如果面试准备时间不够,那么集中把这些算法题做完即可,命中率高达85%+)

image.png

image.png

(img-i8FnJD5h-1709735888953)]

[外链图片转存中…(img-WK76IhWi-1709735888954)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

  • 10
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当谈到Java中级面试时,以下是一些常见的问及其答案: 1. 什么是Java中的多线程?如何创建和启动一个线程? 答:多线程是指在一个程序中同时执行多个线程,每个线程都有自己的执行路径。可以通过继承Thread类或实现Runnable接口来创建线程,并使用start()方法启动线程。 2. 什么是Java中的异常处理?Java中的异常处理机制是如何工作的? 答:异常处理是一种用于处理程序运行时错误的机制。在Java中,异常由抛出(throw)和捕获(catch)两个关键字来处理。当发生异常时,程序会抛出异常,然后通过try-catch语句块来捕获并处理异常。 3. 什么是Java中的集合框架?列举一些常见的集合类。 答:集合框架是Java提供的一组接口和类,用于存储和操作数据。常见的集合类包括ArrayList、LinkedList、HashSet、HashMap等。 4. 什么是Java中的反射?如何使用反射机制? 答:反射是指在运行时动态获取类的信息并操作类的属性和方法。可以使用Class类的相关方法来获取类的信息,并使用Constructor、Method和Field等类来操作类的构造函数、方法和属性。 5. 什么是Java中的IO流?Java中的IO流分为几种类型? 答:IO流是用于处理输入和输出的机制。Java中的IO流分为字节流和字符流两种类型。字节流用于处理二进制数据,字符流用于处理文本数据。 6. 什么是Java中的泛型?如何使用泛型? 答:泛型是指在编译时不指定具体类型,而是在运行时动态确定类型。可以使用泛型类、泛型接口和泛型方法来实现泛型。 7. 什么是Java中的注解?如何使用注解? 答:注解是一种用于提供元数据的机制。可以使用注解来为类、方法、变量等添加额外的信息。可以通过@符号来使用注解。 8. 什么是Java中的序列化?如何实现对象的序列化和反序列化? 答:序列化是指将对象转换为字节流的过程,反序列化是指将字节流转换为对象的过程。可以通过实现Serializable接口来实现对象的序列化和反序列化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值