首页
题库
公司真题
专项练习
面试题库
在线编程
面试
面试经验
AI 模拟面试
简历
求职
学习
基础学习课
实战项目课
求职辅导课
专栏&文章
竞赛
我要招人
发布职位
发布职位、邀约牛人
更多企业解决方案
AI面试、笔试、校招、雇品
HR免费试用AI面试
最新面试提效必备
登录
/
注册
wjw_steve
江苏大学 Java
发布于北京
关注
已关注
取消关注
@Java三段:
意难平!面试小米,一步之遥...
前几天面试小米,都三面了,本来以为稳了,但没想到最后还是挂了。按往年的经验来看,小米相比与其他互联网大厂来说,面试的难度比较低,而且薪资也比较低,所以拿到 Offer 的概率还是很大的。但今年这个情况,这位同学还是硕士身份,最后还是挂在三面了,确实挺可惜的。那咱们今天来看看,最近小米面试的真题吧,带大家看看小米的面试难度。1.电商系统开发中都遇到了哪些问题?电商系统遇到的常见问题:高并发 -> 缓存、限流、熔断。库存问题:超卖:限流、分布式锁、Redis Lua(先判断库存 -> 减库存 + 加订单)、使用数据库 update 操作库存。少卖:及时对账系统 -> 人工介入处理。弱网支付问题:支付平台提供回调方法进行支付状态的刷新、手动触发主动出查询得到支付状态、定时任务进行刷新。刷单:添加图形验证码、IP 黑名单。重复订单问题:业务实现幂等性判断、数据库的唯一约束。2.怎么用Redis实现秒杀业务?Redis Lua(先判断库存 -> 减库存 + 加订单)。3.为什么Redis单线程执行还这么快?原因有以下几个:基于内存操作。Redis 瓶颈是在内存和带宽,而不是在 CPU 操作。Redis 使用多路复用的 IO。避免多线程切换和过度争抢。4.Redis如何扫描前缀相同的key?Redis 查询前缀相同的 Key 实现方式:keys -> keys user*。scan -> scan 0 math user* count 100。5.Redis的keys和scan有什么区别?keys 查询所有的匹配数据,scan 是可以查询部分数据。6.如何使用Redis实现分布式锁?分布式锁实现:原始方式:setnx key true(死锁)/set key true ex 30 nx(锁误删)-> 锁重入问题。Redisson 框架实现方式:Redis + Lua 实现。7.长连接的好处与坏处?长连接优点:避免了重复创建和销毁连接。提高传输效率。实现实时传输。节省了系统资源的浪费。长连接缺点:占用了更多的资源。增加了服务器的压力。对网络环境的要求是比较高。8.TCP和HTTP有什么区别?TCP VS HTTP:层级不同:HTTP 属于应用层协议;TCP 属于传输层的协议。数据传输方式不同:HTTP 传输文本或二进制文件;TCP 传输的是数据流。9.说说HTTPS的执行流程?HTTPS 执行流程:客户端(浏览器)发送 HTTPS 请求到服务器端。服务器端使用非对称加密,产生一个公钥,将公钥和 CA 证书给到客户端。客户端验证 CA 证书真伪,使用对称加密生成一个共享秘钥,使用刚才的公钥将共享秘钥进行加密,将加密信息发送给服务器端。服务器端得到信息之后,使用非对称加密私钥进行解密,得到对称加密的共享秘钥进行通讯。10.说说ThreadLocal底层实现?ThreadLocal 底层是通过 ThreadLocalMap 实现,key -> ThreadLocal;value -> 需要存储的值。11.ThreadLocal父线程和子线程的数据传递?new InheritableThreadLocal();12.为什么HashMap是线程不安全的?HashMap 不是线程安全的原因:JDK 1.8 之前 -> 链表死循环问题、数据覆盖的问题。JDK 1.8 之后 -> 数据覆盖的问题。13.synchronized和volatile有什么区别?synchronized VS volatile:保证线程安全不同:synchronized 能保证线程安全;volatile 不能保证线程安全。底层实现不同:synchronized 底层实现 -> JVM Monitor(监视器)-> C++ ObjectMonitor -> 操作系统 Mutex Lock。volatile 底层实现 -> 可见性(MESI 协议)、顺序性(内存屏障)。14.说说ThreadPoolExecutor的参数?ThreadPoolExecutor 参数:核心线程数。最大线程数(核心线程数+临时线程数)。临时线程在空闲时间可以存活的最大时间。参数三的单位描述。任务队列。线程池的创建工厂。拒绝策略。15.说说ThreadPoolExecutor运行机制?运行机制(当任务来了之后的执行流程):判断核心线程数是否已满;如果未满创建核心线程执行任务;如果满了执行后续操作。判断任务队列是否已满;如果未满将任务添加到队列;如果满了执行后续流程。判断最大线程数是否已满;如果未满创建临时线程执行任务;如果满了执行后续流程。执行拒绝策略(内置4种拒绝策略+自定义的拒绝策略)。16.RocketMQ和Kafka有什么区别?RocketMQ VS Kafka 主要区别:吐吞量区别:Kafka 吞吐量最高,到达单机百万级的吞吐;RocketMQ 吐吞量是十万到百万级。功能上区别:RocketMQ 本身支持死信队列、延迟队列、支持消息推和拉取消息;Kafka 本身不支持死信队列、延迟队列、消息获取方式只能是消费者自己来拉取。17.说说RocketMQ的重试机制?RocketMQ 重试机制:生产者重试:生成者发送消息的类型有同步发送、异步发送、单次发送(oneway),但模式为同步发送、异步发送才有消息重试机制。消费者重试:消费者模式有广播模式和集群模式;广播模式不会进行消息重试,它只会记录警告信息;集群模式会进行消息重试(通过延迟任务来实现消息重试,默认情况下如果重试超过 16 次就会将此消息存到死信队列)。18.说说MySQL的事务?事务特性:一致性持久化原子性隔离性读未提交:存在脏读、不可重复读和幻读问题。读已提交:不存在脏读问题,但依然存在不可重复读和幻读的问题。可重复读(MySQL 默认的隔离级别):不存在脏读问题、不可重复读,依旧存在幻读问题。串行化:不存在脏读问题、不可重复读、幻读问题,但执行效率不高。19.说说MySQL的优化?explain有什么用?MySQL 优化措施:使用合适的查询语句,不要所有的都使用 select *。使用合适的数据类型。正确使用索引:该创建索引的创建索引。查询时一定要正确的触发索引。数据量大分库分表。使用分布式数据库,例如 TiDB。20.SpringCloud有哪些组件?Spring Cloud 包含的组件:注册中心:Spring Cloud Alibaba Nacos、Spring Cloud Netflix Euruka。配置中心:Spring Cloud Alibaba Nacos。网关:Spring Cloud Gateway。负载均衡器:Spring Cloud LoadBalancer。Restful 请求:Spring Cloud Openfeign。限流、熔断:Spring Cloud Alibaba Sentinel。分布式锁事务:Spring Cloud Alibaba Seata。分布式链路追踪系统:Skywalking。21.Nacos和Euruka的区别?Nacos VS Euruka 主要区别:功能上不同:Nacos 既提供注册中心又提供配置中心;Euruka 只有注册中心。通讯方式不同:Nacos 通讯方式是依靠 Netty 实现的长连接;Euruka 短连接+定时任务。CAP 理论支持不同:Nacos 默认是 AP 模式,但它支持手动设置 CP 模式;Euruka 只支持 AP 模式。健康检查机制不同:Nacos 健康检查机制(默认临时实例),每 5s 上报一次健康状况;15s 未上报任务不健康;30s 会剔除此实例;Euruka 健康检查机制,每 30s 上报一次健康状况;60s 未收到认为不健康;90s 未收到剔除此实例。22.Nacos怎么保证数据一致性的?Nacos 通过 Raft 实现 Leader 节点的选举,由 Leader 节点将数据同步给所有的普通节点,以保证数据的一致性的。23.反向代理是什么?反向代理定义:用于客户端和服务器端进行通讯,代理服务器端的一种代理,可以隐藏真实的服务器地址。反向代理的经典实现就是 Nginx。优点:反向代理服务器可以有缓存,增加查询的效率。可以实现负载均衡,从而提升服务器的 QPS,实现服务器的水平扩展。反向代理通常自带健康检查机制,可以帮你正确的访问健康的服务实例。隐藏真实服务器的地址,一定程度的保证了服务器的安全性。24.Spring事务是怎么实现的?Spring 事务实现方式:编程式事务声明式事务:动态代理实现 -> 1.拦截目标方法;2.在方法执行前开启事务;3.如果方法执行期间出现异常回滚事务;4.在方法执行完之后没有异常,提交事务。25.SpringBoot自动装配的实现流程?Spring Boot 实现流程:启动 Spring Boot 项目时,执行 @SpringBootApplication 注解类。去框架资源文件 spring.factories 读取需要自动装配的类。查找自动装配类的 @Configuration + @Condition 条件注解,如果满足自动装配的条件,将此类通过反射机制创建,并放到 IoC 容器,反之则不创建。参考 & 鸣谢javacn.site
点赞 50
评论 2
全部评论
推荐
最新
楼层
暂无评论,快来抢首评~
相关推荐
07-23 16:58
门头沟学院 嵌入式软件开发
疫情毁了我的竞赛梦
本人电子信息工程专业,在大二的时候好不容易鼓起勇气参加了电子设计大赛,花了三个月的时间速成了51,32单片机和一些硬件知识,结果在开赛前疫情来了,我在网上买的模块和器件全卡在半路上了,最终比赛改成线上举行,我也没有实物,就只能靠着PPT向评委展示我的“伟大构思”,最后草草收场
校园里的破防时刻
点赞
评论
收藏
分享
07-23 14:56
门头沟学院 客户端其它
遇见对的人,更重要
说个普遍存在的现象,现在中大厂校招中,本科生的比例正在逐步降低,无论你是92还是双非,这都将加剧竞争压力。以中厂传音控股举例,今年25届入职研究生比例较24届入职研究生人数增加50%,而这50%的人,去年是本科生啊,之前我以为,企业招收92和研究生是为了出去宣传好看,但是后面才意识到自己这种想法挺可笑的。企业之所以这么做,是因为想降低容错率,快速招到符合岗位需求的优秀人才,所以使用学历衡量这种相对有效准确的筛选方式。说到学历就要说高考,我高中的时候学英语死活学不会,背英语单词就是记不下来,背完忘,什么艾宾浩斯记忆曲线屁用没有,证明啥,一个是IQ不行,一个是天赋不在此,时至今日我也没找到我的天赋...
码农索隆:
都猛劲子冲,秋招你们一定能拿到心仪的offer。
校招阶段,学历VS技术哪...
点赞
评论
收藏
分享
06-30 08:10
福州外语外贸学院 Java
27届求拷打点评
本人目前大三,想找一份短期实习(2-3个月),一直在投简历但是没有一个有后续🥲发这篇帖子想得到大佬的指导,提供一些简历修改的意见、投递技巧和日后学习路线建议。
Cools0812:
两个项目+实习 不如一个苍穹外卖 可以多沉淀一下
点赞
评论
收藏
分享
06-16 18:34
美团_到店事业群_高级切图工程师(准入职员工)
再见啦我的团
早上十点发的邮件 下午解约完成再见互联网👋👋👋
烤点老白薯:
你要是测试就好了
点赞
评论
收藏
分享
07-25 10:20
武汉理工大学 新材料/环保技术
拓竹提前批挂
投递拓竹科技等公司10个岗位
点赞
评论
收藏
分享
评论
点赞成功,聊一聊 >
点赞
收藏
分享
评论
提到的真题
返回内容
全站热榜
更多
1
...
大模型应用开发面经 (5年经验)
1.5W
2
...
实习都是CRUD怎么包装
4584
3
...
滴滴提前批
3778
4
...
读博的尽头是什么?分享我的选择和经历
3157
5
...
百度提前批一面(秋招第一场也估计是压力最大的)
3016
6
...
【07.29更新】能救一个是一个!26届毁意向毁约裁员黑名单
2470
7
...
团孝子启动ing!
2404
8
...
秋招首凉-腾讯TEG 云架构平台提前批
2122
9
...
字节懂车帝 后端实习一面
1763
10
...
实习生工作越做越多是正常的吗……
1569
创作者周榜
更多
正在热议
更多
#
26届的你,投了哪些公司?
#
9522次浏览
135人参与
#
我对___祛魅了
#
19308次浏览
191人参与
#
中兴秋招
#
188547次浏览
2124人参与
#
如何快速融入团队?
#
6987次浏览
89人参与
#
通信/硬件求职避坑tips
#
85719次浏览
868人参与
#
和同事相处最忌讳的是__
#
9704次浏览
105人参与
#
你跟室友的关系怎么样?
#
1826次浏览
44人参与
#
简历上的经历如何包装
#
7562次浏览
214人参与
#
工作中哪个瞬间让你想离职
#
40184次浏览
331人参与
#
什么样的背景能拿SSP?
#
11252次浏览
93人参与
#
你遇到最难的面试题目是_
#
2513次浏览
55人参与
#
你最讨厌面试问你什么?
#
6168次浏览
115人参与
#
职场常用语录大全
#
5903次浏览
42人参与
#
我和mentor的爱恨情仇
#
61329次浏览
373人参与
#
大疆今年的机械笔试难吗?
#
43537次浏览
477人参与
#
打工人的精神状态
#
66174次浏览
1094人参与
#
哪些公司校招卡第一学历
#
91568次浏览
399人参与
#
元戎启行求职进展汇总
#
35511次浏览
270人参与
#
你最希望上岸的公司是?
#
133868次浏览
696人参与
#
实习生活中那些难忘的瞬间
#
161767次浏览
2408人参与
#
机械人,秋招第一次笔试的企业是哪家?
#
42918次浏览
339人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务