Explication détaillée du mot-clé self en PHP
Analyse du mot-clé self de PHP
Quelqu'un dans le groupe PHP a posé des questions sur l'utilisation du mot-clé self, et la réponse est une comparaison évidente :
Vous ne pouvez pas utiliser ceci pour appeler des fonctions non membres dans une fonction membre statique, mais vous pouvez utiliser self pour appeler des fonctions/variables/constantes membres statiques
Autre ; Les fonctions membres peuvent utiliser self pour appeler des fonctions membres statiques et des fonctions membres non statiques.
Au fur et à mesure que la discussion s'approfondissait, j'ai découvert que le soi n'est pas si simple. Compte tenu de cela, cet article compare et différencie d'abord plusieurs mots-clés, puis résume l'utilisation de soi.
Pour bien comprendre le soi, il faut le distinguer du parent, du statique, et ce.
Ce qui suit sont des comparaisons
parent
La distinction entre soi et le parent est relativement simple : la référence du parent à la classe/base parent la classe est une méthode (ou une variable) masquée, self fait référence à sa propre méthode (ou variable).
Par exemple, appeler le constructeur de la classe parent dans le constructeur :
class Base { public function __construct() { echo "Base contructor!", PHP_EOL; } } class Child { public function __construct() { parent::__construct(); echo "Child contructor!", PHP_EOL; } } new Child; // 输出: // Base contructor! // Child contructor!
static
Le but général de static est de modifier des fonctions ou des variables pour en faire des fonctions de classe et les variables de classe, vous pouvez également modifier les variables au sein d'une fonction pour étendre leur cycle de vie au cycle de vie de l'ensemble de l'application.
Mais son association avec self est une nouvelle utilisation introduite depuis PHP 5.3 : la liaison statique retardée.
Avec la fonction de liaison de délai statique de static, la classe appartenant peut être déterminée dynamiquement au moment de l'exécution.
Par exemple :
class Base { public function __construct() { echo "Base constructor!", PHP_EOL; } public static function getSelf() { return new self(); } public static function getInstance() { return new static(); } public function selfFoo() { return self::foo(); } public function staticFoo() { return static::foo(); } public function thisFoo() { return $this->foo(); } public function foo() { echo "Base Foo!", PHP_EOL; } } class Child extends Base { public function __construct() { echo "Child constructor!", PHP_EOL; } public function foo() { echo "Child Foo!", PHP_EOL; } } $base = Child::getSelf(); $child = Child::getInstance(); $child->selfFoo(); $child->staticFoo(); $child->thisFoo();
Le résultat du programme est le suivant :
Constructeur de base !
Constructeur enfant !
Base Foo !
Child Foo !
Child Foo !
En termes de références de fonctions, la différence entre self et static est la suivante : pour les fonctions membres statiques, self pointe vers la classe actuelle du code, et static pointe vers la classe appelante ; pour les membres non statiques Function, self supprime le polymorphisme, pointe vers la fonction membre de la classe actuelle, static est équivalent à cela et Dynamic pointe vers la fonction de la classe appelante.
Il est intéressant de voir les trois mots-clés parent, self et static combinés ensemble. Ils pointent respectivement vers la classe parent, la classe actuelle et la sous-classe, qui ont un peu un « passé, présent et futur ». " saveur.
ce
soi et ceci sont les combinaisons les plus discutées et sont également les plus susceptibles d'être utilisées à mauvais escient.
La principale différence entre les deux est la suivante :
cela ne peut pas être utilisé dans un membre statique function, self Oui;
Pour accéder aux fonctions/variables membres statiques, il est recommandé d'utiliser self au lieu de $this:: ou $this->
Pour accéder à des fonctions non- variables membres statiques, vous ne pouvez pas utiliser self, seulement ceci ;
ceci doit être utilisé lorsque l'objet a été instancié, self n'a pas une telle restriction
est utilisé dans les fonctions membres non statiques, self supprime le polymorphisme Behavior fait référence à la fonction de la classe actuelle et ceci fait référence à la fonction primordiale de la classe appelante (le cas échéant).
Le but de soi
Après avoir lu les différences entre les trois mots-clés ci-dessus, le but de soi est-il immédiatement évident ? Pour résumer en une phrase, c'est-à-dire : self pointe toujours vers "la classe actuelle (et l'instance de classe)".
En détail :
remplace le nom de la classe et fait référence aux variables membres statiques et aux fonctions statiques de la classe actuelle
supprime le comportement polymorphe et les références ; Fonctions de la classe actuelle plutôt que les implémentations couvertes dans les sous-classes
Slots
Parmi ces mots-clés, seul This doit être ajouté avec un signe $ et doit être ajouté Le trouble obsessionnel-compulsif signifie que c'est très inconfortable
Les fonctions membres statiques ne peuvent pas appeler les fonctions membres non statiques via $this->, mais elles peuvent être appelées via self : :, et lors de l'appel de la fonction, elle peut toujours fonctionner correctement sans utiliser $this->. Ce comportement semble se comporter différemment selon les différentes versions de PHP, mais il est correct dans la version 7.3 actuelle
;在静态函数和非静态函数中输出self,猜猜结果是什么?都是string(4) "self",迷之输出;
return $this instanceof static::class;会有语法错误,但是以下两种写法就正常: $class = static::class; return $this instanceof $class; // 或者这样: return $this instanceof static;
所以这是为什么啊?!
$class = static::class;
return $this instanceof $class;
// 或者这样:
return $this instanceof static;
推荐教程:《PHP视频教程》
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Alipay Php ...

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

Le détournement de la session peut être réalisé via les étapes suivantes: 1. Obtenez l'ID de session, 2. Utilisez l'ID de session, 3. Gardez la session active. Les méthodes pour empêcher le détournement de la session en PHP incluent: 1. Utilisez la fonction Session_RegeReate_id () pour régénérer l'ID de session, 2. Stocker les données de session via la base de données, 3. Assurez-vous que toutes les données de session sont transmises via HTTPS.

L'application du principe solide dans le développement de PHP comprend: 1. Principe de responsabilité unique (SRP): Chaque classe n'est responsable d'une seule fonction. 2. Principe ouvert et ferme (OCP): les changements sont réalisés par extension plutôt que par modification. 3. Principe de substitution de Lisch (LSP): les sous-classes peuvent remplacer les classes de base sans affecter la précision du programme. 4. Principe d'isolement d'interface (ISP): utilisez des interfaces à grain fin pour éviter les dépendances et les méthodes inutilisées. 5. Principe d'inversion de dépendance (DIP): les modules élevés et de bas niveau reposent sur l'abstraction et sont mis en œuvre par injection de dépendance.

Comment définir automatiquement les autorisations d'UnixSocket après le redémarrage du système. Chaque fois que le système redémarre, nous devons exécuter la commande suivante pour modifier les autorisations d'UnixSocket: sudo ...

Comment déboguer le mode CLI dans phpstorm? Lors du développement avec PHPStorm, nous devons parfois déboguer PHP en mode interface de ligne de commande (CLI) ...

Liaison statique (statique: :) implémente la liaison statique tardive (LSB) dans PHP, permettant à des classes d'appel d'être référencées dans des contextes statiques plutôt que de définir des classes. 1) Le processus d'analyse est effectué au moment de l'exécution, 2) Recherchez la classe d'appel dans la relation de succession, 3) il peut apporter des frais généraux de performance.

Envoyant des données JSON à l'aide de la bibliothèque Curl de PHP dans le développement de PHP, il est souvent nécessaire d'interagir avec les API externes. L'une des façons courantes consiste à utiliser la bibliothèque Curl pour envoyer le post� ...
