Introduction à __construct() et __initialize() dans thinkphp
À propos de la compréhension de __construct() et _initialize() dans thinkphp
Il existe de nombreuses opinions et utilisations sur Internet, je l'ai testé moi-même. sur le test Les résultats sont combinés avec votre propre compréhension pour tirer des conclusions. S'il y a des erreurs, vous pouvez les corriger ! ! !
Jetons d'abord un coup d'œil au contenu de la classe Controlle fournie avec Thinkphp (ThinkPHPLibraryThinkController.class.php)
Regardez le constructeur :
/** * 架构函数 取得模板对象实例 * @access public */ public function __construct() { Hook::listen('action_begin',$this->config); //实例化视图类 $this->view = Think::instance('Think\View'); //控制器初始化 if(method_exists($this,'_initialize')) $this->_initialize(); }
Du constructeur dans la classe Controller Comme vous pouvez le savoir, le constructeur déterminera s'il y a une méthode _initialize dans l'objet. Si c'est le cas, la méthode _initialize sera exécutée en premier,
Donc, si nous sommes dans un contrôleur défini par nous-mêmes,
1) : Il y a un constructeur surchargé :
①Dans la construction surchargée, il y a un constructeur qui implémente la classe parent (parent::construct()),
Si dans le contrôleur la méthode _initialize() est définie, alors lorsque nous appellerons la méthode dans le contrôleur, nous exécuterons d'abord la méthode _initialize(), puis exécuterons la méthode dont nous avons besoin. Regardez le code :
.
<?php namespace Home\Controller; use Think\Controller; class IndexController extends Controller { public function __construct() { parent::__construct(); self::b(); echo '我是构造<br />'; } public function _initialize() { echo '我先来<br />'; // parent::_initialize(); } public function index(){ self::b(); echo '这是index'; } public function b() { echo 'bbbb<br />'; } } /* 当执行index方法时,打印结果: 我先来 bbbb 我是构造 bbbb 这是index */
② : Le constructeur de la classe parent n'est pas implémenté dans la construction remplacée. Lorsque la méthode est exécutée, la méthode _initialize() définie n'a aucun effet (la méthode _initialize ne sera pas exécutée en premier lorsque la méthode est exécutée. est exécuté). Regardez le code :
<?php namespace Home\Controller; use Think\Controller; class IndexController extends Controller { public function __construct() { // parent::__construct(); self::b(); echo '我是构造<br />'; } public function _initialize() { echo '我先来<br />'; // parent::_initialize(); } public function index(){ self::b(); echo '这是index'; } public function b() { echo 'bbbb<br />'; } } /* 当执行index方法时,打印结果: bbbb 我是构造 bbbb 这是index */
Remarque : La méthode _initialize() mentionnée ici signifie qu'il n'y a pas d'appel de fonction avant parent::__construct();. __construct(); self::b(), il n'est pas nécessaire de dire que b() doit être exécuté en premier, mais il n'est généralement pas écrit de cette façon. Il n'y a généralement aucune sortie ni configuration avant que le constructeur de la classe parent ne soit exécuté. implémenté
De plus, s'il s'agit d'un héritage, si la classe parent a un constructeur, la sous-classe initialise généralement le constructeur de la classe parent en premier dans son constructeur pour garantir l'originalité et l'intégrité du code
2) Il n'y a pas de remplacement du constructeur, c'est-à-dire que dans le cas où le constructeur
n'est pas déclaré dans le contrôleur que nous avons défini, si la méthode _initialize() est définie dans le contrôleur, lorsque nous appelons d'autres méthodes, _initialize sera appelée première méthode (), regardez le code :
<?php namespace Home\Controller; use Think\Controller; class IndexController extends Controller { // public function __construct() { // // parent::__construct(); // self::b(); // echo '我是构造<br />'; // } public function _initialize() { echo '我先来<br />'; // parent::_initialize(); } public function index(){ self::b(); echo '这是index'; } public function b() { echo 'bbbb<br />'; } } /* 当执行index方法时,打印结果: 我先来 bbbb 这是index */
De plus, _initialize() peut également être utilisé pour hériter de
<?php namespace Home\Controller; use Think\Controller; class BaseController extends Controller { public function __construct() { parent::__construct(); echo '我是父类<br />'; } public function _initialize() { echo '我先来<br />'; } public function a() { echo 'aaaa<br />'; } }
<?php namespace Home\Controller; use Think\Controller; class IndexController extends BaseController { public function __construct() { parent::__construct(); self::b(); echo '我是构造<br />'; } public function _initialize() { parent::_initialize(); echo '我是子类先来<br />'; } public function index(){ self::b(); echo '这是index'; } public function b() { echo 'bbbb<br />'; } } /* 当执行index方法时,打印结果: 我先来 我是子类先来 我是父类 bbbb 我是构造 bbbb 这是index */
Remarque : S'il n'y a pas de parent::construct() dans le constructeur de la classe parent, la _initialize() définie ne fonctionne pas non plus
Donc, il y a les deux __construct() (le constructeur initialise le constructeur de la classe parent class) et _initialize(), lequel est exécuté en premier ?
La réponse est - exécutez d'abord la méthode _initialize(), c'est-à-dire que si les conditions sont remplies, la fonction _initialize() doit être exécutée avant l'exécution de toute méthode, y compris le constructeur,
Bien sûr, si vous appelez une ou plusieurs méthodes dans la méthode à exécuter, lorsque vous appelez ces méthodes en plus, la méthode _initialize() ne sera pas exécutée à nouveau, elle est associée à la méthode que vous avez appelée pour la première fois. time , c’est-à-dire qu’il n’a aucun contrôle sur ce qui se fait dans la méthode.
Tutoriel recommandé : tutoriel thinkphp
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)

Pour exécuter le projet ThinkPHP, vous devez : installer Composer ; utiliser Composer pour créer le projet ; entrer dans le répertoire du projet et exécuter php bin/console serve ; visiter http://localhost:8000 pour afficher la page d'accueil.

ThinkPHP dispose de plusieurs versions conçues pour différentes versions de PHP. Les versions majeures incluent 3.2, 5.0, 5.1 et 6.0, tandis que les versions mineures sont utilisées pour corriger les bogues et fournir de nouvelles fonctionnalités. La dernière version stable est ThinkPHP 6.0.16. Lorsque vous choisissez une version, tenez compte de la version PHP, des exigences en matière de fonctionnalités et du support de la communauté. Il est recommandé d'utiliser la dernière version stable pour de meilleures performances et une meilleure assistance.

Étapes pour exécuter ThinkPHP Framework localement : Téléchargez et décompressez ThinkPHP Framework dans un répertoire local. Créez un hôte virtuel (facultatif) pointant vers le répertoire racine ThinkPHP. Configurez les paramètres de connexion à la base de données. Démarrez le serveur Web. Initialisez l'application ThinkPHP. Accédez à l'URL de l'application ThinkPHP et exécutez-la.

Comparaison des performances des frameworks Laravel et ThinkPHP : ThinkPHP fonctionne généralement mieux que Laravel, en se concentrant sur l'optimisation et la mise en cache. Laravel fonctionne bien, mais pour les applications complexes, ThinkPHP peut être mieux adapté.

"Suggestions de développement : comment utiliser le framework ThinkPHP pour implémenter des tâches asynchrones" Avec le développement rapide de la technologie Internet, les applications Web ont des exigences de plus en plus élevées pour gérer un grand nombre de requêtes simultanées et une logique métier complexe. Afin d'améliorer les performances du système et l'expérience utilisateur, les développeurs envisagent souvent d'utiliser des tâches asynchrones pour effectuer certaines opérations chronophages, telles que l'envoi d'e-mails, le traitement des téléchargements de fichiers, la génération de rapports, etc. Dans le domaine de PHP, le framework ThinkPHP, en tant que framework de développement populaire, offre des moyens pratiques d'implémenter des tâches asynchrones.

Étapes d'installation de ThinkPHP : Préparez les environnements PHP, Composer et MySQL. Créez des projets à l'aide de Composer. Installez le framework ThinkPHP et ses dépendances. Configurez la connexion à la base de données. Générez le code de l'application. Lancez l'application et visitez http://localhost:8000.

ThinkPHP est un framework PHP hautes performances présentant des avantages tels que le mécanisme de mise en cache, l'optimisation du code, le traitement parallèle et l'optimisation des bases de données. Les tests de performances officiels montrent qu'il peut gérer plus de 10 000 requêtes par seconde et qu'il est largement utilisé dans les sites Web à grande échelle et les systèmes d'entreprise tels que JD.com et Ctrip dans les applications réelles.

Le service RPC basé sur ThinkPHP6 et Swoole implémente la fonction de transfert de fichiers Introduction : Avec le développement d'Internet, le transfert de fichiers est devenu de plus en plus important dans notre travail quotidien. Afin d'améliorer l'efficacité et la sécurité du transfert de fichiers, cet article présentera la méthode d'implémentation spécifique de la fonction de transfert de fichiers basée sur le service RPC basé sur ThinkPHP6 et Swoole. Nous utiliserons ThinkPHP6 comme framework Web et utiliserons la fonction RPC de Swoole pour réaliser le transfert de fichiers entre serveurs. 1. Norme environnementale
