函数参数约定


Function parameters convention

如果我有一个包含数十个参数的函数,是否可以使用变量名称作为指南?

例如:

public function addUser($user,$employeeno,$streetno,$street,$city,$state,
        $zip,$mobileno,$officeno,$email,$password,$division,$something,
        $something_else,$another_thing,$one_more) {
}

要添加用户,如果我执行以下操作会不会有问题:

.... addUser($user = 'hello', $empno = '123456', $streetno = '123',
             $street = 'Stack Overflow Avenue', $city = 'Stack City',
             $state = 'SC', $zip = 99999, $mob = '1234567890' // ... and so on

试过了,它奏效了,但是我应该知道任何影响吗?在我五年多的PHP经验中,我从未在其他人开发的示例代码和系统中遇到过这种情况。如果它是可靠的,这将允许我跟踪我正在传递函数或方法的信息。

没问题,你当然可以随心所欲地争论。当然,当它们被正确命名时,它会让你的生活更轻松。

当您忘记订单时,麻烦就会出现,甚至更糟的是想要修改它 - 这将变得难以维护,因为您需要在使用该功能的任何地方进行更改。

但是,您可以创建一个User类:

class User
{
  protected $username;
  protected $employeeNumber;
  protected $streetNumber;
  public function getUsername();
  public function setUsername($username);
  public function setEmployeeNumber($number);
}

然后在客户端代码中:

$user = new User();
$user->setUsername($user);
$user->setEmployeeNumber($employeeno);
//....

然后在register()函数上键入提示。

public function register(User $user)
{
  // Save the users data
}

最终结果是用户的所有数据都封装在 user 类中,因此任何更改都不需要对 register 函数进行任何进一步的修改。

如果你想

继续使用函数式编码,你可以总是使用数组。

$data = array("user" => "hello", "employeeno" => 123456, "streetno" => 123, "street" => "Stack Overflow Avenue"); // etc...
addUser($data);

或者,如果您想要更易于阅读的版本:

$data['user'] = "hello";
$data['employeeno'] = 123456;
$data['streetno'] = 123;
$data['street'] = "Stack Overflow Avenue";
addUser($data);

或者清理第一个版本:

$data = array("user" => "hello", 
"employeeno" => 123456, 
"streetno" => 123, 
"street" => "Stack Overflow Avenue"); // etc...
addUser($data);