拼多多面经(完结)


拼多多面经(完结)
同学 1
一面
1.jdk 动态代理和 cglib 动态代理有什么区别?为什么
// 代理实例的获取
Enhancer enhancer = new Enhancer();
// 设置需要创建子类的类,final/private 方法不能被代理,这个接口不管用?
enhancer.setInterfaces(new Class[] {HelloService.class});
// 需要创建的父类,只能传递一个
enhancer.setSuperclass(superClass);
enhancer.setCallbackFilter(new CallbackFilter() {
@Override
public int accept(Method method) {
// callback 数组的下标
return 1;
}
});
enhancer.setCallbacks(new Callback[]{callback,callback});
// EnhancerTest 的子类
return (T) enhancer.create();
Proxy.newProxyInstance(classLoader, proxiedInterfaces 可以传递多个接口,
invocationHandler);
2.threadlocal 怎么用,可能会有哪些问题?怎么避免内存泄漏。底层怎么优化的。key 是
弱引用,可以为 null,那么 value 呢?怎么解决呢?用 threadLocal 有什么好处?
• 内存泄漏。remove
• 重复 new。static 定义 threadLocal,value 使用弱引用
• 数据会串,上下文污染
• 上下文丢失问题。例如底层 remove 了,上层依然依赖这个上下文。
• 跨线程池问题
• 并发问题。例如传递的是一个复杂对象,需要深拷贝
3.spring 事务有哪些传播级别
答案
REQUIRED:如果当前存在事务,则加入该事务;如果当前没有事务,则创建一个新事
务。这是默认的传播级别。
SUPPORTS:如果当前存在事务,则加入该事务;如果当前没有事务,则以非事务方式执
行。
MANDATORY:如果当前存在事务,则加入该事务;如果当前没有事务,则抛出异常。
REQUIRES_NEW:始终创建一个新的事务,并挂起当前事务(如果存在)。
NOT_SUPPORTED:以非事务方式执行操作,如果当前存在事务,则将其挂起。
NEVER:以非事务方式执行操作,如果当前存在事务,则抛出异常。
NESTED:如果当前存在事务,则在嵌套事务中执行;如果当前没有事务,则创建一个新
的事务。嵌套事务可以独立提交或回滚,但也会受到外部事务的影响。
4.微服务有什么好处,带来哪些问题,业务里分布式事务怎么做的?
• 链路追踪,服务治理(重试、熔断、超时设置、限流),分布式问题,一致性问题
• 过度微的话,可能一次需求会改很多个服务。浪费资源
• 序列化、反序列化等耗时
• 原先直接调用没问题,改为平台后,可能导致重复调用,循环调用,链路变长
• rpc 交互,sdk 升级可能存在问题,例如不能用枚举交互,不能使用 Builder,Builder
默认值不生效。
• 对于下游需要引入防腐层。
5.内存 gc 怎么排查,有哪些工具,怎么优化的?
6.哪些场景会保存到老年代?为什么达到 15 年龄就要升级?
• 大对象
• 新生代 gc,存活对象达到晋升年龄
• 触发新生代担保机制,新生代回收后 survivor 放不下,直接放到老年代
7.数据权限怎么设计的?是否通用
部门是挂在角色上
8.ES 的怎么解决深分页?
9.springboot 怎么实现自动化配置?
10.给你两个递增数据,合并成一个数组,第一个数组含有所有的空间,只能用这两个数
组,不能用额外的空间
11.spring 怎么去做监控,错误码体系
12.java 的异常体系
13.go 中 channel 和 mutex 实现有什么区别?
14.怎么实现幂等?
• 上游生成一个幂等的 uuid,作为 key,放到 redis 里,默认 120 毫秒过期
• update 数据时增加条件,如果状态扭转了,则不往下走
• jackson 序列化所有请求参数,得到一个 md5 作为 key,是否会调整参数的位置,但
是参数是相同的?
• 插入时,增加唯一键;删除时判断接口
• aop 对上面包装一下,减少侵入性