设为首页收藏本站language→→ 语言切换

鸿鹄论坛

 找回密码
 论坛注册

QQ登录

先注册再绑定QQ

查看: 1544|回复: 1
收起左侧

PHP 编码规范-源文件的编码规范

[复制链接]
发表于 2010-2-24 13:42:54 | 显示全部楼层 |阅读模式
<><STRONG><FONT size=4>3.1 开头注释</FONT></STRONG></P><>所有的源文件都应该在开头有一个C语言风格的注释,其中列出类名、功能、版本信息、日期、作者和版权声明:</P><><BR>/*<BR> * 类名<BR> * 功能<BR> * 版本<BR> * 日期<BR> * 作者<BR> * 版权<BR> */<BR><BR>如果对文件进行了修改,应该在文件头中说明修改目的、修改日期、修改人,并变更文件的版本信息;如果修改问文件的一部分,则在文件中进行注释即可,并且标识出修改部分的起止位置</P><>……</P><>/*<BR> * 修改目的<BR> * 修改日期<BR> * 修改人<BR> * 版本<BR> */</P><>……<BR><BR>修改起始<BR><BR>……<BR><BR>……<BR><BR>修改结束<BR><BR>……</P><><STRONG><FONT size=4>3.2 引入语句</FONT></STRONG></P><>引入语句应该位于文件的头部,并在引入时说明引入文件的作用。例如:</P><>//数据库操作类<BR>require( “db.php” );</P><><STRONG><FONT size=4>3.3 类的声明</FONT></STRONG></P><>1 类文档注释(/**……*/) 该注释中所需包含的信息,参见"文档注释" <BR>2 类的声明<BR>3 类实现的注释(/*……*/)如果有必要的话 该注释应包含任何有关整个类的信息,而这些信息又不适合作为类文档注释。<BR>4 类的(静态)变量 首先是类的公共变量,随后是保护变量,再后是包一级别的变量(没有访问修饰符,access modifier),最后是私有变量。<BR>5 实例变量 首先是公共级别的,随后是保护级别的,再后是包一级别的(没有访问修饰符),最后是私有级别的。 <BR>6 构造器 <BR>7 方法 这些方法应该按功能,而非作用域或访问权限,分组。例如,一个私有的类方法可以置于两个公有的实例方法之间。其目的是为了更便于阅读和理解代码</P><><STRONG><FONT size=4>3.4 缩进排版</FONT></STRONG></P><>4个空格常被作为缩进排版的一个单位。缩进的确切解释并未详细指定(空格 vs. 制表符)。一个制表符等于8个空格(而非4个),所以在某些编辑器中,需要特别指定一下制表符的长度为4(UltraEdit),而在某些编辑器中,会将制表符转换为空格</P><><STRONG><FONT size=4>3.5 行长度</FONT></STRONG></P><>尽量避免一行的长度超过80个字符,因为很多终端和工具不能很好处理之。</P><><STRONG><FONT size=4>3.6 换行</FONT></STRONG></P><>当一个表达式无法容纳在一行内时,可以依据如下一般规则断开之:</P><>- 在一个逗号后面断开<BR>- 在一个操作符前面断开<BR>- 宁可选择较高级别(higher-level)的断开,而非较低级别(lower-level)的断开<BR>- 新的一行应该与上一行同一级别表达式的开头处对齐<BR>- 如果以上规则导致你的代码混乱或者使你的代码都堆挤在右边,那就代之以缩进8个空格。 </P><>以下是断开方法调用的一些例子:</P><><BR>someMethod(longExpression1, longExpression2, longExpression3, <BR>             longExpression4, longExpression5);</P><>$var = someMethod1(longExpression1, <BR>                 someMethod2(longExpression2, <BR>                              longExpression3));<BR></P><>以下是两个断开算术表达式的例子。前者更好,因为断开处位于括号表达式的外边,这是个较高级别的断开。</P><><BR>$longName1 = $longName2 * ($longName3 + $longName4 - $longName5)<BR>            + 4 * $longname6; //使用这种缩进方式</P><>$longName1 = $longName2 * ($longName3 + $longName4 <BR>                   - $longName5) + 4 * $longname6; //避免这种<BR></P><>以下是两个缩进方法声明的例子。前者是常规情形。后者若使用常规的缩进方式将会使第二行和第三行移得很靠右,所以代之以缩进8个空格</P><><BR>//传统的缩进方式<BR>function someMethod($anArg, $anotherArg, $yetAnotherArg, <BR>          $andStillAnother) {<BR>...<BR>}</P><>//利用8个连续空格避免过渡的缩进<BR>function horkingLongMethodName($anArg,<BR>     $anotherArg, $yetAnotherArg,<BR>     $andStillAnother) {<BR>...<BR>}<BR></P><>if语句的换行通常使用8个空格的规则,因为常规缩进(4个空格)会使语句体看起来比较费劲。比如:</P><><BR>//不要使用这种缩进方式<BR>if ((condition1 &amp;&amp; condition2)<BR>  || (condition3 &amp;&amp; condition4)<BR>  ||!(condition5 &amp;&amp; condition6)) { //错误的换行方式,没有进行缩进<BR>  doSomethingAboutIt(); //条件与此句对齐,造成阅读程序时很可能漏过此句<BR>}</P><>//应该使用这种缩进方式<BR>if ((condition1 &amp;&amp; condition2)<BR>    || (condition3 &amp;&amp; condition4)<BR>    ||!(condition5 &amp;&amp; condition6)) {<BR>  doSomethingAboutIt();<BR>}</P><>//或者这样的缩进方式也可以<BR>if ((condition1 &amp;&amp; condition2) || (condition3 &amp;&amp; condition4)<BR>        ||!(condition5 &amp;&amp; condition6)) {<BR>  doSomethingAboutIt();<BR>}<BR></P><>这里有三种可行的方法用于处理三元运算表达式:</P><>$alpha = (aLongBooleanExpression) ? beta : gamma;</P><>$alpha = (aLongBooleanExpression) ? beta<BR>                 : gamma;</P><>$alpha = (aLongBooleanExpression)<BR>    ? beta<BR>    : gamma;<BR></P>
发表于 2012-4-25 23:26:07 | 显示全部楼层
沙发 2012-4-25 23:26:07 回复 收起回复
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 论坛注册

本版积分规则

QQ|Archiver|手机版|小黑屋|sitemap|鸿鹄论坛 ( 京ICP备14027439号 )  

GMT+8, 2024-4-26 21:23 , Processed in 0.051257 second(s), 9 queries , Redis On.  

  Powered by Discuz!

  © 2001-2024 HH010.COM

快速回复 返回顶部 返回列表