70道阿里百度高频Java面试题(框架+JVM+多线程+算法+数据库)

简介: 70道阿里百度高频Java面试题(框架+JVM+多线程+算法+数据库)

基础与框架

1.String类能被继承吗,为什么
2.String,Stringbuffer,StringBuilder的区别?
3.ArrayList和LinkedList有什么区别
4.类的实例化顺序,比如父类静态数据,构造函数,字段,子类静态数据,构造函数,字段,他们的执行顺序
5.用过哪些Map,都有什么区别,HashMap是线程安全的吗,并发下使用的Map是什么,他们内部原理分别是什么,比如hashcode,扩容等
6.HashMap为什么get和set那么快,concurrentHashMap为什么能提高并发
7.抽象类和接口的区别,类可以继承多个类么,接口可以继承多个接口么,类可以实现多个接口么
8.什么情况下会发生栈内存溢出
9.什么是nio,原理
10.反射中,Class.forName和ClassLoader区别
11.tomcat结构,类加载器流程
12.讲讲Spring事务的传播属性,AOP原理,动态代理与cglib实现的区别,AOP有哪几种实现方式
13.Spring的beanFactory和factoryBean的区别
14.Spring加载流程
15.Spring如何管理事务的
image

多线程

1.线城池的最大线程数目根据什么确定
2.多线程的几种实现方式,什么是线程安全,什么是重排序
3.volatile的原理,作用,能代替锁么
4.sleep和wait的区别,以及wait的实现原理
5.Lock与synchronized 的区别,synchronized 的原理,什么是自旋锁,偏向锁,轻量级锁,什么叫可重入锁,什么叫公平锁和非公平锁
6.用过哪些原子类,他们的参数以及原理是什么
7.用过哪些线程池,他们的原理简单概括下,构造函数的各个参数的含义,比如coreSize,maxsize等
8.有一个第三方接口,有很多个线程去调用获取数据,现在规定每秒钟最多有10个线程同时调用它,如何做到。
9.spring的controller是单例还是多例,怎么保证并发的安全
10.用三个线程按顺序循环打印abc三个字母,比如abcabcabc
11.ThreadLocal用过么,原理是什么,用的时候要注意什么
12.如果让你实现一个并发安全的链表,你会怎么做
image

JVM相关

1.jvm中一次完整的GC流程(从ygc到fgc)是怎样的,重点讲讲对象如何晋升到老年代,几种主要的jvm参数等
2.你知道哪几种垃圾收集器,各自的优缺点,重点讲下cms
3.当出现了内存溢出,你怎么排错
4.JVM内存模型的相关知识了解多少
5.简单说说你了解的类加载器
6.JAVA的反射机制

网络

1.http1.0和http1.1有什么区别
2.TCP三次握手和四次挥手的流程,为什么断开连接要4次,如果握手只有两次,会出现什么
3.TIME_WAIT和CLOSE_WAIT的区别
4.说说你知道的几种HTTP响应码
5.当你用浏览器打开一个链接的时候,计算机做了哪些工作步骤
6.Linux下IO模型有几种,各自的含义是什么
7.TCP/IP如何保证可靠性,数据包有哪些数据组成
8.架构设计与分布式:
9.tomcat如何调优,各种参数的意义
10.常见的缓存策略有哪些,你们项目中用到了什么缓存系统,如何设计的,Redis的使用要注意什么,持久化方式,内存设置,集群,淘汰策略等
11.如何防止缓存雪崩
12.用java自己实现一个LRU
13.分布式集群下如何做到唯一序列号
14.设计一个秒杀系统,30分钟没付款就自动关闭交易
15.如何做一个分布式锁
16.用过哪些MQ,怎么用的,和其他mq比较有什么优缺点,MQ的连接是线程安全的吗
17.MQ系统的数据如何保证不丢失
18.分布式事务的原理,如何使用分布式事务
19.什么是一致性hash
20.什么是restful,讲讲你理解的restful
21.如何设计建立和保持100w的长连接?
22.解释什么是MESI协议(缓存一致性)
23.说说你知道的几种HASH算法,简单的也可以
24.什么是paxos算法
25.redis和memcached 的内存管理的区别
26.一个在线文档系统,文档可以被编辑,如何防止多人同时对同一份文档进行编辑更新
image

算法

1、10亿个数字里里面找最小的10个
2、有1亿个数字,其中有2个是重复的,快速找到它,时间和空间要最优
3、2亿个随机生成的无序整数,找出中间大小的值
4、遍历二叉树

数据库

1.数据库隔离级别有哪些,各自的含义是什么,MYsql默认的隔离级别是是什么,各个存储引擎优缺点
2.高并发下,如何做到安全的修改同一行数据,乐观锁和悲观锁是什么,INNODB的行级锁有哪2种,解释其含义
3.SQL优化的一般步骤是什么,怎么看执行计划,如何理解其中各个字段的含义,索引的原理?
4.数据库会死锁吗,举一个死锁的例子,mysql怎么解决死锁
5.MYsql的索引实现方式
6.聚集索引和非聚集索引的区别
7.数据库中 BTREE和B+tree区别

最后
欢迎大家一起交流,喜欢文章记得点个赞哟,感谢支持!

相关实践学习
消息队列RocketMQ版:基础消息收发功能体验
本实验场景介绍消息队列RocketMQ版的基础消息收发功能,涵盖实例创建、Topic、Group资源创建以及消息收发体验等基础功能模块。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
7天前
|
监控 Kubernetes Java
阿里面试:5000qps访问一个500ms的接口,如何设计线程池的核心线程数、最大线程数? 需要多少台机器?
本文由40岁老架构师尼恩撰写,针对一线互联网企业的高频面试题“如何确定系统的最佳线程数”进行系统化梳理。文章详细介绍了线程池设计的三个核心步骤:理论预估、压测验证和监控调整,并结合实际案例(5000qps、500ms响应时间、4核8G机器)给出具体参数设置建议。此外,还提供了《尼恩Java面试宝典PDF》等资源,帮助读者提升技术能力,顺利通过大厂面试。关注【技术自由圈】公众号,回复“领电子书”获取更多学习资料。
|
1天前
|
存储 人工智能 算法
解锁分布式文件分享的 Java 一致性哈希算法密码
在数字化时代,文件分享成为信息传播与协同办公的关键环节。本文深入探讨基于Java的一致性哈希算法,该算法通过引入虚拟节点和环形哈希空间,解决了传统哈希算法在分布式存储中的“哈希雪崩”问题,确保文件分配稳定高效。文章还展示了Java实现代码,并展望了其在未来文件分享技术中的应用前景,如结合AI优化节点布局和区块链增强数据安全。
|
3天前
|
算法 安全 Java
Java线程调度揭秘:从算法到策略,让你面试稳赢!
在社招面试中,关于线程调度和同步的相关问题常常让人感到棘手。今天,我们将深入解析Java中的线程调度算法、调度策略,探讨线程调度器、时间分片的工作原理,并带你了解常见的线程同步方法。让我们一起破解这些面试难题,提升你的Java并发编程技能!
43 16
|
8天前
|
存储 监控 算法
剖析基于Java算法驱动的智能局域网管控之道
本文探讨了基于Java语言的局域网控制方案,结合链表数据结构与令牌桶算法,解决设备管理和流量调度难题。通过链表灵活存储网络设备信息,实现高效设备管理;令牌桶算法则精准控制流量,确保网络平稳运行。二者相辅相成,为校园、企业等局域网提供稳固高效的控制体系,保障业务连续性和数据安全。
|
6天前
|
算法 搜索推荐 Java
【潜意识Java】深度解析黑马项目《苍穹外卖》与蓝桥杯算法的结合问题
本文探讨了如何将算法学习与实际项目相结合,以提升编程竞赛中的解题能力。通过《苍穹外卖》项目,介绍了订单配送路径规划(基于动态规划解决旅行商问题)和商品推荐系统(基于贪心算法)。这些实例不仅展示了算法在实际业务中的应用,还帮助读者更好地准备蓝桥杯等编程竞赛。结合具体代码实现和解析,文章详细说明了如何运用算法优化项目功能,提高解决问题的能力。
41 6
|
6天前
|
算法 Java C++
【潜意识Java】蓝桥杯算法有关的动态规划求解背包问题
本文介绍了经典的0/1背包问题及其动态规划解法。
31 5
|
Java Android开发
百度面试题的java实现
本文为原创,如需转载,请注明作者和出处,谢谢!     有一根27厘米的细木杆,在第3厘米、7厘米、11厘米、17厘米、23厘米这五个位置上各有一只蚂蚁。
897 0
|
20天前
|
监控 Java
java异步判断线程池所有任务是否执行完
通过上述步骤,您可以在Java中实现异步判断线程池所有任务是否执行完毕。这种方法使用了 `CompletionService`来监控任务的完成情况,并通过一个独立线程异步检查所有任务的执行状态。这种设计不仅简洁高效,还能确保在大量任务处理时程序的稳定性和可维护性。希望本文能为您的开发工作提供实用的指导和帮助。
82 17
|
30天前
|
Java
Java—多线程实现生产消费者
本文介绍了多线程实现生产消费者模式的三个版本。Version1包含四个类:`Producer`(生产者)、`Consumer`(消费者)、`Resource`(公共资源)和`TestMain`(测试类)。通过`synchronized`和`wait/notify`机制控制线程同步,但存在多个生产者或消费者时可能出现多次生产和消费的问题。 Version2将`if`改为`while`,解决了多次生产和消费的问题,但仍可能因`notify()`随机唤醒线程而导致死锁。因此,引入了`notifyAll()`来唤醒所有等待线程,但这会带来性能问题。
Java—多线程实现生产消费者

热门文章

最新文章