看这篇足矣了,阿里内部SpringBoot高阶手册爆火

本文探讨了分布式锁的概念,介绍了在多线程环境中的锁机制,并列举了Java面试中可能涉及的知识点,如Java基础、集合框架、并发与线程池、JVM内存管理、网络编程、MySQL优化、Spring框架和分布式技术如Redis和消息队列。
摘要由CSDN通过智能技术生成

什么是分布式锁?在回答这个问题之前,我们先回答一下什么是锁。

普通的锁,即在单机多线程环境下,当多个线程需要访问同一个变量或代码片段时,被访问的变量或代码片段叫做临界区域,我们需要控制线程一个一个的顺序执行,否则会出现并发问题。

如何控制呢?就是设置一个各个线程都能看的见的标志。然后,每个线程想访问临界区域时,都要先查看标志,如果标志没有被占用,则说明目前没有线程在访问临界区域。如果标志被占用了,则说明目前有线程正在访问临界区域,则当前线程需要等待。

这个标志,就是锁。

在单机多线程的java程序中,我们可以使用堆内存中的变量作为标志,因为多线程是共享堆内存的,堆内存中的变量对于各个线程都是可见的。

面试准备

不论是校招还是社招都避免不了各种面试、笔试,如何去准备这些东西就显得格外重要。 运筹帷幄之后,决胜千里之外!不打毫无准备的仗,我觉得大家可以先从下面几个方面来准备面试:

1. 自我介绍。(介绍自己的项目经历以及一些特长而不是简单自我介绍喜好等)

2. 自己面试中可能涉及哪些知识点、那些知识点是重点。

3. 面试中哪些问题会被经常问到、面试中自己该如何回答。

4. 自己的简历该如何写。

“80%的offer掌握在20%的人手中” 这句话也不是不无道理的。决定你面试能否成功的因素中实力固然占有很大一部 分比例,但是如果你的心态或者说运气不好的话,依然无法拿到满意的 offer。运气暂且不谈,就拿心态来说,千万 不要因为面试失败而气馁或者说怀疑自己的能力,面试失败之后多总结一下失败的原因,后面你就会发现自己会越来 越强大。

另外,大家要明确的很重要的几点是:

1. 写在简历上的东西一定要慎重,这可能是面试官大量提问的地方;

2. 将自己的项目经历完美的展示出来非常重要。

常见面试问题及范围如下

Java基础

  1. 重载和重写的区别

  2. String 和 StringBuffer、StringBuilder 的区别是什么?String 为什么是不可变的?

  3. 自动装箱与拆箱

  4. == 与 equals

  5. final 关键字

  6. Object类的常见方法

  7. Java 中的异常处理

  8. 获取用键盘输入常用的的两种方法

  9. 接口和抽象类的区别是什么

集合框架

  1. Arraylist 与 LinkedList 异同

  2. ArrayList 与 Vector 区别

  3. HashMap的底层实现

  4. HashMap 和 Hashtable 的区别

  5. HashMap 的长度为什么是2的幂次方

  6. HashMap 多线程操作导致死循环问题

  7. HashSet 和 HashMap 区别

  8. ConcurrentHashMap 和 Hashtable 的区别

  9. ConcurrentHashMap线程安全的具体实现方式/底层具体实现

多线程与并发

  1. AQS 原理

  2. AQS 对资源的共享方式

  3. AQS底层使用了模板方法模式

  4. 说一说自己对于 synchronized 关键字的了解

  5. 说说自己是怎么使用 synchronized 关键字,在项目中用到了吗

  6. 讲一下 synchronized 关键字的底层原理

  7. 说说 JDK1.6 之后的synchronized 关键字底层做了哪些优化,可以详细介绍一下这些优化吗

  8. 谈谈 synchronized和ReenTrantLock 的区别

  9. 说说 synchronized 关键字和 volatile 关键字的区别

  10. 为什么要用线程池?

  11. 实现Runnable接口和Callable接口的区别

  12. 执行execute()方法和submit()方法的区别是什么呢?

  13. 如何创建线程池

  14. 介绍一下Atomic 原子类

  15. JUC 包中的原子类是哪4类?

  16. 讲讲 AtomicInteger 的使用

  17. 能不能给我简单介绍一下 AtomicInteger 类的原理

JVM

  1. Java 中会存在内存泄漏吗,简述一下?

  2. 描述一下 JVM 加载 Class 文件的原理机制?

  3. 什么是tomcat类加载机制?

  4. 类加载器双亲委派模型机制?

  5. 垃圾回收常见问题

  6. 什么是GC? 为什么要有 GC?

  7. 简述一下Java 垃圾回收机制?

  8. 如何判断一个对象是否存活?

  9. 垃圾回收的优点和原理,并考虑 2 种回收机制?

  10. Java 中垃圾收集的方法有哪些?

  11. 讲讲你理解的性能评价及测试指标?

  12. 常用的性能优化方式有哪些?

网络编程与操作系统

  1. TCP、UDP 协议的区别

  2. 在浏览器中输入url地址 ->> 显示主页的过程

  3. 各种协议与HTTP协议之间的关系

  4. HTTP长连接、短连接

  5. TCP 三次握手和四次挥手(面试常客)

  6. 简单介绍一下 Linux 文件系统?

  7. 一些常见的 Linux 命令了解吗?

MySQL

  1. 说说自己对于 MySQL 常见的两种存储引擎:MyISAM与InnoDB的理解?

  2. 数据库索引了解吗?

  3. 为什么索引能提高查询速度?

  4. Mysql如何为表字段添加索引?

  5. 对于大表的常见优化手段说一下?

Spring

  1. Spring Bean 的作用域

  2. Spring 事务中的隔离级别

  3. Spring 事务中的事务传播行为

  4. AOP是什么?

  5. IOC是什么?

分布式

  1. 为什么要用 redis缓存?

  2. 为什么要用 redis 而不用 map/guava 做缓存?

  3. redis 和 memcached 的区别?

  4. redis 常见数据结构以及使用场景分析?(String,Hash,List,Set,Sorted Set)

  5. redis 设置过期时间

  6. redis 内存淘汰机制(MySQL里有2000w数据,Redis中只存20w的数据,如何保证Redis中的数据都是热点数据?)

  7. redis 持久化机制(怎么保证 redis 挂掉之后再重启数据可以进行恢复)?

  8. redis 事务

  9. 缓存雪崩和缓存穿透问题解决方案

  10. 如何解决 Redis 的并发竞争 Key 问题

  11. 如何保证缓存与数据库双写时的数据一致性?

  12. 什么是消息队列?为什么要用消息队列?

  13. 通过异步处理提高系统性能(削峰、减少响应所需时间)

  14. 降低系统耦合性

  15. 使用消息队列带来的一些问题

  16. JMS两种消息模型

  17. JMS 五种不同的消息正文格式

  18. 常见的消息队列对比

  19. 什么是 Dubbo?为什么要用 Dubbo?

  20. 什么是 RPC?RPC原理是什么?

  21. Dubbo 工作原理?

  22. 解释一下什么是负载均衡?

  23. 看看 Dubbo 提供的负载均衡策略?

  24. zookeeper宕机与dubbo直连的情况?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值