Analyse von 6 vordefinierten Schnittstellen in PHP

*文
Freigeben: 2023-03-18 17:22:01
Original
1343 Leute haben es durchsucht

In diesem Artikel werden hauptsächlich die 6 vordefinierten Schnittstellen in PHP vorgestellt und Traversable, Iterator, IteratorAggregate, ArrayAccess, Serializable und Closure ausführlich erläutert. Ich hoffe, es hilft allen.

PHP vordefinierte 6 Schnittstellen werden wie folgt eingeführt:

1. Tatsächlich handelt es sich nicht um eine Schnittstelle, die in PHP verwendet werden kann. Es können nur interne Klassen verwendet werden. Eine ihrer Verwendungszwecke besteht darin, zu erkennen, ob eine Klasse durchlaufen werden kann.


if($class instanceof Traversable) {
  //foreach
}
Nach dem Login kopieren


2. Iterator-Schnittstelle

Schnittstellenübersicht:


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) 
}
Nach dem Login kopieren


Das Obige ermöglicht einer Klasse, eine grundlegende Iterationsfunktion zu implementieren. Die Iterationsaufrufsequenz kann wie folgt gesehen werden:


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" ;
}
Nach dem Login kopieren


3. IteratorAggregate aggregierte Iteratorschnittstelle

Schnittstellenzusammenfassung:


IteratorAggregate extends Traversable {
 
//获取外部迭代器
abstract public Traversable getIterator ( void )
}
Nach dem Login kopieren


getIterator ist eine Instanz einer Klasse von Iterator oder Traversable-Schnittstelle. Rufen Sie den externen Iterator wie folgt ab, um den iterativen Zugriff zu implementieren.


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" ;
}
Nach dem Login kopieren


4.ArrayAccess Array-Zugriffsschnittstelle

Schnittstellenübersicht:


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 ) //复位一个偏移位置的值
}
Nach dem Login kopieren


Auf das Objekt kann wie ein Array wie folgt zugegriffen werden:


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 [] = 'Append 1' ;
$obj [] = 'Append 2' ;
$obj [] = 'Append 3' ;
print_r ( $obj );
Nach dem Login kopieren


5.Serialisierbare Serialisierungsschnittstelle

Schnittstellenübersicht:


Serializable {
 
  /* 方法 */
  abstract public string serialize ( void ) //对象的字符串表示
  abstract public mixed unserialize ( string $serialized ) // 构造对象
}
Nach dem Login kopieren


Klassen, die diese Schnittstelle implementieren, unterstützen __sleep() und __wakeup() nicht mehr. Die Verwendung ist sehr einfach, solange die Serialisierungsmethode beim Serialisieren des Objekts und die Deserialisierungsmethode beim Deserialisieren aufgerufen wird.


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);
Nach dem Login kopieren



6.Abschluss

Schnittstellenzusammenfassung:



Closure {
  /* 方法 */
  __construct ( void ) //用于禁止实例化的构造函数
  public static Closure bind ( Closure $closure , object $newthis [, mixed $newscope = 'static' ] ) //复制一个闭包,绑定指定的$this对象和类作用域。
  public Closure bindTo ( object $newthis [, mixed $newscope = 'static' ] ) //复制当前闭包对象,绑定指定的$this对象和类作用域。
}
Nach dem Login kopieren



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 , 'A' );
 $bcl2 = Closure :: bind ( $cl2 , new A (), 'A' );
echo $bcl1 (), "\n" ;
echo $bcl2 (), "\n" ;
Nach dem Login kopieren
Verwandte Empfehlungen:

Die tatsächliche Rolle von PHP-Schnittstellenklassen und abstrakten Klassen

PHP-Sicherheitsgespräch, PHP-Schnittstellensicherheit, PHP-Sicherheitserkennung, php.ini-Sicherheitskonfiguration

Detaillierte Erklärung der PHP-Schnittstelle und Referenzschnittstelle_PHP-Tutorial

Das obige ist der detaillierte Inhalt vonAnalyse von 6 vordefinierten Schnittstellen in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!