Java后端开发规范
Java后端开发规范
一、技术栈规约
二、命名规范
三、Java代码规范(注释规范、异常与日志、代码逻辑规范)
四、Mybatis与SQL规范
五、结果检查(单元测试及代码扫描)
六、安全规范一、技术栈规约
二、命名规范命名使用英文词组合,严禁使用中文拼音或拼音首字母组合命名(专有名词例外)OrganizationTreeNode,OrganizationVO;不推荐使用PSTree,TlogsgroupId,package包名前缀统一为:com。wiwj包名第三位为产品分类名,如com。wiwj。cbs常量命名全大写,单词间下划线分隔。如:DEFAULTPAGESIZE其他命名遵循驼峰式命名法:类名:首字母大写的UpperCamelCase,如:Organization方法名、变量名:首字母小写的lowerCamelCase,如:orgName特定标识命名:领域模型增加类型后缀标识,如xxVO,yyDAO基类抽象类使用BaseAbstract等前缀标识设计模式类添加Factory,Builder,Proxy等标识Controller,Service,Mapper统一添加到对应分层目录接口实现类添加Impl后缀标识枚举类添加Enum后缀标识CRUD接口采用统一前缀:get,count,create,delete,update,batchCreate三、Java代码规范注释规范Java文件统一添加固定Header,通过IDE统一配置(codetemplates)Description
authormazhicheng5i5j。com
version1。0
date{YEAR}{MONTH}{DAY}
接口和方法统一添加JavaDoc标准注释缓存keyvalue并设定过期时间paramkey缓存对象的keyparamvalueList缓存对象return缓存是否成功TbooleanaddList(Stringkey,ListTvalueList);需暂留的弃用类方法添加Deprecated废弃标记和see链接指向新接口seecom。wiwj。common。cache。redis。JedisSentinelPoolUtilDeprecatedpublicclassJedisUtils{}异常与日志调用外部服务等可能异常的代码块,用trycatch代码块捕获并在catch中记录异常跟踪日志及业务逻辑处理禁止吞掉异常信息
禁止catch里不做任何记录和处理,吞掉异常及其堆栈信息
禁止:logger。error(XXX操作异常)或logger。error(XXX操作异常e)或e。printStackTrace()
正确:logger。error(XXX操作异常,e)对于非预期的条件,尽量增加else记录跟踪日志禁止通过System。。out()打印日志(单元测试例外)日志记录logger需使用Slf4J代理声明,禁止绑死具体日志系统的API,避免后期更换日志组件导致代码的大量改动
privatestaticfinalLoggerlogLoggerFactory。getLogger(OrganizationServiceImpl。class);
如采用了lombok,可用Slf4j注解替代以上声明。对tracedebuginfo级别的日志输出,必须使用占位符形式,避免直接String拼接异常信息(即使日志级别不匹配也会执行拼接操作空耗资源)。
正确写法如:log。debug(当前用户id:{},操作对象:{}{},userId,objectType,objectId);或条件输出形式如:if(log。isDebugEnabled()){log。debug(当前用户id:id,操作对象:objectTypeobjectId);}逻辑代码规范废弃的无用的代码一律直接删除,禁止以注释等方式保留。如需查看历史代码,通过SVNGit的history找回
(无用的代码会干扰团队成员的阅读或被误调,越积越多会导致代码维护成本增高)接口类中的方法不需添加public修饰符需要序列化的Bean类统一实现Serializable接口并用IDE生成serialVersionUIDpublicclassMyEntityimplementsSerializable{privatestaticfinallongserialVersionUID123456L;。。。}常用字符串统一定义在常量类里,如:utf8,yyyyMMdd避免数字类型比较的坑:统一采用equals进行比较其值,不用进行比较,避免踩坑。ifelseforwhile语句后必须使用大括号,即使只有一行代码。(需求总是变化的,一行是暂时的)嵌套层次过多的代码块利用反向思维缩减层次方法单一职责:单个方法代码行数控制在100行以内,超长的需要拆分(拆分成多个方法或类)避免NPE(NullPointException)的一些建议:equals比较将非空对象前置:如true。equals(request。getParameter(isXx)),即使后者为空也不会导致NPE。数据库字段可空的映射属性使用包装类型定义:如基本数据类型的int映射到数据库的null值将产生NPE,而用吧包装类型Integer则不会。可能为空的变量进行必要判空,并在非预期条件下打印必要的跟踪日志,不但避免NPE,还非常便于跟踪调试。如:级联调用obj。getA()。getB()。getC()易产生NPE,先进行判空或使用JDK8的Optional类包装。调用Dubbo接口拿到返回值时,进行判空。封装统一的判空类用于常用类型的判空,代码需要判空时统一调用即可。如XX。isEmpty(),XX。isNotEmpty()遵循:Don’tRepeatYourself,即DRY原则。避免进行简单的复制粘贴修改,当出现重复代码时思考是否封装
当代码中存在大量重复代码时,一旦代码逻辑变动将很容易导致顾此失彼,产生bug,非常不利于维护。Bean属性拷贝推荐用SpringBeanCopier或者Mapstruct,避免ApacheBeanUtils或调用setter禁止在循环中执行耗时的操作,如在循环中执行SQL语句调用外部服务等错误的示例:for(Longid:idList){循环执行SQL查询或调用外部系统接口,产生性能问题EntityentityxxService。getEntityById(id);。。。}此案例的更优方案是通过idList一次性查询获取到Entity集合,然后转换为MapId,Entity供后续获取。需要多次使用的可复用对象将对象单独定义,禁止多次调用取不同属性。如:StringnameuserService。getUser(id)。getName();LongdeptIduserService。getUser(id)。getDepeId();替换为:UseruseruserService。getUser(id);Stringnameuser。getName(),。可异步执行的耗时操作采用异步处理:使用SpringAsync或MQ,或夜间Timer定时常用数据考虑缓存,存入Redis,设置缓存过期时间需要保证写一致性的逻辑,在外层方法上添加事务Transactional(rollbackForException。class)四、Mybatis与SQL规范表名、字段名、索引等数据结构定义大小写:Oracle大写,MySQL小写。名称使用英文下划线,并控制总长度,如username。表名建议采用模块标识前缀,如basuser(如果模块库独立可省略模块名标识)禁止程序中的SQL使用并行计算parallel(t,n)SQL使用标准SQL,避免出现数据库特定的语法未经评审不可直接使用视图、触发器、存储过程SQLJOIN表数量不超过3张,超过3张表需要经过评审(拆分成多次单表查询、主表冗余、程序绑定idname映射、根据条件动态JOIN等)。合理创建索引,并尽量避免不走索引的情况:如LIKE右任意匹配(‘xx’,‘xx’)不走索引,换为精确匹配或固定前缀的左匹配’张’不等条件(!、、NOT)不走索引,应尽量避免(转换成INBETWEEN等)IS(NOT)NULL不走索引,应尽量避免(如字段给定默认值,避免NULL)索引列使用函数或隐式转换都将导致索引失效,如tochar(createdate,yyyymmdd)20190102禁止手动拼接SQL语句,利用Mybatis等ORM框架的动态SQL实现。参数使用{}(避免{}产生SQL注入问题)。禁止使用数据库处理函数decode(),改为Java枚举或Map定义,通过id进行绑定decode(client。TYPE,1,私客,2,店组公客,3,组团公客‘)禁止动态拼接时强加11之类的写法,如WHERE11。使用Mybatis动态SQL标签实现,如,,SQL中的参数类型确保与列定义一致,避免数据库隐式转换开销且无法使用索引,如:列定义为日期类型,参数要转换为Date日期类型进行比较:CREATETIME2019041423:59:59’CREATETIMEtodate(2019041400:00:00,yyyyMMddHH24:mi:ss’)列定义为数字类型,参数不用StringDEPTID123’ID主键自增的情况下,按createtime排序改为按ID排序,效果一样效率更高五、检查结果后端服务及其他需要自测的代码,编写对应的单元测试类,统一采用Junit,禁止直接在原Java类中写main()方法自测。单元测试会在打包前统一运行,可及时发现受影响的代码问题(比如新代码导致了之前的代码逻辑产生问题,如果有单元测试可在打包时及时发现)Junit单元测试类示例:publicclassTestApollo{Test标记为单元测试方法publicvoidtestApolloConfig(){StringappIdFoundation。app()。getAppId();预期结果断言Assert。assertNotNull(appId);}}IDE中安装代码质量检查插件:FindBugs及AlibabaJavaCodingGuidelines
六、安全规约
说明:本文限于篇幅,故而只展示部分的面试内容,完整的Java面试学习文档小编已经帮你整理好了,有需要的朋友点赞关注私信我777免费领取Java、大厂面试学习资料哦!
原文作者:地球其实挺好
原文出处:https:www。cnblogs。comzltblogp10839955。html
英伟达晒首款搭载RTX4090显卡的MOD主机IT之家9月21日消息,今天,英伟达晒出了首款搭载GeForceRTX4090显卡的速度穿越MOD主机,由liquidhaus打造。据介绍,这款主机GeForceRTX4090采用
四大旗舰投票开始,下月还有哪些新机发布最近一段时间,不少品牌都带来了旗下的全新旗舰产品。而随着新一代苹果iPhone14系列和华为Mate50系列的正式到来,今年的旗舰市场也开始了更激烈的竞争。同时,科技美学四大旗舰投
羊了个羊为何火,还不是我们犟种?(附第二关攻略)羊了个羊的爆火,都离不开我们的犟,玩过的人都知道,这游戏不如叫做驴了个驴,因为我们比驴还犟,明知道第二关过不去非要过,哪怕广告看到吐,哪怕明天还要上班,哪怕肚子气的鼓鼓的此游戏,就
当羊变成了烊羊了个羊为什么这么火最近有一个小游戏超级火爆,相信不少朋友都已经玩过也为之抓狂,没错,就是标题里的这个游戏羊了个羊。最先看到这个小游戏是前几天在抖音中发现的,但是没有点进去,因为我对抖音的小游戏不太信
火爆全网的羊了个羊,我一次也没有打开过羊了个羊在这个初秋,占据了人们的指尖游戏时间,走上热门。过不了第二关的懊恼声,盖过了塌房明星粉丝的哀嚎。没有人质疑它的流量实力,但从知道这个游戏到现在,我一次也没有打开过羊。不知道
彻底淘汰WiFi7手机曝光网速延迟完美头部的无线厂商如高通联发科博通等早已发布了WiFi7芯片等解决方案,新华三等设备厂的WiFi7路由产品也抢滩登陆,那么对于普通消费者来说,支持WiFi7的手机笔记本等要何时相见呢?
电竞名人传梦泪梦泪2019年,梦泪因为打了一场BO5的比赛,却拿下了kpl年度最受欢迎选手奖,很多人不明白,这个长相平平的男人,他凭什么拥有这么大的影响力?梦泪早期照片,皮肤黝黑加眼镜有点搞笑梦
羊了个羊一夜爆火,幕后公司什么来头?钛度图闻钛度图闻第五十七期策划制作钛媒体视觉中心,编辑刘美兰,作图初彦墨过去一周,一款名为羊了个羊的小游戏火爆全网。据官方介绍,这是一款超难的闯关消除小游戏,通关率不到0。1。玩家们需要点
白癜风偏方无花果叶有用吗?有关白癜风偏方的话题发过很多,算是老生常谈了,这不,又有一位患者问无花果叶子能治白癜风吗?本文将为大家详细介绍下有关无花果,无花果叶的相关常识。无花果无花果具有很高的营养价值,它的
年龄大了要忌嘴!提醒少吃猪肉和豆腐,多吃3样,为秋冬打基础年龄大了要忌嘴!提醒少吃猪肉和豆腐,多吃3样,为秋冬打基础。哈喽,大家好,我是大厨江一舟,今天又到了和大家分享美食的时刻了,你准备好了吗?随着年龄的不断增大,尤其是对于过了50岁的
良性结节会自己消失吗?良性结节一般是指,结节的大小以及症状在可控的范围内,且不需要手术治疗,恶化可能性低的乳腺疾病的统称。一般包括,经期前后规律出现的乳腺增生,常发于青年女性的良性肿瘤乳腺纤维瘤,乳腺检