游戏电视苹果数码历史美丽
投稿投诉
美丽时装
彩妆资讯
历史明星
乐活安卓
数码常识
驾车健康
苹果问答
网络发型
电视车载
室内电影
游戏科学
音乐整形

Java编码规范

  Java编码规范(日常编码总结,规范项目组员有统一的规范,方便合作,查错,重构等)当你抛弃规范随心所意的写代码时,等你之后再回来阅读时真有的一种全部删掉重写的冲动。前言如果这份规范中有不合理的地方,欢迎提issue提PR等各种形式进行完善。如果您有更好的代码风格未在本规范中列出,欢迎提issue提PR等各种形式进行完善。本规范最后一部分业务规范仅根据本人所在公司情况制定(游戏开发),请酌情考虑使用。本project还在完善和验证中,希望和大家一起写出优雅而实用的代码。常用开发工具下载IDE(IDEAeclipseorother)mysql(5。6)mysqlclient(navicatmysqlworkbeach)xshellandxftpjdk1。7emeditorapacheantapachemaventortoisesvn64位一。命名规范1。【强制】代码中的命名严禁使用拼音与英文混合的方式,更不允许直接使用中文的方式。
  说明:正确的英文拼写和语法可以让阅读者易于理解,避免歧义。注意,即使纯拼音命名方式也要避免采用。不会的单词请谷歌翻译。反例:DaZhePromotion〔打折〕getPingfenByName()〔评分〕int某变量3正例:alibabataobaoyoukuhangzhou等国际通用的名称,可视同英文。2。类名使用UpperCamelCase风格(首字母大写),必须遵从驼峰形式。
  正例:MarcoPoloUserDOXmlServiceTcpUdpDealTaPromotion反例:macroPoloUserDoXMLServiceTCPUDPDealTAPromotion3。方法名、参数名、成员变量、局部变量都统一使用lowerCamelCase风格(首字母小写),必须遵从驼峰形式。
  正例:localValuegetHttpMessage()inputUserId4。【强制】常量命名全部大写,单词间用下划线隔开,力求语义表达完整清楚,不要嫌名字长。
  正例:MAXSTOCKCOUNT反例:MAXCOUNT5。【强制】包名统一使用小写,点分隔符之间有且仅有一个自然语义的英语单词。包名统一使用单数形式,但是类名如果有复数含义,类名可以使用复数形式。
  正例:应用工具类包名为com。java。open。util、类名为MessageUtils(此规则参考spring的框架结构)6。杜绝完全不规范的缩写,避免望文不知义。
  反例:AbstractClass缩写命名成AbsClass;condition缩写命名成condi,此类随意缩写严重降低了代码的可阅读性。7。【推荐】如果使用到了设计模式,建议在类名中体现出具体模式。
  说明:将设计模式体现在名字中,有利于阅读者快速理解架构设计思想。正例:publicclassOrderFactory;publicclassLoginProxy;publicclassResourceObserver;8。枚举类名建议带上Enum后缀,枚举成员名称需要全大写,单词间用下划线隔开。
  说明:枚举其实就是特殊的常量类,且构造方法被默认强制是私有。正例:枚举名字:DealStatusEnum,成员名称:SUCCESSUNKOWNREASON。9。【强制】代码中的命名均不能以下划线或美元符号开始,也不能以下划线或美元符号结束。
  反例:namenameObjectnamenameObject10。【推荐】接口类中的方法和属性不要加任何修饰符号(public也不要加),保持代码的简洁性,并加上有效的Javadoc注释11。源代码文件以文件内容中的最顶层的Java类命名,而且大小写敏感,文件扩展名为。java,同时,文件的编码格式统一为UTF8。12。类的命名遵循大驼峰命名法UpperCamelCase,而方法名和变量名的命名遵循小驼峰命名法lowerCamelCase
  常量名使用大写字母表示,单词之间以下划线分隔,例如staticfinalintCONNECTIONTIMEOUT10000二。常量定义1。【强制】不允许出现任何魔法值(即未经定义的常量)直接出现在代码中。
  反例:StringkeyIdtaobaotradeId;cache。put(key,value);2。【强制】long或者Long初始赋值时,必须使用大写的L,不能是小写的l,小写容易跟数字1混淆,造成误解。
  说明:Longa2l;写的是数字的21,还是Long型的2?3。【强制】不要使用一个常量类维护所有常量,应该按常量功能进行归类,分开维护。
  如:缓存相关的常量放在类:CacheConsts下;系统配置相关的常量放在类:ConfigConsts下。说明:大而全的常量类,非得使用查找功能才能定位到修改的常量,不利于理解和维护。4。【推荐】常量的复用层次有五层:跨应用共享常量、应用内共享常量、子工程内共享常量、包内共享常量、类内共享常量。1)跨应用共享常量:放置在二方库中,通常是client。jar中的constant目录下。2)应用内共享常量:放置在一方库的modules中的constant目录下。反例:易懂变量也要统一定义成应用内共享常量,两位攻城师在两个类中分别定义了表示是的变量:类A中:publicstaticfinalStringYESyes;类B中:publicstaticfinalStringYESy;A。YES。equals(B。YES),预期是true,但实际返回为false,导致产生线上问题。3)子工程内部共享常量:即在当前子工程的constant目录下。4)包内共享常量:即在当前包下单独的constant目录下。5)类内共享常量:直接在类内部privatestaticfinal定义。5。【推荐】如果变量值仅在一个范围内变化,且带有名称之外的延伸属性,定义为枚举类。下面
  正例中的数字就是延伸信息,表示星期几。正例:publicEnum{MONDAY(1),TUESDAY(2),WEDNESDAY(3),THURSDAY(4),FRIDAY(5),SATURDAY(6),SUNDAY(7);}三。格式规约1。【建议】缩进采用4个空格,禁止使用tab字符。
  说明:如果使用tab缩进,必须设置1个tab为4个空格。IDEA设置tab为4个空格时,请勿勾选Usetabcharacter;而在eclipse中,必须勾选insertspacesfortabs。因为tab很容易造成代码对齐方式错乱,尤其在生成html文档的时候格式会乱掉。2。【强制】单行字符数限制不超过120个,超出需要换行。3。Javadoc
  标准的Javadoc常见的标记和含义如下:Javadoc常见的标记param方法参数的说明return对方法返回值的说明throws方法抛出异常的藐视version模块的版本号author模块的作者see参考方向deprecated标记是否过时四。OOP规约1。【强制】外部正在调用或者二方库依赖的接口,不允许修改方法签名,避免对接口调用方产生影响。接口过时必须加Deprecated注解,并清晰地说明采用的新接口或者新服务是什么。2。【强制】定义DODTOVO等POJO类时,不要设定任何属性默认值。
  反例:POJO类的gmtCreate默认值为newDate();,但是这个属性在数据提取时并没有置入具体值,在更新其它字段时又附带更新了此字段,导致创建时间被修改成当前时间。3。【强制】构造方法里面禁止加入任何业务逻辑,如果有初始化逻辑,请放在init方法中。4。【强制】POJO类必须写toString方法。使用IDE的中工具:sourcegeneratetoString时,如果继承了另一个POJO类,注意在前面加一下super。toString。
  说明:在方法执行抛出异常时,可以直接调用POJO的toString()方法打印其属性值,便于排查问题。5。【推荐】当一个类有多个构造方法,或者多个同名方法,这些方法应该按顺序放置在一起,便于阅读。6。【推荐】类内方法定义顺序依次是:公有方法或保护方法私有方法gettersetter方法。
  说明:公有方法是类的调用者和维护者最关心的方法,首屏展示最好;保护方法虽然只是子类关心,也可能是模板设计模式下的核心方法;而私有方法外部一般不需要特别关心,是一个黑盒实现;因为方法信息价值较低,所有Service和DAO的gettersetter方法放在类体最后。7。【推荐】setter方法中,参数名称与类成员变量名称一致,this。成员名参数名。在gettersetter方法中,不要增加业务逻辑,增加排查问题的难度。我曾天真的认为这种黑魔法很酷。
  反例:publicIntegergetData(){if(true){returndata100;}else{returndata100;}}8。【推荐】下列情况,声明成final会更有提示性:
  1)不需要重新赋值的变量,包括类属性、局部变量。2)对象参数前加final,表示不允许修改引用的指向。3)类方法确定不允许被重写。9。【推荐】类成员与方法访问控制从严:
  1)如果不允许外部直接通过new来创建对象,那么构造方法必须是private。2)工具类不允许有public或default构造方法。3)类非static成员变量并且与子类共享,必须是protected。4)类非static成员变量并且仅在本类使用,必须是private。5)类static成员变量如果仅在本类使用,必须是private。6)若是static成员变量,必须考虑是否为final。7)类成员方法只供类内部调用,必须是private。8)类成员方法只对继承类公开,那么限制为protected。说明:任何类、方法、参数、变量,严控访问范围。过于宽泛的访问范围,不利于模块解耦。
  思考:如果是一个private的方法,想删除就删除,可是一个public的service方法,或者一个public的成员变量,删除一下,不得手心冒点汗吗?变量像自己的小孩,尽量在自己的视线内,变量作用域太大,如果无限制的到处跑,那么你会担心的。四。集合操作1。【强制】不要在foreach循环里进行元素的removeadd操作。remove元素请使用Iterator方式,如果并发操作,需要对Iterator对象加锁。
  反例:ListStringanewArrayListString();a。add(1);a。add(2);for(Stringtemp:a){if(1。equals(temp)){a。remove(temp);}}
  正例:IteratorStringita。iterator();while(it。hasNext()){Stringtempit。next();if(删除元素的条件){it。remove();}}五。异常处理1。【推荐】方法的返回值可以为null,不强制返回空集合,或者空对象等,必须添加注释充分说明什么情况下会返回null值。调用方需要进行null判断防止NPE问题。2。【强制】对大段代码进行trycatch,这是不负责任的表现。catch时请分清稳定代码和非稳定代码,稳定代码指的是无论如何不会出错的代码。对于非稳定代码的catch尽可能进行区分异常类型,再做对应的异常处理。3。【强制】捕获异常是为了处理它,不要捕获了却什么都不处理而抛弃之,如果不想处理它,请将该异常抛给它的调用者。最外层的业务使用者,必须处理异常,将其转化为用户可以理解的内容。六。日志1。【强制】直接return的情况下一定要打日志,不然根本无法判断代码没有执行还是在哪个位置被return了。2。【强制】异常信息应该包括两类信息:案发现场信息和异常堆栈信息。如果不处理,那么通过关键字throws往上抛出。
  正例:logger。error(各类参数或者对象toStringe。getMessage(),e);3。【参考】可以使用warn日志级别来记录用户输入参数错误的情况,避免用户投诉时,无所适从。注意日志输出的级别,error级别只记录系统逻辑出错、异常等重要的错误信息。如非必要,请不要在此场景打出error级别。
  备注:以上内容摘自阿里巴巴JAVA编程规范7。业务规范1。【强制】写业务逻辑时,一定要把对应的需求链接贴在代码注释里,方便在和策划撕逼时方便决定谁该背锅。月卡增幅20170104http:192。168。1。88:8010index。php?mstoryfviewstoryID7775if((instanceConfig。getInstanceType()1)1){个人BOSSitemNumextraAdd;}if(itemConfig。getCarrymax()0){intcountBagApiNew。getItemCount(bag,itemId)StorageApi。getItemCount(rid,itemId);if(countitemNumitemConfig。getCarrymax()){超出最大囤积上限的时候获得一部分LOGGER。error({}{}玩家领取副本【{}】奖励【itemId:{},itemNum:{},oldNum:{}】时超出上限【{}】,rid,role。get(name),instanceConfig。getMapid(),itemId,itemNum,count,itemConfig。getCarrymax());itemNumitemConfig。getCarrymax()count;}}2。【强制】不要和策划口头定需求,有修改或者新增在需求里体现出来。3。【强制】需求做完要自己先测试,未测出bug再打给策划。然后再和策划一起做最后bug排查和功能优化。严禁未经任何自查就扔给策划,除百你对改动的代码100确认没有问题。4。【强制】方法体一定要有注释并署名,方便找写该业务的人做BUG排查。请求打开困惑殿堂面板paramridridauthor:小莫date:2017050410:08publicvoidreqOpenPanel(intrid){code}5。【强制】方法体中决定不能出现数字(0除外),放在常量类中并加以注释。如果常量小于3个可以放在本类的顶部(参考常量定义3)packagerpg。system。task。constant;publicinterfaceTaskType{intJIFENGFUMO4;intCAIJI5;intXIANGYAOFUMO8;intBIGBOSS10;精英任务intQIYUXUNHUAN11;intJINDU12;intTIAOZHAN13;intTREASUREBOWL14;聚宝盆intQIYUSUIJI23;intCANGYUEISLAND100;}6。【强制】类型和Map的key要定义常量类存放于业务模块。
  正例:uparm模块constant包中存放,以XxxConst,XxxField命名。uparmUparmManager。javabeanComposeBean。javaXilianBean。javaconstantArmFromConst。javaArmField。javahandlerReqAddQhFailNumHandler。javaReqDecomposeHandler。javaReqZyqhHandler。java
  Field内容例如:publicinterfaceLimitTimeTaskField{任务接受状态intTASKACCEPTSTATE1;任务完成状态intTASKCOMPLETESTATE2;限时任务消息StringLIMITTIMETASKINFOLIMITTIMETASKINFO;分组idStringLIMITTIMETASKGROUPIDLIMITTIMETASKGROUPID;}7。【强制】在写业务逻辑的时候尽可能的考虑到发包情况(不要轻信客户端传过来的数据),并对发包请求进行拦截,防止非正常玩家通过BUG刷道具。
  例:玩家领奖之后要给玩家存一个己领奖的flag,当再次请求的时候就不要重复发奖励了。相关资料阿里巴巴Java开发手册v1。2。01。pdf阿里巴巴java编程规范2017版。pdfAndroidJava书写简洁规范的代码

余生请多指教定档日期,余生请多指教多少集余生请多指教说出来很多人清楚,可余生请多指教电视剧定档日期,很多网友就想去了解一下有关的故事,看余生请多指教被很多网友期待,果真没有多久后就给公布出定档的日期,但有的网友就不清……RedmiK40pro配置曝光,相机异常吸睛,售价更感人Redmi生产的手机具有出色的性价比。在今年的5G市场中,Redmi可以说是一个巨大的成功。其中,RedmiK30pro已成为市场上最受欢迎的5G手机,但Redmi随后发布了R……韩国r级限制十大电影2019女主角漂亮香艳剧照精选韩国有很多好看的电影,其中r级限制电影更是他们的一大特色,而且很多限制片中的女主角都十分漂亮,身材也好,来看看,2019年韩国r级限制推荐高颜值电影,女主角漂亮香艳剧照精选。……回顾韩国电影TOP102016年口碑不错的韩国十大电影回顾韩国电影TOP10:2016年口碑不错的韩国十大电影。2016年,韩国电影市场依旧硝烟弥漫,佳篇纷纷扎堆上映,总票房达到了14。4亿美元,跟2015年的14。1亿美元相比,……支付宝新功能安全守护上线像打击酒驾一样打击诈骗随着中国互联网的快速发展,借助于手机、网络等通信工具等的电信诈骗迅速发展蔓延,给人民群众造成了巨大的损失。强力的打击防范态势虽在一定程度上震慑、遏制了犯罪高发,然而电信诈……固话正在慢慢消失台式机的明天会是怎样万里长城上的烽火狼烟,是中国通讯史上的奇迹。马拉松长跑将捷报传到雅典,是希腊通讯史上的传奇。从千里鸿雁到无线电台,从固话到寻呼机,从手提电话到智能手机,通讯行业发展日新月异,科……三千鸦杀覃川阿满是一个人吗揭露二者关系及扮演者资料三千鸦杀覃川阿满是一个人吗揭露二者关系及扮演者资料近日,电视剧《三千鸦杀》未播先火,其中剧中覃川的身份很多人都比较好奇,那么,《三千鸦杀》中覃川和阿满是一个人吗?两者是什么关系……保时捷911TurboS越野版官图全球限量销售40台日前,保时捷911TurboS越野定制版官图正式发布,新车由MarcPhilippGemballa打造。新车基于全新保时捷911TurboS打造而来,拥有不错的越野性能。其被定……三千鸦杀男女主角曝光男主角竟然是他!近几日,电视剧《三千鸦杀》官宣了阵容,男女主角曝光了,男主角竟然是他!男主演技颜值均在线,女主被称为ldquo;男神收割机rdquo;是真的吗?一起来看一下具体的情况。三……择天记结局是什么意思,择天记小说讲了什么玄幻剧《择天记》给观众带来剧情不多么圆满,主要想追求比较美好的情况,不过后期陈长生来阻止战争,使得他没有跟陈有容在一起,却陈长生在原著小说中收获到甜蜜的爱情。1择天记结局是什么……一闪一闪亮星星麦子结局及扮演者穿越剧《一闪一闪亮星星》给表现麦子为街头混混的模样,不过他本质善良,还去给朋友两肋插刀,可他看见林北星惊吓样子跟林大海打起来,使得他入狱,直达最后蒋昀霖扮演麦子刑满出狱来修车厂……千古玦尘清穆什么时候恢复记忆清穆和柏玄是什么关系目前热播剧中《千古玦尘》中的剧情有点虐了,清穆和白玦以及柏玄三个人的关系很是微妙,好奇千古玦尘清穆第几集恢复记忆呢?清穆赶紧恢复记忆和后池一起甜甜蜜蜜的吧。那么,千古玦尘清穆和……
智能洗衣新选择云米互联网洗烘一体机NEO(智能投放版)云米互联网洗烘一体机(智能投放版)当前,对于大部分朋友来讲,洗烘一体机依然是家庭日常洗衣的理想选择。高房价的今天,原本作为晾晒空间的阳台,已经悄然转变为享受生活的理想区域……理想很丰满现实很骨感贵阳大数据交易所这六年证券时报记者罗曼田牧当下的贵州是知名的数据之都,大数据、区块链、互联网金融字眼的招牌在贵阳随处可见。过去每年5月,马云、马化腾、李彦宏等互联网巨头都会齐聚由贵州省政府主办……保守的品质与创新的态度铁三角CK3TW林氏评测日本这个国家着实是很有意思的。说保守,那很多方面真的是保守得不行,老规矩老习惯会一直留着,哪怕在别人看来没什么意义那种也都要坚守。顽固得让别人看不懂的事,他们做得多了去了。……演员和歌手海贝Crystal6六单元动铁耳塞评测在我还很小的时候,我会好奇一件事:如果一个演员出身的人,他她去唱歌,那么他她唱歌的风格,会不会跟演戏时候比较像?或者反过来,歌手做演员,是不是往往也会有这种风格延续性?当……监控视频信号VGA接口,是塔吊起重机对工业一体机的特定要求随着经济的不断发展,完善、强化基础建设一直以来都是社会发展的重要产业,包含住房、城市交通、公共基础建设等,随处可见的施工工程,也为许多产业带来了可观的市场发展潜力。其中,塔吊作……安卓钉子户眼里的13香吗?iPhone13Pro入手体验及配这些年,我家换手机的节奏大概是这样的,每年iPhone上新都入手,给媳妇换,她换下来的,要么我当备机用,要么出掉回血。今年13Pro在屏幕和影像方面有了相对明显提升,所以,这么……对话周伟峰助力早日实现碳中和,椭圆方程用技术赋能建造行业人类社会的发展是不断从自然界采取能源的过程,从柴火时代到煤炭时代,再到石油时代,然后每一次能源开发的过程中,都会对环境产生影响,乃至引起全球性的环境问题。在十四五规划的开……大家想多了亚马逊否认将会在年内支持加密货币支付日前,本号发表的Amazon正在评估接纳比特币汇率波动问题是最大困扰一文提到了亚马逊正在物色加密货币支付的领导人,提到人们认为这标志着亚马逊有可能会很快提供加密货币作为全球支付……云评尼康售价仅1799元的真香镜头Z40mmf2。0尼康自打ZMC105mmf2。8VRS和Zfc后似乎开始逐渐有点起色了,Zfc针对的是年轻和女性市场,复古的外观相当讨喜,而ZMC105mmf2。8VRS则是凭借惊人的天花板画……ZMI紫米33W氮化镓充电器超小体积兼容iPhone12随着手机充电功率越来越高,充电器的体积也越做越大,多个设备同时充电时,难免插排间距不够影响使用。而今年会发现数码配件市场已经迈向小型化、高功率的趋势,从各家为iPhone12推……UNIK释放智能体验当你上车后,UNIK会自动刷脸识别车主身份,并根据相关联的记忆功能,会将座椅、后视镜调整到你之前的位置,哪怕刷脸着车也都是可以的。UNIK还可实现隔空手势交互,能够识别车上所有……一加员工透露一加8T使用体验玩游戏真爽,王者胜率90以上明天就要上班了,你现在是否正在路上堵着呢?而伴随着十一假期的结束,距离一加新机的发布会也仅有一周的时间。10月15日,一加将正式发布新机一加8T。这款在节前就已经曝光的新机即将……
友情链接:易事利快生活快传网聚热点七猫云快好知快百科中准网快好找文好找中准网快软网