0

简而言之

为什么返回错误数组排序的函数会在我调用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

变量检查真的会影响我的排序还是我在其他地方出错了?

4

1 回答 1

2

No, print_r does not affect your array. It just shows you the information of the variable.

From PHP page

print_r — Prints human-readable information about a variable
于 2013-02-13T09:14:17.173 回答