4

我有以下数据结构:

AContract有一个数组projects,可以有 X 个项目。每个Project都有一个数组,subProjects包含相同的Project类型,所以理论上你可以有一个无限的 Project-SubProjects-Project...

无论如何,每个项目都有一个唯一的 ID,我需要搜索一个给定的项目并对那个项目进行修改,从顶层开始,然后将更改的合同存储回我的会话。目前,我正在通过一个递归函数来执行此操作,该函数返回对它找到的项目的引用,但我搜索的越多,人们似乎越不喜欢 PHP 引用。我不确定为什么,有人可以解释这些问题吗?有没有更好的方法来做我想做的事?

一些代码:

// Get the associative array version of the contract (it's stored as JSON)
$contract = json_decode($contract, true);

if(array_key_exists('projects', $contract))
{
    $resultProject = &$this->findProject($contract['projects'], $projectId);

    if($resultProject)
    {
        $resultProject[$inputData['propertyName']] = $inputData['value'];

         \Session::put('workingContract', json_encode($contract));

        // return 200
    }
}

// Return 404

/**
 * Performs a depth-first search to find a project.
 *
 * @param array $projects
 * @param $projectId
 * @return null
 */
private function &findProject(array &$projects, $projectId)
{
    foreach($projects as &$project)
    {
        if($project['_id']['$id'] == $projectId)
        {
            return $project;
        }

        if(array_key_exists('subProjects', $project))
        {
            $result = &$this->findProject($project['subProjects'], $projectId);
            return $result;
        }
    }

    $null = null; // TODO: shitty hack for inability to return null when function returns a reference. Need to rethink use of references in general. Is there another way???
    return $null;
}
4

1 回答 1

1

为什么不创建一个包含所有项目的数组(一个平面数组),索引为ID. 让每个Project对象都有一个->id可以引用的属性。问题解决了?

另外,如果Project平面数组中不存在 ,我认为返回绝对没有问题null

class Contract {
   private $projects_flat = array();

   ....

   private function get_project($id) {
      return (isset($this->projects_flat[$id]) ? $this->projects_flat[$id] : null)
   }
}
于 2013-09-20T13:19:53.937 回答