码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Java 开发必知的规范文档


    一、使用规范的目的

     使本组织能以标准的,规范的方式设计和编码。通过建立编码规范,以使每个开发人员养成良好的编码风格和习惯;并以此形成开发小组编码约定,提高程序的可靠性,可读性,可修改性,可维护性和一致性等,增进团队间的交流,并保证软件产品的质量。

    二、代码组织与风格

    1:长度:为便于阅读和理解,单个函数的有效代码长度当尽量在100行以内(不包括注释行),当功能模块过大时往往采用使用子函数将相应的功能抽取出来,这也有利于提高代码的重用度。
    2:单个类不宜过大,当出现此类过大时当将相应功能的代码重构到其他类中,通过组合等方式来调用,建议单个类的长度包括注释行不超过1500行。尽量避免使用大类和长方法。
    3:间隔:类,方法及功能块间等应以空行相隔,以增加可读性,但不得有无规则的大片空行。操作符两端应当各空一个字符以增加可读性。

    三、注释

    1:注释应该增加代码的清晰度。代码注释的目的时要使代码更易于被其他开发人员等理解。
    2:保持注释的简洁。
    3:注释信息应该包括代码的功能。
    4:除变量定义等较短语句的注释使用行尾注释外,其他注释当避免使用行尾注释。
    5:JavaDoc规范
    对类,方法,变量等注释需要符合javadoc规范,对每个类,方法都应详细说明其功能条件,参数等。类注释中应当包含版本和作者信息。
    1)类,接口注释 在类,接口定义之前当对其进行注释,包括类,接口的目的,作用,功能,继承于何种父类,实现的接口,实现的算法,使用方法,示例程序等。

    2)方法注释  以明确该方法功能,作者,各参数含义以及返回值等。

    3)其他注释  应对重要的变量及不易理解的分支条件表达式加以注释,以说明其含义等。

    四 、命名规范

    1:对变量,类,接口及包的命名应该使用英文。严禁使用汉语拼音及不相关单词命名。更不可以使用汉字来进行命名。采用大小写混合,提高名字的可读性。一般应该采用小写字母,但时类和接口的名称的首字母,以及任何中间单词的首字母应该大写。包名全部小写。
    2:尽量少用缩写,但如果一定要用,当使用公共缩写和习惯缩写等,如implement可缩写为impl,manager可缩写成mgr等。
    3:包名一般以项目或模块名命名,少用缩写和长名,一律小写。
    包名按照如下规定组成 [基本包].[项目名].[模块名].[子模块名].….
       如:org.skyinn.skyhome.dao.hibernate。
       不得将类直接定义在基本包下,所有项目中的类,接口等都当定义在各自的项目和模块包中。
    4:类,接口 所有单词首字母大写,最好能够见名知意。一般采用名词。接口可带I前缀。或able,dao后缀。
    5:字段  常量采用完整的英文大写单词,单词之间用下划线连接,如 DEFAULT_VALUE.
    6:变量和参数对不易识别出该变量类型的变量应使用类型缩写作其前缀,如字符串使用strXXX,boolean使用isXXX,hasXXX等等。除第一个单词外其余单词的首字母大写。
    7:集合 采用复数名称来表示队列中存放的对象类型,名词采用完整的英文描述。
    例如:Vector  vProducts= new Vector();
                  Array   aryUsers= new Array();
    8:方法  方法的名称应采用完整的英文描述,大小写混合使用:所有中间单词的第一个字母大写。方法名称的第一个单词常常采用一个强烈动作色彩的动词。取值类使用get前缀,设置类使用set前缀。例如  getName(),setSarry()。
    9:异常类名由表示该异常类型的单词和Exception组成,如ActionException。异常实例一般使用e,ex等。
    10:数组的命名
    数组应该总是用下面的方式来命名:byte[] buffer; 而不是: byte buffer[];

    五 、 类与接口

    1:基本原则:一个类只做一件事情。另一个原则时根据每个类的职责进行划分,比如用User来存放用户信息,而用UserDAO来对用户信息进行数据访问操作,用UserServer对用户信息的业务操作等等。多个类中使用相同方法时将其方法提到一个接口中或使用抽象类,尽量提高重用度。不希望被实例化的类的缺省构造方法声明为private。
    2:一般而言,接口定义行为,而抽象类定义属性和共有行为,注意2者的取舍,在设计中可由接口定义公用的行为,由一个抽象类来实现其部分或全部方法,以给子类提供统一的行为为定义。

    六 、方法

    一个方法只完成一项功能。方法参数类型和参数返回值尽量接口化,以屏蔽具体的实现细节,提高系统的可扩展性,例如:public  void  addUser(List userList){}
    public  List   listAllUsers(){}

    七、Web 命名规范

    一:jsp页面命名
    对于某个功能块的增删改查页面定义,最好使用
    xxx_add.jsp,xxx_delete.jsp,xxx_update.jsp,xxx_list.jsp.
    二:DAO层名称命名(接口层)     IXxxDao
    三:DAO层的实现层名称命名       XxxDaoImpl
    四:BO  层名称命名(接口层)     IXxxServ
    五:BO层的实现层名称命名        XxxServImpl
    六:struts中的命名规范  XxxForm ,XxxAction。
    七:工具类的命名规范   StringUtil ,  DataUtil。

    八 、性能与安全

    1:不要使用String str=new String(”abc”);这将产生2个对象,应当使用String str=”abc”;
    2:处理可变String 时候尽量使用StringBuffer类。
    3:尽量避免使用Vector 和HashTable等旧的集合实现。由于时实现时同步的,故大量操作带来不必要的性能损失。应使用ArrayList和HashMap来代替。如果一定要使用同步集合类,当使用如下方式:Map map=Collections.synchronizedMap(new HashMap());。
    4:避免在循环中频繁的构建和释放对象。
    5:如无必要,不要序列化对象。
    6:垃圾收集和资源释放,可能有异常的操作时必须在try的finally块中释放资源,如数据库连接,I/O操作等


    Java 自学免费加油站

    ​

    Java基础语法-面向对象-集合-IO-线程与并发-异常-网络编程
    java基础传送门: Java基础入门视频教程,零基础小白自学Java必备教程

    ​​

    Java进阶
    java进阶13天: Java13天进阶教程,深入学习Java编程核心思想
    API:  Java基础教程2020新版JDK8日期API解析

    ​​

    技术框架 Spring: Java进阶教程spring框架,深入浅出讲解细致
    SpringMVC+ mybatis: Springmvc+Mybatis由浅入深全套视频教程
    mybatis plus: MybatisPlus深入浅出教程,快速上手Mybatis-Plus
    spring data: java进阶教程数据层全栈方案Spring Data高级应用

    ​​

    分布式架构
    Zookeeper+Dubbo: Dubbo快速入门,Java分布式框架必会的教程
    Springcloud: SpringCloud从小白到精通教程
    Skywalking: java基础教程全面的深入学习Skywalking
    服务器中间件
    Rabbitmq: RabbitMQ全套教程,RabbitMQ消息中间件到实战面试
    Rocketmq: RocketMQ系统精讲,电商分布式消息中间件,硬核揭秘双十一
    Kafka: Kafka深入浅出,快速玩转分布式发布订阅消息系统
    Redis: Redis入门到精通,Java企业级解决方案必看
    MongoDB: java必备基础教程-MongoDB基础入门到高级进阶
    Apollo分布式: 轻松入门Apollo分布式配置中心-服务中间件
    服务器技术
    Tomcat: Java进阶教程Tomcat核心原理解析
    容器技术
    Docker: Docker容器化技术,从零学会Docker教程
    Kubernetes: Kubernetes(K8S)超快速入门教程

    ​​

    练手项目合集
    1.传智健康项目 https://www.bilibili.com/video/BV1Bo4y117zVa
    2.iHRM 人力资源管理系统 https://www.bilibili.com/video/BV18A411L7UXa
    3.Java项目《 万信金融》企业级开发实战 https://www.bilibili.com/video/BV1Ub4y1f7rka
    4.好客租房项目 https://www.bilibili.com/video/BV1sZ4y1F7PDa
    5.品优购V1.3.1项目实战 https://www.bilibili.com/video/BV1mi4y1L7Hta
    6.Java大型分布式微服务闪聚支付项目 https://www.bilibili.com/video/BV17v411V79c/a
    7.Java集信达短信平台实战 https://www.bilibili.com/video/BV1J

    ​​

    面试题:
    深入解读阿里等一线大厂java面试必考HashMap技术点
    Java面试热点问题,synchronized原理剖析与优化
    Java面试热门内容精讲之——并发编程volatile
    MySQL优化教程,超详细的MySQL数据库优化,Java面试热点必考问题

    觉得有帮助可以抓紧收藏,说不定啥时候失效了

  • 相关阅读:
    【C语言入门】ZZULIOJ 1026-1030
    MATLAB算法实战应用案例精讲-【图像处理】目标检测(附实战案例及代码实现)
    【web网页设计期末课程大作业】基于HTML+CSS+JavaScript仿山东传媒职业学院网站
    2023 收入最高的十大编程语言
    深入探索CSS3多列布局:重构文本流与网页排版的艺术
    Linux ARM平台开发系列讲解(CAN) 2.14.1 CAN基础协议分析
    【批量获取文件名及批量文件重命名】
    数据结构-线性表
    PYTHON快捷键合集!学会让你成为大一最靓的仔
    VMware vCenter 从6.7跨版本升级至7.0U3N
  • 原文地址:https://blog.csdn.net/m0_57290404/article/details/127843804
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号