ArrayAccess::offsetExists
(PHP 5, PHP 7, PHP 8)
ArrayAccess::offsetExists — オフセットが存在するかどうか
説明
abstract public ArrayAccess::offsetExists
( mixed $offset
) : bool
オフセットが存在するかどうかを返します。
このメソッドが実行されるのは、ArrayAccess を実装したオブジェクト上で isset() あるいは empty() を使用した場合です。
注意:
empty() を使用すると ArrayAccess::offsetGet() がコールされ、ArrayAccess::offsetExists() が
true
を返すかどうかで空かどうかを判断します。
パラメータ
offset
- 調べたいオフセット。
返り値
成功した場合に true
を、失敗した場合に false
を返します。
注意:
非 boolean 値が返された場合は bool にキャストして返します。
例
例1 ArrayAccess::offsetExists() の例
<?phpclass obj implements arrayaccess { public function offsetSet($offset, $value) { var_dump(__METHOD__); } public function offsetExists($var) { var_dump(__METHOD__); if ($var == "foobar") { return true; } return false; } public function offsetUnset($var) { var_dump(__METHOD__); } public function offsetGet($var) { var_dump(__METHOD__); return "value"; }}$obj = new obj;echo "Runs obj::offsetExists()\n";var_dump(isset($obj["foobar"]));echo "\nRuns obj::offsetExists() and obj::offsetGet()\n";var_dump(empty($obj["foobar"]));echo "\nRuns obj::offsetExists(), *not* obj:offsetGet() as there is nothing to get\n";var_dump(empty($obj["foobaz"]));?>
上の例の出力は、 たとえば以下のようになります。
Runs obj::offsetExists() string(17) "obj::offsetExists" bool(true) Runs obj::offsetExists() and obj::offsetGet() string(17) "obj::offsetExists" string(14) "obj::offsetGet" bool(false) Runs obj::offsetExists(), *not* obj:offsetGet() as there is nothing to get string(17) "obj::offsetExists" bool(true)