Detailed explanation of Ioc and Di examples in php
I have been using the ThinkPHP5 framework recently. After looking at its source code, I found that dependency injection (inversion of control) is also used in many places. I feel it is necessary to briefly talk with you about what dependency injection is and how to use it.
Let’s look at an example first:
<?php class A { public $b; public $c; public function A() { //TODO } public function Method() { $this->b=new B(); $this->c=new C(); $this->b->Method(); $this->c->Method(); //TODO } } class B { public function B() { //TODO } public function Method() { //TODO echo 'b'; } } class C { public function C() { //TODO } public function Method() { //TODO echo 'c'; } } $a=new A(); $a->Method(); ?>
The above code, we can easily understand one sentence:
Class A depends on B Class and Class C
That is to say, if in the future development process, we need to modify Class B or Class C, once it involves renaming the function, changing the number of function parameters, or even adjusting the entire class structure, we will also have to modify it. Category A makes corresponding adjustments, and the independence of category A is lost. This is very inconvenient during the development process. This is what we call "one thing affects the whole body". If the two categories are written by two people separately, Conflicts often arise at this time. . .
If we really need to change categories B and C, is there any way to not change the code of category A or to change it as little as possible? Inversion of control is used here.
High-level modules should not depend on low-level modules, both should rely on abstractions.
Inversion of control (IOC) is an idea, and dependency injection (DI) is a method of implementing this idea.
The first method is called: constructor injection (this method is not recommended, but it is better than not using it)
class A { public $b; public $c; public function A($b,$c) { $this->b=$b; $this->c=$c; } public function Method() { $this->b->Method(); $this->c->Method(); } }
Client The class is written like this:
$a=new A(new B(),new C()); $a->Method();
The constructor of class A depends on class B and class C. It is passed in through the parameters of the constructor. At least one thing is achieved, which is B The creation of class object b and class C object c have been moved outside class A, so once class B and class C are changed, class A does not need to be modified, just change it in the client class.
If One day, we need to expand class B and make two subclasses of class B
class B { public function B() { //TODO } public function Method() { //TODO echo 'b'; } } class B1 extends B { public function B1() { //TODO } public function Method() { echo 'b1'; } } class B2 extends B { public function B2() { //TODO } public function Method() { echo 'b2'; } }
is also very simple. The client class is written like this:
$a=new A(new B2(),new C()); $a->Method();
So class A does not need to care about which subclasses class B has, as long as it is concerned about the client class.
The second method is called: factory mode injection (recommended)
class Factory { public function Factory() { //TODO } public function create($s) { switch($s) { case 'B': { return new B(); break; } case 'C': { return new C(); break; } default: { return null; break; } } } }
Our Class A code is changed to:
class A { public $b; public $c; public function A() { //TODO } public function Method() { $f=new Factory(); $this->b=$f->create('B'); $this->c=$f->create('C'); $this->b->Method(); $this->c->Method(); //TODO } }
In fact, a small part has been decoupled. At least if the constructors of classes B and C change, such as modifying function parameters, etc., we only need to change the Factory class. That's it.
Abstraction should not depend on details, details should depend on abstraction.
Abstract the methods in classes B and C and make an interface
interface IMethod { public function Method(); }
In this way, the $b variable in class A The $c variable is no longer a concrete variable, but an abstract type variable. I don’t know how their Method is implemented until the moment it is run.
class B implements IMethod { public function B() { //TODO } public function Method() { //TODO echo 'b'; } } class C implements IMethod { public function C() { //TODO } public function Method() { //TODO echo 'c'; } }
To summarize a few points:
1. We move the creation of class B objects and class C objects in class A to class A External
2. Originally, class A relied on class B and class C, but now it has become that A depends on Factory, and Factory depends on B and C.
Related recommendations:
Detailed example code explanation of PHP Inversion of Control (IOC) and Dependency Injection (DI)
Share practical tutorials on PHP Dependency Injection (DI) and Inversion of Control (IoC)
PHP Dependency Injection (DI) and Inversion of Control (IoC) )Example tutorial
The above is the detailed content of Detailed explanation of Ioc and Di examples in php. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

What are the magic methods of PHP? PHP's magic methods include: 1.\_\_construct, used to initialize objects; 2.\_\_destruct, used to clean up resources; 3.\_\_call, handle non-existent method calls; 4.\_\_get, implement dynamic attribute access; 5.\_\_set, implement dynamic attribute settings. These methods are automatically called in certain situations, improving code flexibility and efficiency.

PHP and Python each have their own advantages, and choose according to project requirements. 1.PHP is suitable for web development, especially for rapid development and maintenance of websites. 2. Python is suitable for data science, machine learning and artificial intelligence, with concise syntax and suitable for beginners.
