一天流程面完京东后端

部门:京东物流
技术与数据智能部
4.1更新已发offer

流程:
投递约面3.28
一面上午九点二十
二面上午十点
hr面下午三点

流程快的难以置信,面试时间大约10-20分钟,只聊了实习经历没有单独的八股,面试官很好,约的9:20然后他9:15就提前来了,看到来的更早还说迟到了,二面的领导也很和蔼,反问具体业务也特别详细的介绍。

由于确实没有面到什么八股,就把之前准备京东整理的一些面经发一下吧

1、增大堆内存命令,增大栈内存命令
堆内存
- -Xms:用于设置 JVM 堆内存的初始大小。
- -Xmx:用于设置 JVM 堆内存的最大大小。
栈内存
- 可使用 -Xss 参数来调整栈内存大小。

2、MyBatis $与#的区别有哪些
#:它是预编译的占位符。MyBatis 在处理# 占位符时,会把 SQL 语句和参数分开处理。先将 SQL 语句中的 # 占位符替换为 ?,接着使用 PreparedStatement 来执行 SQL 语句,把参数值作为 PreparedStatement 的参数传入。这样可以有效防止 SQL 注入攻击。
$是直接替换占位符。MyBatis 会直接把 $ 占位符替换为实际的参数值,而不进行预编译。这意味着参数值会原样插入到 SQL 语句中。

3、使用$如何防止sql注入
- 在将参数传递给 MyBatis 之前,要对参数进行严格的过滤和验证,确保参数值符合预期。例如,若参数是表名或列名,可预先定义一个合法的名称列表,只有在列表中的名称才允许使用。
- 借助正则表达式来验证参数值,保证其只包含合法的字符。比如,对于表名和列名,通常只允许包含字母、数字和下划线。
- 可以自定义 MyBatis 拦截器,在拦截器中对使用 $ 的 SQL 语句进行额外的检查和处理。

4、MyBatis如何设置超时时间
- 可以在 MyBatis 的全局配置文件(通常是 mybatis-config.xml)里设置超时时间,此设置会对所有的 SQL 语句生效。
- 也能在 Mapper XML 文件里针对具体的 SQL 语句设置超时时间,这种设置方式会覆盖全局配置中的超时时间。

5、MyBatis如何实现分页效果
- 手动在 SQL 语句中添加分页逻辑,不同数据库的分页语法有所不同。例如,MySQL 使用 LIMIT 关键字
- 使用第三方分页插件,如 PageHelper,它会自动拦截 SQL 语句并添加分页逻辑。

6、PageHelper插件原理,哪个包提供的
1. 拦截器注册:PageHelper 借助实现 MyBatis 的 Interceptor 接口,创建一个拦截器类。在配置 MyBatis 时,会把这个拦截器注册到 MyBatis 的拦截器链中。当执行 SQL 查询时,MyBatis 会按照拦截器链的顺序依次调用各个拦截器。
2. 分页参数设置:PageHelper.startPage(pageNum, pageSize) 方法来设置分页参数,这些参数会保存在threadlocal中
3. sql拦截和修改:拦截 Executor 的 query 方法。在拦截器的 intercept 方法中,会从 ThreadLocal 里获取之前设置的分页参数。对原先的sql添加limit等参数
4. 执行sql命令
5. 清除threadlocal

7、深分页怎么优化?
数据库层面
- 覆盖索引,查询所需要的字段都包含在索引中,数据库可以直接从索引中获取数据,而无需回表查询
- 嵌套查询,先去查主键id,然后select *
- 如果是递增的,可以记录之前的id,然后条件里面添加where id > **
业务层面
- 缓存层处理
- 前端分页限制

8、雪花算法有什么问题?
时间回拨:服务器的时间出现回拨,即时间被调整到过去的某个时刻,就可能导致生成的 ID 出现重复
解决方案:
- 如果时间差的不多的话,暂停ID的生成,然后等待时间恢复
- 主机号那个地方,选出3位,当回退的时候序号+1

9、C10k 问题是什么,C10M呢
C10k 问题是指服务器如何支持 10k(10,000)个并发连接的问题
C10M 则是指服务器如何实现处理 10M(10,000,000)个并发连接的问题

10、什么是同步和异步io,什么是阻塞和非阻塞io
同步IO:程序发起一个 I/O 操作后,程序需要等待 I/O 操作完成后才能继续执行后续代码
异步IO:程序发起一个 I/O 操作后,不必等待 I/O 操作完成,可以继续执行后续代码,后续用回调函数、信号等方式通知程序
阻塞IO:程序发起一个 I/O 操作后,如果 I/O 设备没有准备好数据,程序会被挂起,处于等待状态,直到 I/O 设备准备好数据并完成数据传输,程序才会继续执行。
非阻塞IO:程序发起一个 I/O 操作后,如果 I/O 设备没有准备好数据,程序不会被挂起,而是会立即返回一个错误信息,程序可以继续执行其他任务,通过轮询的方式来检查IO是否准备好数据。

11、对AOP的理解
面向切面编程,它是一种编程范式
是对面向对象编程的补充
核心概念涉及:
切面:和业务逻辑没关,但是被多个模块调用的一些逻辑,比如日志信息、事务管理
连接点:程序运行可以插入切面的点,比如是方法调用、返回、抛出异常的关键点
通知:就是切面在连接点要干的事情。有前置通知、后置通知、环绕通知等
实现方式主要静态代理和动态代理,静态代理就是在编译那一步去做的,对java代码进行修改,动态代理通过代理类把对应逻辑织入到目标链路中。主要有jdk代理和cglib代理两种。

12、如果甲方很强势,给你一个需求,但是这个需求确实不能按期完成,你会怎么做?

13、在实习的过程中是否有很难对接的情况,这种情况是怎么处理的呢

#牛客创作赏金赛##京东##京东求职进展汇总##牛客AI配图神器#
全部评论
tql了字节
1 回复 分享
发布于 03-28 23:40 北京
接好运
点赞 回复 分享
发布于 03-31 12:01 北京
请问楼主接了offer了吗打算去吗
点赞 回复 分享
发布于 03-31 19:55 辽宁
佬是实习还是春招
点赞 回复 分享
发布于 03-31 22:43 广东
佬,请问是什么bg?二面要写代码吗?
点赞 回复 分享
发布于 04-02 16:46 辽宁

相关推荐

03-29 22:01
中南大学 Java
## 3.25美团一面1. 自我介绍2. redis的使用场景,以及为什么使用redis?3. Zset的底层结构是什么?4. 为什么Zset要使用两种结构来实现?5. jemeter压测比较关注什么数据?6. 高并发场景的稳定性你是怎么理解的?7. 介绍一下秒杀的流程?8. 如果出现库存扣减成功但是异步调用失败了怎么办?9. 还是库存扣减成功了,但是调用mq的rpc接口失败了,怎么办?(我回答的是事务,回滚)10.承接上问,如果因为上述的问题,库存扣减了,mq没有接收到消息,导致库存不一致怎么办?11.redis的k,v结构是怎么设计的?12.怎么保证redis的数据不会丢失?13.主从集群有延迟,主节点刚存进去数据,还没同步就挂了,这时从节点没有数据, 那怎么办?14.mysql,订单表怎么设计的?15.如果活动很火爆,有100万QPS的访问量,只持续一分钟,或者5分钟的话,只有一个节点的话根本扛不住,怎么处理?16.场景题:大公司里给员工发工资,十分种以内发十万个人的工资。有一个表存的是公司的账户,里面存的金额。另一个表是员工表,记录的员工的信息。怎么处理?17.算法:删除链表倒数第N个节点(核心代码模式)## 3.26美团二面1.自我介绍2.聊以前的经历(高考,考研)3.项目中,你写了个异步处理和加redis缓存将相应时间降低50%,怎么个处理方式,以及是什么业务场景?4.什么样的场景使用消息对立比较合适?或者哪些任务你需要用消息队列去异步处理,你是怎么划分的?5.redis的哪些原理和特性,导致它是个高性能缓存工具?6.介绍自己研究生期间的成果,这个成果的想法怎么产生的,为什么业界的大公司都没想打你能想到。7.本地缓存和分布式缓存的区别,以及使用场景?8.radis的数据一致性相对于本地缓存比较好,是怎么保证?9.怎么保证redis和数据库的数据一致性?(先更新数据库再删除缓存)10.那为什么不先改数据库数据再去更新缓存呢?11.mq在什么场景下使用?12.设计分布式锁怎么去考量,比如key,value的设计,怎么避免死锁?13.rpc从发起到接收,用哪些协议,有哪些阶段哪些流程?14.讲一下高并发架构的设计15.对ai的理解16.闲聊(无手撕)#牛客AI配图神器##面经java##美团约面#
点赞 评论 收藏
分享
评论
5
74
分享

创作者周榜

更多
牛客网
牛客企业服务