简而言之
为什么返回错误数组排序的函数会在我调用print_r()或var_dump()排序之前的数组时返回预期的排序?
细节
我正在尝试打印从几个谷歌日历收集的接下来几个事件的基本信息,这些信息uasort()根据事件开始日期/时间按自定义排序。
function getUpcomingEvents()
{
$calUrls = array( /* Four Google calendar URLs */);
foreach ($calUrls as $url)
{
$calEvents = json_decode(file_get_contents($url), true);
for($i=0; $i<count($calEvents['items']); $i++)
{
$item = $calEvents['items'][$i];
$events[] = array(
'title' => $item['summary'],
'description' => $item['description'],
'start' => date_create($item['start']['dateTime']),
'end' => date_create($item['end']['dateTime']),
'htmlLink' => $item['htmlLink']
);
}
}
//print_r($events); // <-- **LOOK AT ME**
uasort($events, function($a, $b) {
return strtotime($a['start']->date) - strtotime($b['start']->date);
});
return $events;
}
...*snip*...
<?php foreach(getUpcomingEvents() as $event) : ?>
<li><h3><?php echo date_format($event['start'], 'M j'); ?></li>
<?php endforeach; ?>
当我加载以这种方式注释掉 print_r() 的页面时,我的列表项按以下顺序打印:
Feb 19, Feb 21, Feb 23, Feb 26, Mar 5, Feb 19, Feb 16,...
(注意:这些分别代表日历 1、2、1、1、1、2、2、...中的事件,因此它并不能简单地反映日历请求的顺序。)
取消注释后print_r()(没有其他更改),列表项按时间顺序打印:
Feb 10, Feb 14, Feb 16, Feb 16, Feb 16, Feb 19, Feb 19,...
(注意:这些是打印出来<li>'s的,而不是本身的输出,print_r()没有排序)。
我已经尝试过:
* 在global $events;上面声明getUpcomingEvents(),以防它是一个变量范围问题
* 使用usort而不是uasort,以及单独的比较函数声明而不是匿名的
* 构建$events为显式索引数组 ( $events[$i] = ...) 而不是使用[]运算符,以防万一有助于保持更稳定的数组顺序
* 在将getUpcomingEvents()新变量传递给foreach
变量检查真的会影响我的排序还是我在其他地方出错了?