이 기사에서는 주로 PHP 디커플링의 세 가지 영역에 대한 관련 지식을 소개합니다(서비스 컨테이너에 대한 간략한 논의). 매우 좋은 참조 값을 가지고 있습니다. 아래 편집기로 살펴보겠습니다
이 글을 읽기 전에 PHP 구문, 객체 지향을 숙지해야 합니다.
전체 소프트웨어 프로젝트 개발을 완료하는 과정에서 때로는 여러 사람의 협력이 필요할 수도 있고, 때로는 금액에 관계없이 독립적으로 완료될 수도 있습니다. 코드가 증가하면 코드가 작성됨에 따라 "통제 불능"이 됩니다. 점차적으로 "추악한 인터페이스, 지저분한 구현"으로 인해 프로젝트 유지 관리의 비용과 어려움이 점차 증가하여 지속 불가능하고 유일한 옵션이 되는 지점에 도달했습니다. 재건축이나 재개발.
1단계
가설 시나리오: 세션, 데이터베이스 및 파일 시스템을 동시에 작동할 수 있는 처리 클래스를 작성해야 합니다. . 우리는 이것을 쓸 수도 있습니다.
Realm 기능: 실행할 수 있지만 결합이 심함
class DB{ public function DB($arg1,$arg2){ echo 'constructed!'.PHP_EOL; } } class FileSystem{ public function FileSystem($arg1,$arg2){ echo 'constructed!'.PHP_EOL; } } class Session{ public function Session($arg1,$arg2){ echo 'constructed!'.PHP_EOL; } } class Writer{ public function Write(){ $db=new DB(1,2); $filesystem=new FileSystem(3,4); $session=new Session(5,6); } } $writer=new Writer(); $writer->write();
작성 단점:
1. 공개 함수에서 객체를 구성합니다. 일단 데이터베이스 매개변수가 변경되면 수정에 많은 작업이 필요합니다
DB의 다양한 API에 익숙해야 합니다. >소비를 줄일 수 있는 방법이 있나요?
두 번째 수준(매개변수 종속성)
가설 시나리오: 고객이 다르기 때문에 데이터베이스 주소를 자주 변경해야 하며, DB 클래스를 호출해야 합니다. 아주 많고(수십개가 있다면), 데이터베이스 주소가 변경되더라도 이들 클래스의 코드는 수정하지 않아도 되기를 바랍니다.
class DB{ public function DB($arg1,$arg2){ echo 'constructed!'.PHP_EOL; } } class FileSystem{ public function FileSystem($arg1,$arg2){ echo 'constructed!'.PHP_EOL; } } class Session{ public function Session($arg1,$arg2){ echo 'constructed!'.PHP_EOL; } } class Writer{ protected $_db; protected $_filesystem; protected $_session; public function Set($db,$filesystem,$session){ $this->_db=$db; $this->_filesystem=$filesystem; $this->_session=$session; } public function Write(){ } } $db=new DB(1,2); $filesystem=new FileSystem(3,4); $session=new Session(5,6); $writer=new Writer(); $writer->Set($db,$filesystem,$session); $writer->write();
DB 클래스의 구성을 클라이언트로 옮겼음에도 불구하고 수정이 가해지면 작업량이 크게 줄어들지만 새로운 문제가 발생합니다. Writer 클래스를 생성하려면 먼저 DB 클래스, FileSystem 클래스 등을 생성해야 합니다. 이는 Writer 클래스를 담당하는 사람에게 매우 까다로운 일입니다. 그는 다른 많은 클래스 문서를 읽고 하나씩 생성해야 합니다(필요할 수도 있음). 초기화) 필수 작성기변수.
그래서 우리는 Writer 클래스를 작성하는 사람들이 매개변수를 입력하지 않고도 더 빠른 인터페이스를 사용하여 원하는 클래스를 만들고 호출할 수 있도록 더 나은 작성 방법이 있기를 바랍니다.
세 번째 레벨(IOC 컨테이너)
처음 두 레벨 이후에는 다음과 같은 이점을 추가할 수 있기를 바랍니다.
1. DB 클래스, Session 클래스, FileSystem 클래스는 $db=new라고 쓰는 등 매번 지루한 초기화 없이 "즉시" 사용할 수 있기를 바랍니다. DB(arg1, arg2);이 유형의 명령문입니다.
2. DB 및 기타 유형의 객체는 "전역"이며 전체 프로그램 실행 중 언제든지 호출할 수 있기를 바랍니다.
3. DB 및 기타 유형을 호출하는 프로그래머는 이 클래스에 대해 너무 많은 세부 사항을 알 필요가 없으며 string이라는 별칭을 사용해도 됩니다. 그러한 객체를 생성합니다.
위의 목표를 달성할 수 있는 것이 바로 IOC 컨테이너입니다. IOC 컨테이너를 전역 변수로 간주하고 관련 배열 을 사용하여 문자열을 구성하면 됩니다. 그리고 함수 는 바인딩을 합니다.
먼저 컨테이너 클래스를 구현합니다
class Container{ public $bindings; public function bind($abstract,$concrete){ $this->bindings[$abstract]=$concrete; } public function make($abstract,$parameters=[]){ return call_user_func_array($this->bindings[$abstract],$parameters); } }
서비스 등록(바인딩)
$container=new Container(); $container->bind('db',function($arg1,$arg2){ return new DB($arg1,$arg2); }); $container->bind('session',function($arg1,$arg2){ return new Session($arg1,$arg2); }); $container->bind('fs',function($arg1,$arg2){ return new FileSystem($arg1,$arg2); });
컨테이너 종속성
위 내용은 PHP 디커플링의 삼중 영역에 대한 샘플 코드(서비스 컨테이너에 대한 간략한 설명)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!