软件开发面试题及答案.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

软件开发面试题及答案

一、基础概念类(初中级)

问:什么是内存泄漏?举一个你工作中遇到过的场景

答:内存泄漏是指程序中已不再使用的对象无法被垃圾回收机制回收,导致内存占用持续增加的问题。比如之前做定时任务时,用static修饰了ArrayList存储临时数据,每次任务执行后没清空列表,随着任务次数增加,列表里的对象一直累积,一周后服务器内存占比从30%升到80%,最后通过在任务结束时调用list.clear()解决。

问:HTTP401和403状态码有什么区别?实际开发中怎么处理?

答:401是“未授权”,表示客户端没提供身份凭证(比如没传Token);403是“禁止访问”,表示客户端有凭证但权限不够(比如普通用户想访问管理员接口)。处理时,401通常引导用户登录,403直接返回“无权限操作”提示,我们项目里会在拦截器里判断,401跳登录页,403返回JSON格式的错误信息。

问:MySQL里InnoDB和MyISAM引擎的核心区别是什么?选哪个?

答:最关键的是事务支持和锁粒度。InnoDB支持事务(ACID)和行级锁,MyISAM不支持事务,只有表级锁。实际选InnoDB,比如订单表必须保证事务一致性(创建订单时扣库存、减余额要同时成功或失败),用MyISAM的话一旦中间出错,数据就会不一致,之前公司老项目用MyISAM,出现过订单创建成功但库存没扣的问题,后来全换成了InnoDB。

二、实际开发类(中高级)

问:项目里怎么解决并发更新数据的问题?举个例子

答:主要用乐观锁或悲观锁。比如商品库存扣减,之前没处理并发时,多个用户同时下单会超卖。后来用了乐观锁,在库存表加version字段,更新时SQL写updateproductsetstock=stock-1,version=version+1whereid=?andversion=?andstock0,如果更新行数为0,说明有并发冲突,就重试3次,还失败就提示“当前下单人数过多”。

问:Redis缓存穿透怎么解决?你项目里是怎么做的?

答:缓存穿透是指请求查询不存在的数据(比如查id=-1的用户),缓存和数据库都没数据,导致请求全打数据库。我们项目用了两种方案:一是空值缓存,查不到数据时往Redis存个空值(比如key:user:-1,value:null),设置5分钟过期;二是布隆过滤器,把所有存在的用户id存在布隆过滤器里,请求先过过滤器,不存在的直接返回,减少数据库压力。

问:SpringBoot项目里,怎么处理全局异常?说下具体实现

答:用@ControllerAdvice+@ExceptionHandler。我们项目里写了个GlobalExceptionHandler类,加@ControllerAdvice注解,然后写不同的方法处理不同异常:比如@ExceptionHandler(BusinessException.class)处理业务异常(像“库存不足”),@ExceptionHandler(Exception.class)处理通用异常。方法里用ResponseEntity返回统一格式的响应,包含状态码、消息和时间戳,前端直接拿这些字段展示,不用每个接口单独写try-catch。

三、调试排查类(实战型)

问:线上接口突然响应变慢,怎么排查问题?步骤是什么?

答:分四步查:①先看网络,用Postman测接口响应时间,同时ping服务器看延迟,排除网络波动;②查服务器资源,用top命令看CPU、内存占用,df-h看磁盘是否满了,之前遇到过磁盘满导致日志写不进去,接口卡顿的情况;③查应用日志,看error.log有没有报错,再看接口对应的业务日志,比如有没有慢SQL,用explain分析SQL执行计划,之前有个接口因为没加索引,查询耗时从100ms升到5s,加索引后恢复正常;④查缓存,看Redis有没有命中率下降,或者缓存雪崩,比如大量key同时过期,导致请求全打数据库。

问:项目上线后出现数据不一致,比如订单状态是“已支付”但库存没扣,怎么定位原因?

答:先查日志,看支付成功后的库存扣减逻辑有没有执行:①看支付回调日志,有没有调用库存接口;②看库存服务日志,有没有收到扣减请求,有没有报错(比如SQL异常、参数错误);③如果日志显示库存接口没调用,可能是支付回调后代码没执行(比如事务回滚、异步任务没触发);④如果日志显示库存接口调用了但没成功,查数据库执行记录,看扣库存的SQL有没有执行,有没有事务冲突;之前遇到过一次,是库存扣减时因为网络超时抛了异常,没做重试,后来加了重试机制和补偿任务,定时核对

文档评论(0)

151****9429 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档