大家问项目的时候都怎么回答啊?

八股倒是琢磨的很熟悉,问八股也都能扩展。但是一到项目就懵,确实是自己的项目,但是总是讲不好,比如讲一个功能,我能说出他是怎么做的,问为什么这样做其实好像答不出来,因为大家还有教程都是这样做的(当然这个例子不好,其实讲一下这个框架的优点就好,只不过是我一时想不起来其他的例子了,脑袋空空)
好像记性有点差,比如问我一个东西
“这个模块怎么实现的?”
“这个过程用到了哪些东西”
“为什么用到了这个?”
“用这个中间件的时候需要注意什么?”
“用这个中间件的时候出现了什么错误?”
“为什么会出现这个错误”
“那怎么解决呢?”
“如果这样可以解决,那我如何一开始就预防呢?”
“是的可以这样, 但是我们一般用另一种方法,你知道另一种方法预防的吗”
“那这个预防的过程中会出现哪些问题呢?”
反正就是一直深挖,我大概只能挖到第三四个问题,往后就答不出来,可能缺少发散思维,但是这个项目确实是自己做的,中间件用的也不少,他要是随机问的真的很难答出来,所以大家是怎么准备回答这个项目深挖的问题的?
全部评论
比如第五个,没有错误你就创造错误(不是太简单的错误),你可以说你现在的方法是进行优化后样子,之前可能会有精度丢失、数据传输不稳定等问题,对于你项目每一块实现的功能,相出起码两种可以实现的方法,对比一下各自的优势是什么,这样他问你的时候你可以展示出你对这个功能考虑过,并且会优化,而不是傻傻的就会用而已。这样他都没有问你后面问题的机会。
14 回复 分享
发布于 2023-08-19 22:17 吉林
m
2 回复 分享
发布于 2023-08-19 09:05 山东
同问
1 回复 分享
发布于 2023-08-19 10:36 北京
m
1 回复 分享
发布于 2023-08-18 17:03 重庆
m
1 回复 分享
发布于 2023-08-18 11:28 广东
m
点赞 回复 分享
发布于 2023-09-03 22:25 北京
m
点赞 回复 分享
发布于 2023-08-31 09:08 重庆
mmmm
点赞 回复 分享
发布于 2023-08-23 02:31 重庆
m
点赞 回复 分享
发布于 2023-08-19 13:39 江苏
m
点赞 回复 分享
发布于 2023-08-19 09:47 广东
点赞 回复 分享
发布于 2023-08-18 16:06 广东

相关推荐

05-23 15:16
已编辑
门头沟学院 Java
1,缓存架构?答:讲了一下redis在项目中的具体实现注:其实面试官想问的是多层架构2,redsi缓存击穿,穿透,雪崩怎么解决?答:击穿可以通过设置热key永不过期穿透可以使用缓存空值和布隆过滤器来解决雪崩可以通过给键设置基础时间值+随机时间值来解决注:缓存击穿还可以还通过互斥锁进行解决(性能较低)关于雪崩上面只说了大量key过期的问题 没有提到redis宕机解决方法:(1)设置多层架构(2)建立redis主从或集群(3)提前演练redis宕机 从而设计解决方法3,大量不存在的用户同时登录时会给数据库造成压力,怎么解决?答:使用redis缓存空值注:缓存空值不能有效解决这类缓存穿透问题这里要使用布隆过滤器进行拦截 更加有效在实际业务开发中最好俩者结合使用4,jwt?答:说了一下jwt的生成和解析以及结构5,讲讲乐观锁和悲观锁答:讲了一遍sychronized的底层实现从无锁->偏向锁->轻量级锁->重量级锁这里轻量级锁就是乐观锁 重量级锁就是悲观锁6,乐观锁和悲观锁最主要的区别?答:在低并发场景下乐观锁性能好在高并发场景下悲观锁性能好注:乐观锁是认为操作的时候没有线程和我并发操作通过cas判断 不会让你的线程挂起 可能会不断自旋去尝试获取锁悲观锁是认为有线程和我并发操作 拿不到锁线程就会进入阻塞状态直到拿到锁的线程释放锁后唤醒该线程7,sychronized和reentrantlock有什么区别?答:sychronized由jvm释放锁 reentrantlock手动释放sychronized不可重入 reentrantlock可重入(避免死锁)注:这里答错了sychronized可重入他们的主要区别在于sychronized不支持公平锁,不支持超时不可中断,不支持多条件sychronized是java内置的关键字 reentrantlock是由juc类库所提供的8,aop怎么理解?这里答的太乱了不清楚注:把那些非核心功能抽取出来封装成一个切面去掉冗余代码通过动态代理的方式 将需要注入切面的对象进行代理在进行调用的时候直接将公共逻辑注入侵入性较低1,缓存架构?答:讲了一下redis在项目中的具体实现注:其实面试官想问的是多层架构2,redsi缓存击穿,穿透,雪崩怎么解决?答:击穿可以通过设置热key永不过期穿透可以使用缓存空值和布隆过滤器来解决雪崩可以通过给键设置基础时间值+随机时间值来解决注:缓存击穿还可以还通过互斥锁进行解决(性能较低)关于雪崩上面只说了大量key过期的问题 没有提到redis宕机解决方法:(1)设置多层架构(2)建立redis主从或集群(3)提前演练redis宕机 从而设计解决方法3,大量不存在的用户同时登录时会给数据库造成压力,怎么解决?答:使用redis缓存空值注:缓存空值不能有效解决这类缓存穿透问题这里要使用布隆过滤器进行拦截 更加有效在实际业务开发中最好俩者结合使用4,jwt?答:说了一下jwt的生成和解析以及结构5,讲讲乐观锁和悲观锁答:讲了一遍sychronized的底层实现从无锁->偏向锁->轻量级锁->重量级锁这里轻量级锁就是乐观锁 重量级锁就是悲观锁6,乐观锁和悲观锁最主要的区别?答:在低并发场景下乐观锁性能好在高并发场景下悲观锁性能好注:乐观锁是认为操作的时候没有线程和我并发操作通过cas判断 不会让你的线程挂起 可能会不断自旋去尝试获取锁悲观锁是认为有线程和我并发操作 拿不到锁线程就会进入阻塞状态直到拿到锁的线程释放锁后唤醒该线程7,sychronized和reentrantlock有什么区别?答:sychronized由jvm释放锁 reentrantlock手动释放sychronized不可重入 reentrantlock可重入(避免死锁)注:这里答错了sychronized可重入他们的主要区别在于sychronized不支持公平锁,不支持超时不可中断,不支持多条件sychronized是java内置的关键字 reentrantlock是由juc类库所提供的8,aop怎么理解?这里答的太乱了不清楚注:把那些非核心功能抽取出来封装成一个切面去掉冗余代码通过动态代理的方式 将需要注入切面的对象进行代理在进行调用的时候直接将公共逻辑注入 侵入性较低不想写了 直接把问题都扔出来吧java线程池的七个参数?1. Java线程池,5核⼼、10最⼤、10队列,第6个任务来了是什么状态?任务扔到⼯作队列中2. 如果在第6个任务过来的时候,5个核⼼线程都已经空闲了呢?⼀样扔到队列(线程池只关注数量)3. 第16个任务来了怎么处理?创建⾮核⼼线程去处理第16个任务4. 第16个任务来了的时候,要是有核⼼线程空闲了呢?如果这个空闲的线程,将⼯作队列中的10个任务,取⾛了⼀个,变为了9个,那任务扔队列。如果空闲的线程还没来得及取⾛任务,投递时,队列⻓度依然为10,那还是创建⾮核⼼。5. 队列满了以后执⾏队列的任务是从队列头 or 队尾取?⼀般咱们的阻塞队列都是FIFO的,所以先进先出,从头取。6. 核⼼线程和⾮核⼼线程执⾏结束后,谁先执⾏队列⾥的任务?谁空闲了,并且去等待任务,谁先去执⾏队列⾥的任务。7.为什么⾮核⼼优先执⾏投递的任务?8.核⼼线程与⾮核⼼线程有什么区别?9.MySQL中如何实现数据的读⼀致性?10. MySQL的InnoDB引擎是如何通过⽇志实现事务的?11. MySQL崩溃恢复为什么不⽤binLog?12.Redis的事务了解吗?13.Redis 的持久化机制?总结:对底层的理解还是不够深入 之前没有了解过redis事务 有的时候答非所问容易跑题
点赞 评论 收藏
分享
评论
15
117
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务