6

我正在尝试通过以下setInfoClass方法将自定义类设置为迭代器:

使用此方法设置一个自定义类,该类将在调用 getFileInfo 和 getPathInfo 时使用。传递给此方法的类名必须派生自 SplFileInfo。

我的课是这样的(简化示例):

class MyFileInfo extends SplFileInfo
{
    public $props = array(
        'foo' => '1',
        'bar' => '2'
    );
}

迭代器代码是这样的:

$rit = new RecursiveIteratorIterator(
           new RecursiveDirectoryIterator('/some/file/path/'),
           RecursiveIteratorIterator::SELF_FIRST);

由于也是RecursiveDirectoryIterator通过对象继承,因此它提供了方法。它没有在手册中列出,但反射显示它在那里:DirectoryIteratorSplFileInfosetInfoClass

shell$ php --rc RecursiveDirectoryIterator
// ...
Method [ <internal:SPL, inherits SplFileInfo> public method setInfoClass ] {  
  - Parameters [1] {
    Parameter #0 [ <optional> $class_name ]
  }
}

到这里为止一切都很好,但是当迭代目录时

$rit->getInnerIterator()->setInfoClass('MyFileInfo');
foreach($rit as $file) {
    var_dump( $file );
}

我得到以下奇怪的结果

object(MyFileInfo)#4 (3) {
  ["props"]=>UNKNOWN:0
  ["pathName":"SplFileInfo":private]=>string(49) "/some/file/path/someFile.txt"
  ["fileName":"SplFileInfo":private]=>string(25) "someFile.txt"
}

因此,当MyFileInfo被拾起时,我无法访问它的属性。如果我添加自定义方法,我可以很好地调用它们,但任何属性都是未知的。

如果我没有将信息类设置为迭代器,而是设置为 SplFileInfo 对象(如手册中的示例所示),它将给出相同的 UNKNOWN 结果:

foreach($rit as $file) {
    // $file is a SplFileInfo instance
    $file->setInfoClass('MyFileInfo');
    var_dump( $file->getFileInfo() );
}

但是,当我这样做时它会起作用

foreach($rit as $file) {
    $file = new MyFileInfo($file);
    var_dump( $file );
}

不幸的是,我想在其中使用它的代码有点复杂,并且堆叠了更多的迭代器。不能像这样创建 MyFileInfo 类。

那么,有谁知道如何让它工作或为什么 PHP 表现得如此怪异?

谢谢。

4

1 回答 1

2

不能告诉你确切的原因,但它适用于

class MyFileInfo extends SplFileInfo
{
  public $props;

  public function __construct($filename) {
    $this->props = array(
      'foo' => '1',
      'bar' => '2'
    );

    parent::__construct($filename);
  }
}
于 2010-04-03T21:37:50.863 回答