Generators

定義済みのインターフェイスとクラスGenerator クラス

ジェネレータとは?

 状態:確認中  閲覧数:1,236  投稿日:2016-12-03  更新日:2016-12-03  
「数列の各要素の値」などを次々と生成(ジェネレート)し他の手続きへ渡す機能

PHPにおけるGeneratorsとは?
・A.Generatorクラス
・B.generator関数

A.Generatorクラス

 閲覧数:378 投稿日:2016-12-03 更新日:2016-12-04 

概要


Cで実装されている

擬似コード
Generator implements Iterator {
/* メソッド */
public mixed current ( void )
public mixed getReturn ( void )
public mixed key ( void )
public void next ( void )
public void rewind ( void )
public mixed send ( mixed $value )
public mixed throw ( Exception $exception )
public bool valid ( void )
public void __wakeup ( void )
}



「Iteratorインターフェース」を実装している


「Generator クラス」は、 Iterator インターフェイスを実装している
・current(), key(), next(), rewind(), valid()を実装する必要がない
・Iterator インターフェイスを実装するクラスを用意しなくても、イテレータのメソッドを利用可

PHP-7.1
zend_class_implements(zend_ce_generator, 1, zend_ce_iterator);

PHP-5.5.4
zend_class_implements(zend_ce_generator TSRMLS_CC, 1, zend_ce_iterator);



ユーザーがnewすることはできない


「Generatorクラスのコンストラクタにエラーが仕込んである」から

PHP-7.1
static ZEND_COLD zend_function *zend_generator_get_constructor(zend_object *object) /* {{{ */
{
zend_throw_error(NULL, "The \"Generator\" class is reserved for internal use and cannot be manually instantiated");

return NULL;
}

PHP-5.5.4
static zend_function *zend_generator_get_constructor(zval *object TSRMLS_DC) /* {{{ */
{
zend_error(E_RECOVERABLE_ERROR, "The \"Generator\" class is reserved for internal use and cannot be manually instantiated");

return NULL;
}


「finalクラス」なので「継承」不可


PHP-7.1
zend_ce_generator->ce_flags |= ZEND_ACC_FINAL;

PHP-5.5.4
zend_ce_generator->ce_flags |= ZEND_ACC_FINAL_CLASS;


「クローン」不可


PHP-7.1
PHP-5.5.4
zend_generator_handlers.clone_obj = NULL;


「serialize」不可


PHP-7.1
PHP-5.5.4
zend_ce_generator->serialize = zend_class_serialize_deny;


「unserialize」不可


PHP-7.1
PHP-5.5.4
zend_ce_generator->unserialize = zend_class_unserialize_deny;


B.generator関数

 閲覧数:374 投稿日:2016-12-03 更新日:2016-12-04 

generator関数とは?


yield文を含む関数
・普通の関数と異なる


特徴


呼ばれたタイミングで関数の実行を行わない
・代わりに、「ジェネレータ関数に紐付いたGeneratorクラスのインスタンス」を返す

動きを一時停止して再度再開することが出来る
→ 関数やメソッド定義のなかの yield 文で指定した式は foreach ループで展開される

一度だけ return するのではない
・必要に応じて何度でも yield することが可能
→ 「値」を繰り返し返せる


ジェネレータ関数の実行順序


前回の終了位置から再開される
・通常の関数のように、毎回先頭から実行されない


PHPのparse時にyield文が見つかると、「その関数がジェネレータ関数であるというフラグが立てられる」


PHP-7.1
PHP-5.5.4
CG(active_op_array)->fn_flags |= ZEND_ACC_GENERATOR;


yield キーワード

 閲覧数:383 投稿日:2016-12-04 更新日:2016-12-04 

比較


通常の関数
・return で関数実行を終了
・値を返す
// not generator
function func($n)
{
 return $n;
}

echo func(10);// 10


yield キーワード
・「ジェネレータ関数」の実行を一時停止
・「ジェネレータを呼び出しているループ」に値を戻す
・「Generatorオブジェクト」を返す
// generator
function func($n)
{
yield $n;
}
$generator = func(10);
foreach ($generator as $val) {
echo "$val<br>"; //10
}

var_dump($generator); //object(Generator)#1 (0) { }
var_export($generator); //Generator::__set_state(array( ))
echo get_class($generator); //Generator


Twitter検索結果。「Generators」に関する最新ツイート

ウルス @urs_nft
Hary(人民・感染対策魔人) @haryint

コメント投稿(ログインが必要)



類似度ページランキング
順位 ページタイトル抜粋
1 syntax error 64
2 session_start() 56
3 ob_start 56
4 Doctrine 56
5 set_error_handler 52
6 register_globals 46
7 foreach文 44
8 realpath 44
9 session_destroy関数 44
10 SessionHandler::gc 43
11 Composer 42
12 session_save_path() 41
13 preg_match 40
14 popen 40
15 isset 40
16 session_set_save_handler() 39
17 session.hash_function 39
18 setcookie関数 38
19 break文 38
20 Propel 38
2023/6/02 4:55 更新
週間人気ページランキング / 5-26 → 6-1
順位 ページタイトル抜粋 アクセス数
1 ブラウザを閉じたらセッションデータはどうなるの? | セッション 30
2 Parse error: syntax error, unexpected 'public' (T_PUBLIC) | Parse error(エラーメッセージ) 13
3 PHP用語 12
3 Fatal error: Uncaught RuntimeException: SplFileObject::__construct(): failed to open stream: Permission denied in | Fatal error(エラーメッセージ) 12
4 スコープ | 変数 11
5 Fatal error: Access level to ▲::$△ must be protected (as in class ●) or weaker | Fatal error(エラーメッセージ) 10
5 ブラウザを閉じたらセッションデータはどうなるの? | セッション 10
6 Fatal error: require_once(): Failed opening required 'PEAR.php' | Fatal error(エラーメッセージ) 9
7 セッションID | セッション 8
8 セッション管理が必要な理由は、HTTPプロトコルには状態を保持する機能がないため | セッション 7
9 Warning: strlen() expects parameter 1 to be string, array given in ○○.php on line △△ | Warning(エラーメッセージ) 5
9 Warning: include() [function.include]: Failed opening '**.php' for inclusion (in | Warning(エラーメッセージ) 5
9 コード例 … 「例外処理」はネストすることができる 5
10 curl | その他のサービス 4
10 型の種類 | 型 4
10 Cookie | クッキー 4
10 @ | 演算子 4
10 Warning: PDO::query(): LOAD DATA LOCAL INFILE forbidden | Warning(エラーメッセージ) 4
10 Fatal error: Call to undefined method MDB2_Error::execute() in ○○ on line △△ | Fatal error(エラーメッセージ) 4
11 Fatal error: Cannot access protected property ○○ in △△ on □□ | Fatal error(エラーメッセージ) 3
2023/6/2 1:01 更新