PHP编码规范之注释和文件结构说明


Posted in PHP onJuly 09, 2010

文件结构

|??images
|??include

|??parameter

|??config

|??function
|??index
images存放图片文件,include中是系统是要引用的文件,一般在parameter中存放参数文件,config中存放配置文件,function中存放方法文件,如javascript的方法等,并按功能模块的分类,将各功能的类也放入其中
文件名
文件夹命名一般采用英文,长度一般不超过20个字符,命名采用小写字母。除特殊情况才使用中文拼音,一些常见的文件夹命名如:images(存放图形文件),flash(存放Flash文件),style(存放CSS文件),scripts(存放Javascript脚本),inc(存放include文件),link(存放友情链接),media(存放多媒体文件)等。文件名称统一用小写的英文字母、数字和下划线的组合。
块注释
块注释通常用于提供对文件,方法,数据结构和算法的描述。块注释被置于每个文件的开始处以及每个方法之前。它们也可以被用于其他地方,比如方法内部。在功能和方法内部的块注释应该和它们所描述的代码具有一样的缩进格式。
块注释之首应该有一个空行,用于把块注释和代码分割开来,比如:
/*
 * 这里是块注释
*/
块注释可以以/*-开头,这样indent(1)就可以将之识别为一个代码块的开始,而不会重排它。
/*-
 * 如果想被忽略,可是使用特别格式的块注释
 *
 * one
 *

two
 *

three
 */
注意:如果你不使用indent(1),就不必在代码中使用/*-,或为他人可能对你的代码运行indent(1)作让步。
单行注释
短注释可以显示在一行内,并与其后的代码具有一样的缩进层级。如果一个注释不能在一行内写完,就该采用块注释。单行注释之前应该有一个空行。以下是一个代码中单行注释的例子:
if (condition) {

/* 以下代码运行的条件 */

...
}
尾端注释
极短的注释可以与它们所要描述的代码位于同一行,但是应该有足够的空白来分开代码和注释。若有多个短注释出现于大段代码中,它们应该具有相同的缩进。
以下是一个代码中尾端注释的例子:

if ($a == 2) { 
return TRUE; /* 对单一条件的说明 */ 
} else { 

return isPrime($a); /* 其余的条件 */ 
}

行末注释
注释界定符"//",可以注释掉整行或者一行中的一部分。它一般不用于连续多行的注释文本;然而,它可以用来注释掉连续多行的代码段。以下是所有三种风格的例子:
if ($foo > 1) { 
// 第二种用法. 

... 
} 
else { 

return false; // 说明返回值的原因 
} 
//if ($bar > 1) { 
// 
//  // 第三种用法 
//  ... 
//} 
//else { 

// return false; 
//}

文档注释
文档注释描述php的类、构造器,方法,以及字段(field)。每个文档注释都会被置于注释定界符/**...*/之中,一个注释对应一个类或成员。该注释应位于声明之前:

/**
 * 说明这个类的一些 ...
*/
class Example { ...

注意顶层(top-level)的类是不缩进的,而其成员是缩进的。描述类的文档注释的第一行(/**)不需缩进;随后的文档注释每行都缩进1格(使星号纵向对齐)。成员,包括构造函数在内,其文档注释的第一行缩进4格,随后每行都缩进5格。
若你想给出有关类、变量或方法的信息,而这些信息又不适合写在文档中,则可使用实现块注释(见5.1.1)或紧跟在声明后面的单行注释(见5.1.2)。例如,有关一个类实现的细节,应放入紧跟在类声明后面的实现块注释中,而不是放在文档注释中。
文档注释不能放在一个方法或构造器的定义块中,因为程序会将位于文档注释之后的第一个声明与其相关联。

PHP 相关文章推荐
PHP实现Socket服务器的代码
Apr 03 PHP
php下通过curl抓取yahoo boss 搜索结果的实现代码
Jun 10 PHP
PHP程序漏洞产生的原因分析与防范方法说明
Mar 06 PHP
PHP随机数 C扩展随机数
May 04 PHP
示例详解Laravel重置密码代码重构
Aug 10 PHP
php排序算法实例分析
Oct 17 PHP
使用YII2框架实现微信公众号中表单提交功能
Sep 04 PHP
深入理解PHP的远程多会话调试
Sep 21 PHP
PHP生成短网址的思路以及实现方法的详解
Mar 25 PHP
解决laravel(5.5)访问public报错的问题
Oct 12 PHP
laravel框架分组控制器和分组路由实现方法示例
Jan 25 PHP
Yii框架小部件(Widgets)用法实例详解
May 15 PHP
PHP中开发XML应用程序之基础篇 添加节点 删除节点 查询节点 查询节
Jul 09 #PHP
php set_magic_quotes_runtime() 函数过时解决方法
Jul 08 #PHP
PHP 函数学习简单小结
Jul 08 #PHP
PHP 5.3.1 安装包 VC9 VC6不同版本的区别是什么
Jul 04 #PHP
PHP三层结构(上) 简单三层结构
Jul 04 #PHP
Apache 配置详解(最好的APACHE配置教程)
Jul 04 #PHP
PHP中文URL编解码(urlencode()rawurlencode()
Jul 03 #PHP
You might like
php的header和asp中的redirect比较
2006/10/09 PHP
PHP 数据库树的遍历方法
2009/02/06 PHP
用Zend Encode编写开发PHP程序
2010/02/21 PHP
php !function_exists("T7FC56270E7A70FA81A5935B72EACBE29"))代码解密
2011/01/07 PHP
Extjs ajax同步请求时post方式参数发送方式
2009/08/05 Javascript
jquery获取特定name所有选中的checkbox,支持IE9标准模式
2013/03/18 Javascript
JS获取下拉列表所选中的TEXT和Value的实现代码
2014/01/11 Javascript
JavaScript字符串对象substr方法入门实例(用于截取字符串)
2014/10/16 Javascript
angularjs中的e2e测试实例
2014/12/06 Javascript
jQuery学习心得总结(必看篇)
2016/06/10 Javascript
artDialog+plupload实现多文件上传
2016/07/19 Javascript
ES6通过babel转码使用webpack使用import关键字
2016/12/13 Javascript
AngularJS学习第一篇 AngularJS基础知识
2017/02/13 Javascript
AngularJS中$http的交互问题
2017/03/29 Javascript
vue-router路由懒加载和权限控制详解
2017/12/13 Javascript
webpack 模块热替换原理
2018/04/09 Javascript
在vue中把含有html标签转为html渲染页面的实例
2019/10/28 Javascript
微信小程序页面间传递数组对象方法解析
2019/11/06 Javascript
echarts饼图各个板块之间的空隙如何实现
2020/12/01 Javascript
[01:50:49]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Aster BO3 第三场 1月24日
2021/03/11 DOTA
[01:00:49]DOTA2-DPC中国联赛 正赛 Ehome vs iG BO3 第二场 1月31日
2021/03/11 DOTA
python解析xml模块封装代码
2014/02/07 Python
在Python中操作字典之setdefault()方法的使用
2015/05/21 Python
python list转矩阵的实例讲解
2018/08/04 Python
Python八皇后问题解答过程详解
2019/07/29 Python
html5新特性与用法大全
2018/09/13 HTML / CSS
详解HTML5中ol标签的用法
2015/09/08 HTML / CSS
ReVive利维肤美国官网:RéVive Skincare
2018/04/18 全球购物
美国领先的低折扣旅行网站:Hotwire
2019/01/19 全球购物
英国网上电器商店:Electricshop
2020/03/15 全球购物
地球鞋加拿大官网:Earth Shoes Canada
2020/11/17 全球购物
大学生军训广播稿
2014/01/24 职场文书
公司年会主持词
2014/03/22 职场文书
《用字母表示数》教学反思
2016/02/17 职场文书
Windows10下安装MySQL8
2021/04/06 MySQL
Spring Cloud OpenFeign模版化客户端
2022/06/25 Java/Android