团队中做代码评审主要要核查哪些指标?

提问者:帅平 问题分类:微服务
团队中做代码评审主要要核查哪些指标?
18 个回答
影子爱人
影子爱人
考察远程调用是否处理完善:
1、不要把超时当作失败处理: 远程调用可能会失败,比如网络中断、超时等等。开发者需要注意远程调用返回的错误码,除非是明确的失败,如果仅仅是超时等问题,不能当作失败处理!而是应该发起查询,确认是否成功,再做处理。
2、异常处理:远程调用可能会抛出异常,例如由于服务端错误或请求格式不正确等。因此,开发人员需要确保能够捕获和处理这些异常,以避免系统崩溃或数据丢失。
3、网络安全:由于远程调用涉及网络通信,因此开发人员需要考虑网络安全的问题,例如数据加密、认证、访问控制等。尽可能使用安全的协议,例如HTTPS 或 SSL/TLS。
4、服务质量:远程调用可能会影响系统的性能和可用性。因此,开发人员需要确保服务的质量,例如避免过度使用远程调用、优化数据传输、实现负载均衡等。
5、版本兼容:由于远程调用涉及不同的进程或计算机之间的通信,因此开发人员需要注意服务端和客户端之间的版本兼容性。尽可能使用相同的接口和数据格式,避免出现不兼容的情况。
6、尽量避免for循环远程调用: 尽量避免for循环远程调用,而应该考虑实现了批量功能的接口。
发布于:6个月前 (02-28) IP属地:未知
情若相惜
情若相惜
考察代码是否臃肿:
1、大量重复代码(抽公用方法,设计模式)
2、方法参数过多(可封装成一个DTO对象)
3、方法过长(抽小函数)
4、判断条件太多(优化if...else)
5、不处理没用的代码(没用的import)
6、避免过度设计
发布于:6个月前 (02-28) IP属地:未知
宁愿短发披肩
宁愿短发披肩
考察中间件的使用注意事项,比如数据库:
1、关注数据库连接池参数设置、超时参数设置是否合理
2、避免循环调用数据库操作
3、如果不分页,查询SQL时,如果条数不明确,是否加了limit限制限制
4、数据库的返回是否判空处理
5、数据库慢SQL是否有监控
6、表结构更新是否做兼容,存量表数据是否涉及兼容问题考虑
7、索引添加是否合理
8、是否连表过多等等

比如redis:
1、Redis的key使用是否规范
2、Redis 异常捕获以及处理逻辑是否合理
3、Redis连接池、超时参数设置是否合理
4、Redis 是否使用了有坑的那些命令,如hgetall、smember
5、是否可能会存在缓存穿透、缓存雪奔、缓存击穿等问题。
发布于:6个月前 (02-28) IP属地:未知
心尖爱人
心尖爱人
考察幂等处理,比如开户接口,多次请求过来的时候,需要先查一下该客户是否已经开过户,如果已经开户成功,直接返回开户成功的报文。如果还没开户,就先开户,再返回开户成功的报文。这就是幂等处理。
发布于:6个月前 (02-28) IP属地:未知
扎起头发是矫情
扎起头发是矫情
考察事务控制规范:
1、一般推荐使用编程式事务,而不是一个注解 @Transactional的声明式事务。因为 @Transactional有很多场景,可能导致事务不生效。
2、事务范围要明确,数据库操作必须在事务作用范围内,如果是非数据库操作,尽量不要包含在事务内。
3、不要在事务内进行远程调用(可能导致数据不一致,比如本地成功了,但是远程方法失败了,这时候需要用分布式事务解决方案)
4、事务中避免处理太多数据,一些查询相关的操作,尽量放到事务之外(避免大事务问题)
发布于:6个月前 (02-28) IP属地:未知
穿越到古代找美女
穿越到古代找美女
考察代码的安全性,例如:
1、输入校验:应该始终对任何来自外部的输入数据进行校验,以确保它们符合预期并且不会对系统造成伤害。校验应该包括检查数据的类型、大小和格式。
2、防范SQL注入攻击:在使用SQL查询时,应该始终使用参数化查询或预处理语句,以防止SQL注入攻击。
3、防范跨站脚本攻击(XSS): 在Web应用程序中,应该始终对输入的HTML、JavaScript和CSS进行校验,并转义特殊字符,以防止XSS攻击。
4、避免敏感信息泄露: 敏感信息(如密码、密钥、会话ID等)应该在传输和存储时进行加密,以防止被未经授权的人访问。同时,应该避免在日志、调试信息或错误消息中泄露敏感信息。
5、防范跨站请求伪造(CSRF): 应该为所有敏感操作(如更改密码、删除数据等)添加CSRF令牌,以防止未经授权的人员执行这些操作。
6、防范安全漏洞: 应该使用安全性高的算法和协议(如HTTPS、TLS)来保护敏感数据的传输和存储,并定期对系统进行漏洞扫描和安全性审计。
发布于:6个月前 (02-28) IP属地:四川省
伤疤
伤疤
考察程序逻辑是否清晰,主次是否够分明,例如:你的一个注册接口,有参数校验、判断用户是否已经注册、插入用户记录、发送注册成功通知等功能。如果你把所有所有功能代码塞到一个方法里面,程序逻辑就不清晰,主次不够分明
发布于:6个月前 (02-28) IP属地:未知
咪有了
咪有了
考察接口兼容性,因为很多bug都是因为修改了对外旧接口,但是却不做兼容导致的。关键这个问题多数是比较严重的,可能直接导致系统发版失败的。
发布于:6个月前 (02-28) IP属地:未知
俗世风流债
俗世风流债
考察代码格式是否规范:
1、缩进使用四个空格
2、代码块使用花括号分隔
3、每行不超过80个字符
4、每个方法应该按照特定的顺序排列,例如:类变量、实例变量、构造函数、公共方法、私有方法等。
发布于:6个月前 (02-28) IP属地:四川省
咪有了
咪有了
考察单元测试是否规范:
1、测试类的命名,一般以测试的类+Test,如:CalculatorTest.
2、测试方法的命名,一般以test开头+ 测试的方法,如testAdd.
3、单测行覆盖率一般要求大于75%.
4、单测一般要求包含主流程用例、参数边界值等校验用例
5、单测一般也要求包含中间件访问超时、返回空、等异常的用例,比如访问数据库或者Redis异常.
6、单测用例要求包含并发、防重、幂等等用例.
发布于:6个月前 (02-28) IP属地:未知
玖墨
玖墨
考察并发控制的规范:
1、在使用并发集合时,应该注意它们的线程安全性和并发性能,如ConcurrentHashMap是线性安全的,HashMap就是非线性安全的
2、乐观锁,悲观锁防止数据库并发.乐观锁一般用版本号version控制,悲观锁一般用select …for update
3、如果是单实例的多线程并发处理,一般通过Java锁机制,比如sychronized ,reentrantlock
4、如果是同一集群的多线程并发处理,可以用Redis分布式锁或者走zookeeper
5、如果是跨集群的多线程并发处理,则考虑数据库实现的分布式锁。
6、在使用分布式锁的时候,要注意有哪些坑,比如redis一些经典的坑.
发布于:6个月前 (02-28) IP属地:未知
唯宠她
唯宠她
考察代码是否模块化,是否有扩展性,例如:
未来如果其他场景比如一键贴现接入刷脸的话,不用再搞一套新的接口,只需要新增枚举,然后复用刷脸通过流程接口,实现一键贴现刷脸的差异化即可。

发布于:6个月前 (02-28) IP属地:未知
我就这样
我就这样
考察异常处理是否规范:
1、不要捕获通用的Exception异常,而应该尽可能捕获特定的异常
2、在捕获异常时,应该记录异常信息以便于调试
3、内部异常要确认最终的处理方式,避免未知异常当作失败处理。
4、在finally块中释放资源,或者使用try-with-resource
5、不要使用e.printStackTrace(),而是使用log打印。
6、catch了异常,要打印出具体的exception,否则无法更好定位问题
7、捕获异常与抛出异常必须是完全匹配,或者捕获异常是抛异常的父类
8、捕获到的异常,不能忽略它,要打印相对应的日志
9、注意异常对你的代码层次结构的侵染(早发现早处理)
10、自定义封装异常,不要丢弃原始异常的信息Throwable cause
11、注意异常匹配的顺序,优先捕获具体的异常
12、对外提供APi时,要提供对应的错误码
13、系统内部应该抛出有业务含义的自定义异常,而不是直接抛出RuntimeException,或者直接抛出Exception\Throwable。
发布于:6个月前 (02-28) IP属地:未知
霸占丶迩德
霸占丶迩德
考察是否做了判空处理:
1、对集合进行判空
2、对对象进行判空
发布于:6个月前 (02-28) IP属地:未知
回忆多美好
回忆多美好
考察是否做了必要的参数校验:
1、非空检查
2、金额范围检查
3、长度校验
4、必要的正则校验
发布于:6个月前 (02-28) IP属地:未知
心尖爱人
心尖爱人
考察命名是否规范:
1、类和接口应该使用首字母大写的驼峰命名法
2、方法和变量应该使用小写的驼峰命名法
3、常量应该使用全大写字母和下划线
4、开发者是不是选择易于理解的名称给变量、类和方法进行命名
发布于:6个月前 (02-28) IP属地:未知
北饮清茶
北饮清茶
考察日志打印规范:
1、日志级别选择不对。常见的日志级别有error、warn、info、debug四种,不要反手就是info哈
2、日志没打印出调用方法的入参和响应结果,尤其是跨系统调用的时候。
3、业务日志没包含关键参数,如userId,bizSeq等等,不方便问题排查
4、如果日志包含关键信息,比如手机号、身份证等,需要脱敏处理
5、一些不符合预期的情况,如一些未知异常(数据库的数据异常等),又或者不符合业务预期的特殊场景,都需要打印相关的日志
发布于:6个月前 (02-28) IP属地:四川省
西瓜女皇
西瓜女皇
考察是否做了必要的注释:
1、所有的类都必须添加创建者和创建日期,以及简单的注释描述
2、方法内部的复杂业务逻辑或者算法,需要添加清楚的注释
3、一般情况下,注释描述类、方法、变量的作用
4、任何需要提醒的警告或TODO,也要注释清楚
5、如果是注释一行代码的,就用//;如果注释代码块或者接口方法的,有多行/* **/
6、一块代码逻辑如果你站在一个陌生人的角度去看,第一遍看不懂的话,就需要添加注释了
发布于:6个月前 (02-28) IP属地:四川省
我来回答