PHP编码规范实例
<?php | |
/** | |
* 符合psr-1,2的编程实例 | |
* | |
* @author 作者 描述 | |
*/ | |
namespace Standard; // 顶部命名空间 | |
// 空一行 | |
use Test\TestClass;//use引入类 | |
/** | |
* 类描述 | |
* | |
* 类名必须大写开头驼峰. | |
*/ | |
abstract class StandardExample // {}必须换行 | |
{ | |
/** | |
* 常量描述. | |
* | |
* @var string | |
*/ | |
const THIS_IS_A_CONST = ''; // 常量全部大写下划线分割 | |
/** | |
* 属性描述. | |
* | |
* @var string | |
*/ | |
public $nameTest = ''; // 属性名称建议开头小写驼峰 | |
// 成员属性必须添加public(不能省略), private, protected修饰符 | |
/** | |
* 属性描述. | |
* | |
* @var string | |
*/ | |
private $_privateNameTest = ''; // 类私有成员属性,【个人建议】下划线小写开头驼峰 | |
/** | |
* 构造函数. | |
* | |
* 构造函数描述 | |
* | |
* @param string $value 形参名称/描述 | |
*/ | |
public function __construct($value = '')// 成员方法必须添加public(不能省略), private, protected修饰符 | |
{// {}必须换行 | |
$this->nameTest = new TestClass(); | |
// 链式操作 | |
$this->nameTest->functionOne() | |
->functionTwo() | |
->functionThree(); | |
// 一段代码逻辑执行完毕 换行 | |
// code... | |
} | |
/** | |
* 成员方法名称. | |
* | |
* 成员方法描述 | |
* | |
* @param string $value 形参名称/描述 | |
* | |
* @return 返回值类型 返回值描述 | |
* 返回值类型:string,array,object,mixed(多种,不确定的),void(无返回值) | |
*/ | |
public function testFunction($value = '')// 成员方法必须小写开头驼峰 | |
{ | |
// code... | |
} | |
/** | |
* 成员方法名称. | |
* | |
* 成员方法描述 | |
* | |
* @param string $value 形参名称/描述 | |
* | |
* @return 返回值类型 返回值描述 | |
*/ | |
private function _privateTestFunction($value = '')// 私有成员方法【个人建议】下划线小写开头驼峰 | |
{ | |
// code... | |
} | |
/** | |
* 成员方法名称. | |
* | |
* 成员方法描述 | |
* | |
* @param string $value 形参名称/描述 | |
* | |
* @return 返回值类型 返回值描述 | |
*/ | |
public static function staticFunction($value = '')// static位于修饰符之后 | |
{ | |
// code... | |
} | |
/** | |
* 成员方法名称. | |
* | |
* 成员方法描述 | |
* | |
* @param string $value 形参名称/描述 | |
* | |
* @return 返回值类型 返回值描述 | |
*/ | |
abstract public function abstractFunction($value = ''); // abstract位于修饰符之前 | |
/** | |
* 成员方法名称. | |
* | |
* 成员方法描述 | |
* | |
* @param string $value 形参名称/描述 | |
* | |
* @return 返回值类型 返回值描述 | |
*/ | |
final public function finalFunction($value = '')// final位于修饰符之前 | |
{ | |
// code... | |
} | |
/** | |
* 成员方法名称. | |
* | |
* 成员方法描述 | |
* | |
* @param string $valueOne 形参名称/描述 | |
* @param string $valueTwo 形参名称/描述 | |
* @param string $valueThree 形参名称/描述 | |
* @param string $valueFour 形参名称/描述 | |
* @param string $valueFive 形参名称/描述 | |
* @param string $valueSix 形参名称/描述 | |
* | |
* @return 返回值类型 返回值描述 | |
*/ | |
public function tooLangFunction( | |
$valueOne = '', // 变量命名可小写开头驼峰或者下划线命名,个人那习惯,据说下划线可读性好 | |
$valueTwo = '', | |
$valueThree = '', | |
$valueFour = '', | |
$valueFive = '', | |
$valueSix = '')// 参数过多换行 | |
{ | |
if ($valueOne === $valueTwo) {// 控制结构=>后加空格,同{一行,(右边和)左边不加空格 | |
// code... | |
} | |
switch ($valueThree) { | |
case 'value': | |
// code... | |
break; | |
default: | |
// code... | |
break; | |
} | |
do { | |
// code... | |
} while ($valueFour <= 10); | |
while ($valueFive <= 10) { | |
// code... | |
} | |
for ($i = 0; $i < $valueSix; $i++) { | |
// code... | |
} | |
} | |
} |
PHP编码规范实例的更多相关文章
- Objective-C开发编码规范【转载】
概要 Objective-C是一门面向对象的动态编程语言,主要用于编写iOS和Mac应用程序.关于Objective-C的编码规范,苹果和谷歌都已经有很好的总结: Apple Coding Guide ...
- 【转】JavaScript 风格指南/编码规范(Airbnb公司版)
原文转自:http://blog.jobbole.com/79484/ Airbnb 是一家位于美国旧金山的公司,本文是其内部的 JavaScript 风格指南/编码规范,在 Github 上有 11 ...
- 资料推荐--Google Java编码规范
之前已经推荐过Google的Java编码规范英文版了: http://google-styleguide.googlecode.com/svn/trunk/javaguide.html 虽然这篇文章的 ...
- 【转】Airbnb React编码规范
Airbnb的编码规范是在业界非常流行的一套规范,而且它一直都在进化,推出最新技术的规范 原文:https://zhuanlan.zhihu.com/p/20616464 用更合理的方式书写React ...
- Python + OpenCV2 系列:3 - python 字符串,类,编码规范
首先,强烈推荐<<简明 Python 教程>> Swaroop, C. H. 著 沈洁元 译 其实,这本书里已经把python的最基本的用法,编码等等介绍的很好,这里把我用到的 ...
- Bootstrap编码规范
黄金定律 永远遵循同一套编码规范 -- 可以是这里列出的,也可以是你自己总结的.如果你发现本规范中有任何错误,敬请指正.通过 open an issue on GitHub为本规范添加或贡献内容. 不 ...
- iOS 注释的5要3不要和编码规范的26个方面
注释 代码注释,可以说是比代码本身更重要.这里有一些方法可以确保你写在代码中的注释是友好的: 不要重复阅读者已经知道的内容 能明确说明代码是做什么的注释对我们是没有帮助的. // If the col ...
- [iOS翻译]Cocoa编码规范
简介: 本文整理自Apple文档<Coding Guidelines for Cocoa>.这份文档原意是给Cocoa框架.插件及公共API开发者提供一些编码指导,实质上相当于Ap ...
- 网易前端JavaScript编码规范
在多年开发邮箱webmail过程中,网易邮箱前端团队积累了不少心得体会,我们开发了很多基础js库,实现了大量前端效果组件,开发了成熟的opoa框架以及api组件,在此向大家做一些分享.今天想先和大家聊 ...
随机推荐
- iOS开发——实时监控网速(仅作参考,发现一点问题)
开发中用到获取网速的地方,应该就两种: 1.下载速度,这种可以直接在接受数据的地方统计计算.这个就不讲了. 2.获取手机网卡的数据,可以监控网卡的进出流量,下面就是. #import "Vi ...
- Reinstall the Arduino Pro Mini Bootloade ISP(转)
源:Reinstall the Arduino Pro Mini Bootloade ISP To resolve the errors I burned the bootloader to the ...
- 通过Jenkins跑Jmeter接口测试脚本,我想当有接口跑失败时Jenkins发送邮件通知,这个如何弄呢
通过Jenkins跑Jmeter接口测试脚本,我想当有接口跑失败时Jenkins发送邮件通知,这个如何弄呢
- linux 文件类型识别
使用 ls -aldrwxr-xr-x. 4 root root 100 Apr 26 15:05 cpulrwxrwxrwx. 1 root root 13 Apr 26 15:05 fd -> ...
- <Natural Language Processing with Python>学习笔记一
Spoken input (top left) is analyzed, words are recognized, sentences are parsed and interpreted in c ...
- MySQL引擎简述
MySQL数 据库引擎取决于MySQL在安装的时候是如何被编译的.要添加一个新的引擎,就必须重新编译MYSQL.在缺省情况下,MYSQL支持三个引擎:ISAM.MYISAM和HEAP.另外两种类型IN ...
- realm-java 源码疑问
JNIEXPORT void JNICALL Java_io_realm_internal_Group_nativeWriteToFile( JNIEnv* env, jobject, jlong n ...
- iOS开发——An App ID with identifier "*****" is not avaliable
Error: An App ID with identifier "*****" is not avaliable. Please enter a different string ...
- STM32驱动DS18B20
DS18B20 是由 DALLAS 半导体公司推出的一种的“一线总线”接口的温度传感器.与传 统的热敏电阻等测温元件相比,它是一种新型的体积小.适用电压宽.与微处理器接口简单的 数字化温度传感器.一线 ...
- ios UIKit动力
UIkit动力学是UIkit框架中模拟真实世界的一些特性. UIDynamicAnimator 主要有UIDynamicAnimator类,通过这个类中的不同行为来实现一些动态特性. 它一般有两种初始 ...