3

Countable、ArrayAccess、Iterator、および Serializable を実装するクラスがあります。配列形式のパブリック変数 $data があります。そして私の反復実装:

public function rewind() { return reset($this->data); }
public function current() { return current($this->data); }
public function key() { return key($this->data); }
public function next() { return next($this->data); }
public function valid() { return isset($this->data[$this->key()]); }

すべてがforeachループで機能しますが、手動で呼び出すとcurrent($arrayObject)、現在の配列ではなく、配列全体が返さ$dataれます。できますがcurrent($arrayObject->data)、できる限りネイティブ配列機能を維持したいと考えています。

これはphpの動作ですよね?(私のコードのバグではありません)そして、カスタム関数(指が交差していない)なしで、これに回避策はありますか?

[編集] 完全なクラスの簡略化されたバージョン(作業中):

$arrayObject = mysqli_fetch_object($this->result_id, "simpleMysqliResult ", array(array(
        "fields" => array( "field1", "field2", "field3" )
    )));
class simpleMysqliResult implements Countable, ArrayAccess, Iterator, Serializable {

    public $data = array();

    public function __construct($input) {
        extract($input);
        foreach ($fields as $field) {
            $this->data[$field] = $this->{$field};
            unset($this->{$field});
        }
    }

    public function &toArray() { return $this->data; }
    public function offsetGet($index) { return $this->data[$index]; }
    public function offsetSet($index, $value) { $this->data[$index] = $value; }
    public function offsetUnset($index) { unset($this->data[$index]); }
    public function offsetExists($index) { return $this->offsetGet($index) !== null; }
    public function count() { return count($this->data); }
    public function rewind() { return reset($this->data); }
    public function current() { return current($this->data); }
    public function key() { return key($this->data); }
    public function next() { return next($this->data); }
    public function valid() { return isset($this->data[$this->key()]); }
    public function serialize() { return serialize($this->data); }
    public function unserialize($str) { return $this->data = unserialize($str); }

    public function __call($func, $argv) {
        if (!is_callable($func) || substr($func, 0, 6) !== 'array_')
        {
            throw new BadMethodCallException(__CLASS__.'->'.$func);
        }
        return call_user_func_array($func, array_merge(array($this->data), $argv));
    }

}
4

1 に答える 1

1

データをプライベート モードで配置してみてください。私はあなたがそれをいじり、それに変更を加えている外部手順を持っていると思います。あなたのクラスをコピーし、コンストラクターを少し変更しました。あなたと同じ入力がなく、奇妙な動作が得られなかったからです。最終的に、extract($input) の理由も調べたいと思うかもしれません。$input['fields'] または $input->fields を適切に使用してください。それでも機能します。

ここに私の修正があります:

private $data = array();

public function __construct($input) {
    foreach($input['fields'] as $field) {
        $this->data[$field] = $input[$field];
    }
}

ここに私のテストがあります

$data = array('fields' => array('id', 'name'), 'id' => 1, 'name' => 'Franco');
$smr = new simpleMysqliResult($data);
var_dump($smr->current());
var_dump($smr->current());
var_dump($smr->current());
var_dump($smr->current());
var_dump($smr->next());
var_dump($smr->current());
var_dump($smr->current());

そして、私の出力は大丈夫です

int(1) int(1) int(1) int(1) string(6) "Franco" string(6) "Franco" string(6) "Franco" 

私が言ったように、あなたの問題は主に $data が公開されていて、他の何かがそれで遊んでいるという事実にあると思います。

また

私の側で動作させるために修正しなければならなかったのは、あなたのコンストラクターにあります。

幸運を

于 2012-01-10T13:03:34.203 に答える