我有以下数据结构:
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;
}