- 浏览: 3547408 次
- 性别:
- 来自: 大连
博客专栏
-
使用Titanium Mo...
浏览量:38127
-
Cordova 3.x入门...
浏览量:607210
-
常用Java开源Libra...
浏览量:682200
-
搭建 CentOS 6 服...
浏览量:89283
-
Spring Boot 入...
浏览量:401743
-
基于Spring Secu...
浏览量:69673
-
MQTT入门
浏览量:91673
文章分类
最新评论
-
afateg:
阿里云的图是怎么画出来的?用什么工具?
各云服务平台的架构图 -
cbn_1992:
博主,采用jdbctoken也就是数据库形式之后,反复点击获取 ...
Spring Security OAuth2 Provider 之 数据库存储 -
ipodao:
写的很是清楚了,我找到一份中文协议:https://mcxia ...
MQTT入门(6)- 主题Topics -
Cavani_cc:
还行
MQTT入门(6)- 主题Topics -
fexiong:
博主,能否提供完整源码用于学习?邮箱:2199611997@q ...
TensorFlow 之 构建人物识别系统
良好的代码风格能提高代码可读性及可维护性,程序员都应该遵守基本的代码排版规范、代码命名规范。
首先看看以下三张图,在没有代码的情况下能猜猜各是什么开发语言。
---------------------------------------------------------------
---------------------------------------------------------------
---------------------------------------------------------------
第一张图是CSS,可以看到清晰的选择器和属性键值对。
第二张图是HTML,可以看到清晰的head和body定义。
第三张图是Java,可以看到头部imports,类定义,成员变量,构造函数以及其他方法。
图片来自:https://schneide.wordpress.com/2015/04/26/the-typography-of-source-code/
各个语言都有自己的规范,开发所用的各种IDE也都内置了代码格式化工具,比如Eclipse对Java和JavaScript代码的标准格式化定义:
也可以通过 Checkstyle 检查Java代码的规范性。
这里罗列几个最有争议的。
(1)缩进
使用Tab 还是空格?2个空格还是4个空格?具体关于这个网上的争论太多了,但是需要特别注意的是像Python和CoffeeScript等是通过缩进来控制代码逻辑。
https://softwareengineering.stackexchange.com/questions/57/tabs-versus-spaces-what-is-the-proper-indentation-character-for-everything-in-e
https://medium.com/@hoffa/400-000-github-repositories-1-billion-files-14-terabytes-of-code-spaces-or-tabs-7cfe0b5dd7fd
(2)换行
大括号是否应该换行?
https://softwareengineering.stackexchange.com/questions/2715/should-curly-braces-appear-on-their-own-line
大括号是否应该省略?
https://stackoverflow.com/questions/8020228/is-it-ok-if-i-omit-curly-braces-in-java
(3)对齐
赋值等号对齐
注释对齐
参数对齐
链式方法对齐
(4)空行
合理的利用空行来区分代码块。
(5)命名
违反命名规范的例子有很多,这里列2个:
非驼峰命名
连续编号
再列举一些代码书写上的其他Style。
(1)多层嵌套 还是 中途退出?
(2)常量放在左侧还是右侧?
https://stackoverflow.com/questions/2369226/object-null-or-null-object
(3)定义接口类型还是实现类型?
(4)标准for循环还是增强for循环?
(5)变量是否需要先定义为null?
*** 成员变量有默认值不需要赋值null,本地变量没有默认值需要赋值null。
(6)通过class还是interface定义全局常量?
还有这么定义的:
这些都是常见的,还有很多。
首先看看以下三张图,在没有代码的情况下能猜猜各是什么开发语言。
---------------------------------------------------------------
---------------------------------------------------------------
---------------------------------------------------------------
第一张图是CSS,可以看到清晰的选择器和属性键值对。
第二张图是HTML,可以看到清晰的head和body定义。
第三张图是Java,可以看到头部imports,类定义,成员变量,构造函数以及其他方法。
图片来自:https://schneide.wordpress.com/2015/04/26/the-typography-of-source-code/
各个语言都有自己的规范,开发所用的各种IDE也都内置了代码格式化工具,比如Eclipse对Java和JavaScript代码的标准格式化定义:
也可以通过 Checkstyle 检查Java代码的规范性。
这里罗列几个最有争议的。
(1)缩进
使用Tab 还是空格?2个空格还是4个空格?具体关于这个网上的争论太多了,但是需要特别注意的是像Python和CoffeeScript等是通过缩进来控制代码逻辑。
https://softwareengineering.stackexchange.com/questions/57/tabs-versus-spaces-what-is-the-proper-indentation-character-for-everything-in-e
https://medium.com/@hoffa/400-000-github-repositories-1-billion-files-14-terabytes-of-code-spaces-or-tabs-7cfe0b5dd7fd
(2)换行
大括号是否应该换行?
if (you.hasAnswer()) { you.postAnswer(); } else { you.doSomething(); }
if (you.hasAnswer()) { you.postAnswer(); } else { you.doSomething(); }
if (you.hasAnswer()) you.postAnswer(); else you.doSomething();
https://softwareengineering.stackexchange.com/questions/2715/should-curly-braces-appear-on-their-own-line
大括号是否应该省略?
for (int i = 0; i < size; i++) { a += b; }
for (int i = 0; i < size; i++) a += b;
for (int i = 0; i < size; i++) a += b;
https://stackoverflow.com/questions/8020228/is-it-ok-if-i-omit-curly-braces-in-java
(3)对齐
赋值等号对齐
int a_variable = 1; int another_variable = 2; int yet_another_variable = 3;
注释对齐
// whole line comment int linePointer; // inline comment BufferredReader br = new BufferredReader(); // inline comment File f = new File(); // inline comment
参数对齐
int some_call_result = some_object.a_method( with, quite_long, list_of, parameters );
链式方法对齐
protected void configure(HttpSecurity http) throws Exception { http .authorizeRequests() .antMatchers("/resources/**", "/signup", "/about").permitAll() .antMatchers("/admin/**").hasRole("ADMIN") .antMatchers("/db/**").access("hasRole('ADMIN') and hasRole('DBA')") .anyRequest().authenticated() .and() .formLogin(); }
(4)空行
合理的利用空行来区分代码块。
/** * Initialize this servlet. Most of the processing has been factored * into support methods so that you can override particular functionality * at a fairly granular level. * * @throws ServletException if we cannot configure ourselves correctly */ public void init() throws ServletException { final String configPrefix = "config/"; final int configPrefixLength = configPrefix.length() - 1; // Wraps the entire initialization in a try/catch to better handle // unexpected exceptions and errors to provide better feedback // to the developer try { initInternal(); initOther(); initServlet(); initChain(); getServletContext().setAttribute(Globals.ACTION_SERVLET_KEY, this); initModuleConfigFactory(); // Initialize modules as needed ModuleConfig moduleConfig = initModuleConfig("", config); initModuleMessageResources(moduleConfig); initModulePlugIns(moduleConfig); initModuleFormBeans(moduleConfig); initModuleForwards(moduleConfig); initModuleExceptionConfigs(moduleConfig); initModuleActions(moduleConfig); moduleConfig.freeze(); Enumeration names = getServletConfig().getInitParameterNames(); while (names.hasMoreElements()) { String name = (String) names.nextElement(); if (!name.startsWith(configPrefix)) { continue; } String prefix = name.substring(configPrefixLength); moduleConfig = initModuleConfig(prefix, getServletConfig().getInitParameter(name)); initModuleMessageResources(moduleConfig); initModulePlugIns(moduleConfig); initModuleFormBeans(moduleConfig); initModuleForwards(moduleConfig); initModuleExceptionConfigs(moduleConfig); initModuleActions(moduleConfig); moduleConfig.freeze(); } this.initModulePrefixes(this.getServletContext()); this.destroyConfigDigester(); } catch (UnavailableException ex) { throw ex; } catch (Throwable t) { // The follow error message is not retrieved from internal message // resources as they may not have been able to have been // initialized log.error("Unable to initialize Struts ActionServlet due to an " + "unexpected exception or error thrown, so marking the " + "servlet as unavailable. Most likely, this is due to an " + "incorrect or missing library dependency.", t); throw new UnavailableException(t.getMessage()); } }
(5)命名
违反命名规范的例子有很多,这里列2个:
非驼峰命名
package com.test.EC_shop; public class db_manager { private String connection_url; public void Init() { // ... } }
连续编号
public class UC8010 extends CMN0101 { private String FLD0001; public int MTD0001() { // ... } } publi class UC8020 extends CMN0101 { private String FLD0001; public int MTD0001() { // ... } }
再列举一些代码书写上的其他Style。
(1)多层嵌套 还是 中途退出?
public String getInsuranceName(Employee employee) { if (employee != null) { Car car = employee.getCar(); if (car != null) { Insurance insurance = car.getInsurance(); if (insurance != null) { return insurance.getName(); } } } return "UNKNOWN"; }
public String getInsuranceName(Employee employee) { if (employee == null) { return "UNKNOWN"; } Car car = employee.getCar(); if (car == null) { return "UNKNOWN"; } Insurance insurance = car.getInsurance(); if (insurance == null) { return "UNKNOWN"; } return insurance.getName(); }
(2)常量放在左侧还是右侧?
if (currentValue == 5) { // do work } if (5 == currentValue) { // do work }
if (obj == null) { } if (null == obj) { } if (obj = null) { // 赋值运算、NPE异常 } if (null = obj) { // 编译错误 }
https://stackoverflow.com/questions/2369226/object-null-or-null-object
(3)定义接口类型还是实现类型?
List<Integer> sampleList = new ArrayList<Integer>();
ArrayList<Integer> sampleList = new ArrayList<Integer>();
(4)标准for循环还是增强for循环?
for (int i = 0; i < peopleList.size(); i++) { People p = peopleList.get(i); // .. }
for (People p : peopleList) { // ... }
(5)变量是否需要先定义为null?
Object localVariableObj2 = null; localVariableObj2 = new Object();
Object localVariableObj2 = new Object();
*** 成员变量有默认值不需要赋值null,本地变量没有默认值需要赋值null。
(6)通过class还是interface定义全局常量?
public final class Constants { public static final int PI = 3.14; }
public interface Constants { int PI = 3.14; }
还有这么定义的:
public interface Constants { public static final String TOAST = "toast"; }
这些都是常见的,还有很多。
发表评论
-
关于英文缩写
2017-04-14 10:21 1370和中文缩写一样,英文也存在各种各样的缩写,多以词组首字母缩写为 ... -
关于Bootstrap主题模板
2017-04-06 08:54 1439无论Bootstrap还是其他衍生的模板大部分都是以英文为内容 ... -
关于整理归纳
2017-03-14 10:25 1184整理归纳虽然是个人习惯,但善于整理归纳的人做事更有条理、更有效 ... -
关于远程操作
2017-03-10 13:47 1330(1)远程共享 1)SMB/CIFS(Windows) Wi ... -
关于保留字和敏感词
2017-02-27 14:56 2073保留字、敏感词过滤是网站系统必不可少的2个功能。 (1)保留 ... -
关于开发文档
2017-02-22 13:13 962(1)官方文档 开发语言、开源框架、开源软件都会为开发者提供了 ... -
Excel打开CSV文件乱码的问题
2016-11-08 10:47 5397系统管理功能中,很多 ... -
开发Hubot聊天机器人
2016-10-09 14:06 8914大家所熟知的智能聊天机器人,比如:微软小冰、Apple Sir ... -
有趣的程序员面试
2016-08-03 09:21 2516关于面试有很多参考的资料,比如:有出版的书,有在线的视频,有讲 ... -
抓取 开发者头条 分享的所有文章
2016-07-29 14:57 1804使用 HttpClient 和 jsoup 抓取开发者头条中分 ... -
EC2(CentOS7) + ShadowSocks
2015-08-04 11:27 3041前提: 需要有一个 Amazon 的账号,并且完善账户信息与信 ... -
程序员如何不断提高自己?
2015-06-09 17:16 3046没有超人,关注该关注的即可! (一) 如果遇到问题,先Goo ... -
你所不知道的<html>, <head>, <body>
2014-10-10 15:48 1974(1)HTML并没有要求一 ... -
Apache Cordova 3.x入门 -- 目录结构
2014-02-13 15:10 7(1)目录一览: 引用myApp/ |-- config.xm ... -
Apache Cordova 3.x入门 -- 常用命令
2014-02-13 15:09 4(1)create <directory> [&l ... -
通过yum在CentOS 6中安装Asterisk 12
2014-01-21 12:47 1061、将OS更新到最新。 引用yum update -y ... -
二维码生成器
2013-12-05 14:02 1921(1)QR Code generator http://www ... -
碉堡了的简历,膜拜之!
2013-11-28 18:08 13824→2014/04/11 追加 没想到这篇旧文被推动CSDN极客 ... -
IE 404等错误定制页面
2013-11-25 15:37 1819在web.xml中配置自定义错误页面: <error-p ... -
Code Beautify
2013-10-30 11:13 83Code Beautify http://codebeauti ...
相关推荐
【程序员之路———关于代码风格】的探讨主要集中在代码风格的重要性、代码行极限、缩进方式、折行原则以及空格和空行的使用。这些规范对于任何程序员来说都是提高代码可读性和团队协作效率的基础。 1. **代码行...
该文档详细地介绍了代码风格指南,并且详细地阐述了在Verilog编码过程中应该如何遵循命名约定、编码风格以及严重性级别。 ### 命名约定和编码风格 首先,文档强调了文件中只能包含一个模块,这是为了简化源代码...
在iOS开发中,保持良好的代码风格对于团队协作和项目的维护至关重要。Swift作为一种强类型、安全且高度可读的编程语言,其代码风格的规范性更显得尤为重要。本篇将深入探讨如何在Swift项目中进行有效的代码风格管理...
Linux内核代码风格是一份关于Linux操作系统内核编程的指南,它详细规定了代码的编写习惯,以便提高代码的可读性和可维护性。本知识点将基于给定文档的内容,详细介绍Linux内核代码风格的各个方面。 首先,文档指出...
以下是一些关于Verilog代码风格的重要知识点: 1. **注释**:清晰的注释是任何代码的基础。在模块、接口、函数和关键逻辑部分添加注释,解释其功能和用途。注释应简洁明了,避免过于冗长。 2. **模块结构**:模块...
标题中的“用于VS、Vscode、Clion的代码风格文件”指的是为Visual Studio (VS)、Visual Studio Code (Vscode) 和 CLion 这三款流行的集成开发环境(IDE)提供的代码格式化配置文件。这些文件通常包含了特定的规则和...
在开发团队中,为了确保代码的可读性和一致性,统一代码风格是非常重要的。通常,团队会选择使用流行的集成开发环境(IDE),如IntelliJ IDEA和Eclipse进行开发工作。为了在两个不同的IDE中保持代码风格的一致性,...
Java代码审查表中关于代码风格和格式规则的重要性激活级别检查项有: * 代码段落是否被合适地以空行分隔?(Y20) * 是否合理地使用了空格使程序更清晰?(20) * 代码行长度是否在要求之内?(20) * 是否折行是否...
通过《代码阅读方法与实践》这本书,读者不仅可以学到关于代码风格的基础知识,还能了解到如何通过实践来提高代码的质量。本书通过具体的示例分析,强调了良好的代码风格对于软件开发的重要性,并提供了实用的指南来...
1. **代码风格检查**:StyleCop检查一系列关于代码风格的规定,例如命名约定(变量、类、方法等的命名规则)、注释要求(如需包含XML注释)、代码布局(空格、缩进、换行等)以及代码结构(如避免使用嵌套的using...
通过安装和使用这个插件,开发者可以在编码过程中实时收到关于代码风格和潜在问题的提示,从而及时纠正,提高开发效率。 1. **Intellij IDEA插件安装**: - 打开Intellij IDEA,进入设置(Settings)或首选项...
这个工具旨在消除关于代码风格的争论,通过自动格式化Python源代码,使其遵循PEP 8编码规范,从而提升团队协作效率和代码一致性。Black的独特之处在于它的硬性规定,它不提供任何配置选项,而是以一种“零配置”理念...
通过以上解释,我们可以理解这个压缩包中的内容是关于Eclipse集成CheckStyle的配置文件和操作指南,对于保持团队代码风格的一致性至关重要。开发者可以根据这些资源轻松地在自己的开发环境中实施代码风格检查。
关于代码风格,可以参考Airbnb或Google等知名公司提供的JavaScript编码规范。这些规范通常包含对缩进、空格、括号放置等方面的指导,比如使用2个空格作为缩进,函数参数之间和操作符周围添加空格等。 为了自动化...
在IT行业中,编程规范、注释规范以及代码风格是软件开发中的重要组成部分,尤其是在大型企业如华为这样的公司中,它们被视为保证代码质量、提高团队协作效率的关键准则。这些规范不仅有助于提升代码的可读性和可维护...
《Delphi代码风格规范》是指导开发者在使用Delphi编程时遵循的一套约定,旨在提高代码的可读性、可维护性和团队协作效率。本文将深入探讨这些规范,并结合相关资源进行阐述。 首先,规范中强调了命名约定。在Delphi...
### 匈牙利命名法:好的代码风格是成为优秀程序员的第一步 在软件开发领域,良好的编程习惯与规范是每一个程序员成长道路上不可或缺的部分。其中,匈牙利命名法则是一种广泛应用于C、C++等语言中的变量命名约定,它...
【Linux内核代码风格】是Linux开发中遵循的一套编程规范,旨在确保代码的清晰度、可读性和可维护性。这份文档虽然简洁,但包含了关于缩进、行宽、大括号放置以及空格使用等方面的重要指导原则。 首先,**缩进**是...
在源代码中查找他的名字可以提供关于代码风格和思路的线索。 对于初学者来说,研究这个项目可以学习到以下关键知识点: 1. C#的基本语法和数据类型。 2. 如何定义和调用方法。 3. C#中的类和对象概念。 4. WPF或...
"统一文件编码和代码风格,提高代码可读性(eclipse设置)"这个主题聚焦于如何通过Eclipse集成开发环境来实现这一目标。Eclipse作为一个强大的Java IDE,也支持多种其他语言,它提供了丰富的功能来帮助开发者规范...