Analyse de 6 interfaces prédéfinies en PHP

*文
Libérer: 2023-03-18 17:22:01
original
1343 Les gens l'ont consulté

Cet article présente principalement les 6 interfaces prédéfinies en PHP, et explique en détail Traversable, Iterator, IteratorAggregate, ArrayAccess, Seriallessly et Closure. J'espère que cela aide tout le monde.

6 interfaces PHP prédéfinies sont présentées comme suit :

1. Interface de traversée traversable

Haha ! En fait, ce n'est pas une interface utilisable en PHP, seules les classes internes peuvent être utilisées. Une de ses utilisations est de détecter si une classe peut être parcourue.


if($class instanceof Traversable) {
  //foreach
}
Copier après la connexion


2. Interface de l'itérateur

Résumé de l'interface :


Iterator extends Traversable 
{ 
  //返回当前索引游标指向的元素 
  abstract public mixed current(void) 
  //返回当前索引游标指向的元素的键名 
  abstract public scalar key(void) 
  //移动当前索引游标指向下一元素 
  abstract public void next(void) 
  //重置索引游标的指向第一个元素 
  abstract public void rewind(void) 
  //判断当前索引游标指向的是否是一个元素,常常在调用 rewind()或 next()使用 
  abstract public boolean valid(void) 
}
Copier après la connexion


Ce qui précède permet à une classe d'implémenter une fonction d'itération de base. La séquence d'appel d'itération peut être vue comme suit :


< 🎜. >

class myIterator implements Iterator {
  private $position = 0 ;
  private $array = array(
    "firstelement" ,
    "secondelement" ,
    "lastelement" ,
  );
 
  public function __construct () {
    $this -> position = 0 ;
  }
 
  function rewind () {
    var_dump ( __METHOD__ );
    $this -> position = 0 ;
  }
 
  function current () {
    var_dump ( __METHOD__ );
    return $this -> array [ $this -> position ];
  }
 
  function key () {
    var_dump ( __METHOD__ );
    return $this -> position ;
  }
 
  function next () {
    var_dump ( __METHOD__ );
    ++ $this -> position ;
  }
 
  function valid () {
    var_dump ( __METHOD__ );
    return isset( $this -> array [ $this -> position ]);
  }
}
 
$it = new myIterator ;
 
foreach( $it as $key => $value ) {
  var_dump ( $key , $value );
  echo "\n" ;
}
Copier après la connexion


3. Interface d'itérateur agrégé IteratorAggregate

Résumé de l'interface :


IteratorAggregate extends Traversable {
 
//获取外部迭代器
abstract public Traversable getIterator ( void )
}
Copier après la connexion


getIterator est une instance d'une classe d'interface Iterator ou Traversable. Obtenez l’itérateur externe comme suit pour implémenter l’accès itératif.


class myData implements IteratorAggregate {
  public $property1 = "Public property one" ;
  public $property2 = "Public property two" ;
  public $property3 = "Public property three" ;
 
  public function __construct () {
    $this -> property4 = "last property" ;
  }
 
  
  public function getIterator () {
    return new ArrayIterator ( $this );
  }
}
 
$obj = new myData ;
 
foreach( $obj as $key => $value ) {
  var_dump ( $key , $value );
  echo "\n" ;
}
Copier après la connexion


4.Interface d'accès au tableau ArrayAccess

Résumé de l'interface :


ArrayAccess {
  /* 方法 */
  abstract public boolean offsetExists ( mixed $offset ) //检查偏移位置是否存在
  abstract public mixed offsetGet ( mixed $offset ) //获取一个偏移位置的值
  abstract public void offsetSet ( mixed $offset , mixed $value ) //设置一个偏移位置的值
  abstract public void offsetUnset ( mixed $offset ) //复位一个偏移位置的值
}
Copier après la connexion


L'objet est accessible comme un tableau comme suit :


class obj implements arrayaccess {
  private $container = array();
  public function __construct () {
    $this -> container = array(
      "one"  => 1 ,
      "two"  => 2 ,
      "three" => 3 ,
    );
  }
  public function offsetSet ( $offset , $value ) {
    if ( is_null ( $offset )) {
      $this -> container [] = $value ;
    } else {
      $this -> container [ $offset ] = $value ;
    }
  }
  public function offsetExists ( $offset ) {
    return isset( $this -> container [ $offset ]);
  }
  public function offsetUnset ( $offset ) {
    unset( $this -> container [ $offset ]);
  }
  public function offsetGet ( $offset ) {
    return isset( $this -> container [ $offset ]) ? $this -> container [ $offset ] : null ;
  }
}
 
$obj = new obj ;
 
var_dump (isset( $obj [ "two" ]));
var_dump ( $obj [ "two" ]);
unset( $obj [ "two" ]);
var_dump (isset( $obj [ "two" ]));
$obj [ "two" ] = "A value" ;
var_dump ( $obj [ "two" ]);
$obj [] = &#39;Append 1&#39; ;
$obj [] = &#39;Append 2&#39; ;
$obj [] = &#39;Append 3&#39; ;
print_r ( $obj );
Copier après la connexion


5.Interface de sérialisation sérialisable

Résumé de l'interface :


Serializable {
 
  /* 方法 */
  abstract public string serialize ( void ) //对象的字符串表示
  abstract public mixed unserialize ( string $serialized ) // 构造对象
}
Copier après la connexion


Les classes qui implémentent cette interface ne prennent plus en charge __sleep() et __wakeup(). L'utilisation est très simple, à condition que la méthode serialize soit appelée lorsque l'objet est sérialisé et que la méthode unserialize soit appelée lors de la désérialisation.


class obj implements Serializable {
  private $data ;
  public function __construct () {
    $this -> data = "My private data" ;
  }
  public function serialize () {
    return serialize ( $this -> data );
  }
  public function unserialize ( $data ) {
    $this -> data = unserialize ( $data );
  }
  public function getData () {
    return $this -> data ;
  }
}
 
$obj = new obj ;
$ser = serialize ( $obj );
print_r($ser);
$newobj = unserialize ( $ser );
print_r($newobj);
Copier après la connexion



6.Fermeture

Résumé de l'interface :


Closure {
  /* 方法 */
  __construct ( void ) //用于禁止实例化的构造函数
  public static Closure bind ( Closure $closure , object $newthis [, mixed $newscope = &#39;static&#39; ] ) //复制一个闭包,绑定指定的$this对象和类作用域。
  public Closure bindTo ( object $newthis [, mixed $newscope = &#39;static&#39; ] ) //复制当前闭包对象,绑定指定的$this对象和类作用域。
}
Copier après la connexion



class A {
  private static $sfoo = 1 ;
  private $ifoo = 2 ;
}
 $cl1 = static function() {
  return A :: $sfoo ;
};
 $cl2 = function() {
  return $this -> ifoo ;
};
 
 $bcl1 = Closure :: bind ( $cl1 , null , &#39;A&#39; );
 $bcl2 = Closure :: bind ( $cl2 , new A (), &#39;A&#39; );
echo $bcl1 (), "\n" ;
echo $bcl2 (), "\n" ;
Copier après la connexion

Recommandations associées :

Le rôle réel des classes d'interface php et des classes abstraites

PHP security talk php interface security php security détection php.ini security configuration

Explication détaillée de l'interface PHP et tutoriel interface_PHP de référence


Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!