대상:
클래스의 인터페이스를 고객이 원하는 다른 인터페이스로 변환하여 원래 호환되지 않는 인터페이스가 함께 작동할 수 있습니다. 대중적인 이해는 다양한 인터페이스를 통합 API 인터페이스에 적용하는 것입니다.
캐릭터 :
대상 적응 대상, 이 역할은 다른 클래스를 어떤 인터페이스로 변환할지 정의하며, 이것이 우리가 예상하는 인터페이스입니다.
Adaptee는 조정이 필요한 인터페이스입니다.
Adapter 어댑터, 나머지 두 역할은 기존 역할이며 Adaptee 및 Target 인터페이스를 조정하는 데 사용되는 어댑터 역할을 새로 설정해야 합니다.
적용 시나리오:
데이터 작업에 mysql, mysqli, pdo, sqlite, postgresql 등이 포함되어 있고 생성 환경에서 데이터베이스를 변경해야 하는 경우 어댑터 모드를 사용하여 인터페이스를 통일할 수 있습니다. 캐시 시나리오에도 동일하게 적용됩니다. 이렇게 하면 캐시 전략(memcache, redis, apc)을 변경하는 것이 더 편리해집니다.
장점:
적응된 사람은 고객에게 투명하다는 목적을 달성하기 위해 어댑터를 통해 적응 대상의 적응을 완료합니다.
샘플 코드:
//适配目标,规定的接口将被适配对象实现 interface IDatabase { public function connect($host, $username, $password, $database); public function query($sql); } //适配器 class Mysql implements IDatabase { protected $connect; public function connect($host, $username, $password, $database) { $connect = mysql_connect($host, $username, $password); mysql_select_db($database, $connect); $this->connect = $connect; //... } public function query($sql) { //... } } //适配器 class Postgresql implements IDatabase { protected $connect; public function connect($host, $username, $password, $database) { $this->connect = pg_connect("host=$host dbname=$database user=$username password=$password"); //... } public function query($sql) { //... } } //客户端使用 $client = new Postgresql(); $client->query($sql);
위와 같습니다:
대상 적응 대상: IDataBase 인터페이스
Adaptee가 적용되었습니다: mysql 및 postgresql의 데이터베이스 작업 기능
어댑터: mysql 클래스 및 postgresql 클래스