Explication détaillée 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 relativement évidente :
Vous ne pouvez pas l'utiliser pour appeler des fonctions non membres dans une fonction membre statique, mais vous pouvez utiliser des appels automatiques de fonctions/variables/constantes membres statiques
D'autres 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.
Différences avec le parent, statique et ceci
Si vous voulez bien comprendre le soi, vous devez le distinguer du parent, statique et ceci.
Ce qui suit sont des comparaisons
parent
La distinction entre soi et parent est relativement simple : parent fait référence à la méthode cachée de la classe parent/ classe de base (ou variable), self fait référence à sa propre méthode (ou variable).
Par exemple, appeler le constructeur de 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
static est généralement utilisé pour modifier des fonctions ou des variables pour en faire des fonctions de classe et des variables de classe. Il peut également être modifié. Les variables au sein d'une fonction prolongent leur cycle de vie jusqu'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. Recommandé : "Tutoriel PHP"
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 :
Base constructor! Child constructor! Base Foo! Child Foo! Child Foo!
Dans les références de fonction, self Et static La différence 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 fonctions membres non statiques, self supprime le polymorphisme et 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.
Les principales différences entre les deux sont les suivantes :
this ne peut pas être utilisé dans les fonctions membres statiques, self peut
pour les fonctions membres statiques ; /variables Pour l'accès, il est recommandé d'utiliser self au lieu de $this:: ou $this->
Pour accéder aux variables membres non statiques, self ne peut pas être utilisé, seulement ceci
ceci doit être utilisé lorsque l'objet a été instancié, self n'a pas cette restriction ;
est utilisé dans les fonctions membres non statiques, self supprime le comportement polymorphe et fait référence à la fonction de la classe actuelle ; et cela fait référence à la fonction lourde de la classe appelante Remplacer la fonction (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 fait référence aux fonctions de la classe actuelle ; classe actuelle au lieu de Mise en œuvre couverte dans les sous-classes ;
Slots
Parmi ces mots-clés, seul celui-ci doit être ajouté avec le signe $ et doit être ajouté. Le trouble obsessionnel-compulsif signifie qu'il est très inconfortable. ;
Les fonctions membres non statiques ne peuvent pas être appelées via $this-> dans les fonctions membres statiques, mais elles peuvent être appelées via self::, et elles peuvent toujours s'exécuter correctement sans utiliser $this-> la fonction appelante. Ce comportement semble se comporter différemment dans les différentes versions de PHP. C'est ok dans la version 7.3 actuelle ;
affiche self dans les fonctions statiques et les fonctions non statiques. Ce sont tous des string(4) "self", ce qui est une sortie déroutante ;
return $this instanceof static::class; il y aura des erreurs de syntaxe, mais les deux façons d'écrire suivantes sont normales :
$class = static::class; return $this instanceof $class; // 或者这样: return $this instanceof static;
Alors pourquoi ça ? !
$class = static::class; return $this instanceof $class; // 或者这样: return $this instanceof static;
Pour plus de connaissances sur PHP, veuillez visiter le Site Web PHP chinois !
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

AI Hentai Generator
Générez AI Hentai gratuitement.

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

Dans ce chapitre, nous comprendrons les variables d'environnement, la configuration générale, la configuration de la base de données et la configuration de la messagerie dans CakePHP.

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

Pour travailler avec la date et l'heure dans cakephp4, nous allons utiliser la classe FrozenTime disponible.

Pour travailler sur le téléchargement de fichiers, nous allons utiliser l'assistant de formulaire. Voici un exemple de téléchargement de fichiers.

Dans ce chapitre, nous allons apprendre les sujets suivants liés au routage ?

CakePHP est un framework open source pour PHP. Il vise à faciliter grandement le développement, le déploiement et la maintenance d'applications. CakePHP est basé sur une architecture de type MVC à la fois puissante et facile à appréhender. Modèles, vues et contrôleurs gu

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

Le validateur peut être créé en ajoutant les deux lignes suivantes dans le contrôleur.
