开发规范

应用程序目录

应用程序目录可以放到任意位置

入口文件

和nginx+PHP-FPM下的PHP应用程序一样,WorkerMan中的应用程序也需要一个入口文件,入口文件名没有要求,并且这个入口文件是以PHP Cli方式运行的。

入口文件中是创建监听进程相关的代码,例如下面的基于Worker开发的代码片段

test.php

  1. <?php
  2. use Workerman\Worker;
  3. require_once __DIR__ . '/Workerman/Autoloader.php';
  4. // 创建一个Worker监听2345端口,使用http协议通讯
  5. $http_worker = new Worker("http://0.0.0.0:2345");
  6. // 启动4个进程对外提供服务
  7. $http_worker->count = 4;
  8. // 接收到浏览器发送的数据时回复hello world给浏览器
  9. $http_worker->onMessage = function($connection, $data)
  10. {
  11. // 向浏览器发送hello world
  12. $connection->send('hello world');
  13. };
  14. Worker::runAll();

WorkerMan中的代码规范

1、类采用首字母大写的驼峰式命名,类文件名称必须与文件内部类名相同,以便自动加载。例如:

  1. class UserInfo
  2. {
  3. ...

2、使用命名空间,命名空间名字与目录路径对应,并以开发者的项目根目录为基准。

例如项目MyApp/,类文件MyApp/MyClass.php因为在项目根目录,所以命名空间省略。类文件MyApp/Protocols/MyProtocol.php因为MyProtocol.php在MyApp项目的Protocols目录下,所以要加上命名空间 namespace Protocols;,如下:

  1. namespace Protocols;
  2. class MyProtocol
  3. {
  4. ....

3、普通函数及变量名采用小写加下划线方式 例如

  1. $connection_list = array();
  2. function get_connection_list()
  3. {
  4. ....

4、类成员及类的方法采用首字母小写的驼峰形式 例如:

  1. public $connectionList;
  2. public function getConnectionList();

5、函数及类的参数采用小写加下划线方式

  1. function get_connection_list($one_param, $tow_param)
  2. {
  3. ....