复制代码 代码如下:
<?php
/*
边学边做的,为方便自己翻阅而发布,更为得到高人指点而发布,欢迎高手指点......
【提示】本例通过测试无误
【情景设计】
模拟计算机主板IDE接口,比如:主板可以存取的储存器常常有光驱、硬盘、闪存等等,
为了方便,有必要对这些不同的储存器设定同一的接口。
本例还假设一种前所未有的、存取方式与众不同的外星储存器也要加到主板上进行存取,
于是需要采用耦合的设计模式。
【本例主要讲述】
1、通过接口、抽象类、一般类继承三种方式达到所谓的“接口”模式,以此说明:
A、子类对象可以当父类对象用,因为子类是特殊的父类"耦合设计模式"!
*/
//----------------------------------------------------------------------
/*【方式一】接口实现方式:*/
interface readandwrite{
function read();
function write();
}
class motherboard{
private $storage;
function __construct(readandwrite $obj){
$this->storage=$obj;
}
function read(){
$this->storage->read();
}
function write(){
$this->storage->write();
}
}
class flash implements readandwrite{
function __construct(){
echo "我是闪存:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
class yingpan implements readandwrite{
function __construct(){
echo "我是硬盘:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
class disco implements readandwrite{
function __construct(){
echo "我是光盘:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
//----------------------------------------------------------------------
/*【方式二】抽象类实现方式:
abstract class readandwrite{
abstract function read();
abstract function write();
}
class motherboard{
private $storage;
function __construct(readandwrite $obj){
$this->storage=$obj;
}
function read(){
$this->storage->read();
}
function write(){
$this->storage->write();
}
}
class flash extends readandwrite{
function __construct(){
echo "我是闪存:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
class yingpan extends readandwrite{
function __construct(){
echo "我是硬盘:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
class disco extends readandwrite{
function __construct(){
echo "我是光盘:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
*/
//----------------------------------------------------------------------
//【方式三】一般类继承实现方式:
/*
class readandwrite{
function read(){
echo "reading..............";
}
function write(){
echo "writing..............";
}
}
class motherboard{
private $storage;
function __construct(readandwrite $obj){
$this->storage=$obj;
}
function read(){
$this->storage->read();
}
function write(){
$this->storage->write();
}
}
class flash extends readandwrite{
function __construct(){
echo "我是闪存:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
class yingpan extends readandwrite{
function __construct(){
echo "我是硬盘:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
class disco extends readandwrite{
function __construct(){
echo "我是光盘:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
*/
//----------------------------------------------------------------------
/*
【耦合模式】
耦合模式就是将不同标准的两个类(本例的接口、抽象类、普通基类与外星储存器有不同的存取方法),
通过中间转换器,达到同一标准的目的,就像转接线一样——本例就是将unknow类的Rdata、Wdata方法转
换成read、write方法,达到和本例的接口、抽象类、普通基类相同的存取方法, 本例的中间转换器是
Apdater类。
由于php中只能继承一个类但可以继承多个接口,所以产生了三种耦合方法:
方法一:中间转换器Apdater类继承抽象类或普通基类,但由于php中只能继承一个类,所以在Apdater
类中定义一个外星存储器类unknow的对象,并用重载继承的抽象类或普通基类的存取方法的方式来转
换存取方法,达到同一存取方法的目的。
方法二:中间转换器Apdater类继承外星存储器类unknow、接口,此时可以直接用Apdater类的存取方法
(parent::Rdata()与parent::Wdata()——php中子类调用父类方法的方式),和实现接口规定方法,
来转换存取方法,达到同一存取方法的目的。
方法三:与方法一雷同,只是改为继承(实现)接口;
*/
//----------------------------------------------------------------------
/*
【方法一】
*/
/*
class unknow{
function __construct(){
echo "<font color=#ff0000>我是地球人未知的外星储存器,我有不同于地球储存器的存取方式:</font><br>";
}
function Rdata(){
echo "I'm reading now......<br>";
}
function Wdata(){
echo "I'm writing now......<hr>";
}
}
class Adpater extends readandwrite{
private $obj;
function __construct(unknow $x){
$this->obj=$x;
}
function read(){
$this->obj->Rdata();
}
function write(){
$this->obj->Wdata();
}
}
*/
//----------------------------------------------------------------------
/*
【方法二】
class unknow{
function __construct(){
echo "<font color=#ff0000>我是地球人未知的外星储存器,我有不同于地球储存器的存取方式:</font><br>";
}
function Rdata(){
echo "I'm reading now......<br>";
}
function Wdata(){
echo "I'm writing now......<hr>";
}
}
class Adpater extends unknow implements readandwrite{
function read(){
parent::Rdata();
}
function write(){
parent::Wdata();
}
}
*/
//------------------------------------------------------------------------
/*
【方法三】
*/
class unknow{
function __construct(){
echo "<font color=#ff0000>我是地球人未知的外星储存器,我有不同于地球储存器的存取方式:</font><br>";
}
function Rdata(){
echo "I'm reading now......<br>";
}
function Wdata(){
echo "I'm writing now......<hr>";
}
}
class Adpater implements readandwrite{
private $obj;
function __construct(unknow $x){
$this->obj=$x;
}
function read(){
$this->obj->Rdata();
}
function write(){
$this->obj->Wdata();
}
}
//【程序主体调用】
echo "<strong><font color=#990000 size=20px>面向对象程序设计——接口</font></strong><hr>";
$storage1=new flash();
$computer=new motherboard($storage1);
$computer->read();
$computer->write();
$storage2=new yingpan();
$computer=new motherboard($storage2);
$computer->read();
$computer->write();
$storage3=new disco();
$computer=new motherboard($storage3);
$computer->read();
$computer->write();
$un_storage=new unknow();
$apdaterx=new Adpater($un_storage);
$computer=new motherboard($apdaterx);
$computer->read();
$computer->write();
?>
<?php
/*
边学边做的,为方便自己翻阅而发布,更为得到高人指点而发布,欢迎高手指点......
【提示】本例通过测试无误
【情景设计】
模拟计算机主板IDE接口,比如:主板可以存取的储存器常常有光驱、硬盘、闪存等等,
为了方便,有必要对这些不同的储存器设定同一的接口。
本例还假设一种前所未有的、存取方式与众不同的外星储存器也要加到主板上进行存取,
于是需要采用耦合的设计模式。
【本例主要讲述】
1、通过接口、抽象类、一般类继承三种方式达到所谓的“接口”模式,以此说明:
A、子类对象可以当父类对象用,因为子类是特殊的父类"耦合设计模式"!
*/
//----------------------------------------------------------------------
/*【方式一】接口实现方式:*/
interface readandwrite{
function read();
function write();
}
class motherboard{
private $storage;
function __construct(readandwrite $obj){
$this->storage=$obj;
}
function read(){
$this->storage->read();
}
function write(){
$this->storage->write();
}
}
class flash implements readandwrite{
function __construct(){
echo "我是闪存:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
class yingpan implements readandwrite{
function __construct(){
echo "我是硬盘:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
class disco implements readandwrite{
function __construct(){
echo "我是光盘:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
//----------------------------------------------------------------------
/*【方式二】抽象类实现方式:
abstract class readandwrite{
abstract function read();
abstract function write();
}
class motherboard{
private $storage;
function __construct(readandwrite $obj){
$this->storage=$obj;
}
function read(){
$this->storage->read();
}
function write(){
$this->storage->write();
}
}
class flash extends readandwrite{
function __construct(){
echo "我是闪存:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
class yingpan extends readandwrite{
function __construct(){
echo "我是硬盘:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
class disco extends readandwrite{
function __construct(){
echo "我是光盘:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
*/
//----------------------------------------------------------------------
//【方式三】一般类继承实现方式:
/*
class readandwrite{
function read(){
echo "reading..............";
}
function write(){
echo "writing..............";
}
}
class motherboard{
private $storage;
function __construct(readandwrite $obj){
$this->storage=$obj;
}
function read(){
$this->storage->read();
}
function write(){
$this->storage->write();
}
}
class flash extends readandwrite{
function __construct(){
echo "我是闪存:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
class yingpan extends readandwrite{
function __construct(){
echo "我是硬盘:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
class disco extends readandwrite{
function __construct(){
echo "我是光盘:<br>";
}
function read(){
echo "开始读取数据......<br>";
}
function write(){
echo "开始储存数据......<hr>";
}
}
*/
//----------------------------------------------------------------------
/*
【耦合模式】
耦合模式就是将不同标准的两个类(本例的接口、抽象类、普通基类与外星储存器有不同的存取方法),
通过中间转换器,达到同一标准的目的,就像转接线一样——本例就是将unknow类的Rdata、Wdata方法转
换成read、write方法,达到和本例的接口、抽象类、普通基类相同的存取方法, 本例的中间转换器是
Apdater类。
由于php中只能继承一个类但可以继承多个接口,所以产生了三种耦合方法:
方法一:中间转换器Apdater类继承抽象类或普通基类,但由于php中只能继承一个类,所以在Apdater
类中定义一个外星存储器类unknow的对象,并用重载继承的抽象类或普通基类的存取方法的方式来转
换存取方法,达到同一存取方法的目的。
方法二:中间转换器Apdater类继承外星存储器类unknow、接口,此时可以直接用Apdater类的存取方法
(parent::Rdata()与parent::Wdata()——php中子类调用父类方法的方式),和实现接口规定方法,
来转换存取方法,达到同一存取方法的目的。
方法三:与方法一雷同,只是改为继承(实现)接口;
*/
//----------------------------------------------------------------------
/*
【方法一】
*/
/*
class unknow{
function __construct(){
echo "<font color=#ff0000>我是地球人未知的外星储存器,我有不同于地球储存器的存取方式:</font><br>";
}
function Rdata(){
echo "I'm reading now......<br>";
}
function Wdata(){
echo "I'm writing now......<hr>";
}
}
class Adpater extends readandwrite{
private $obj;
function __construct(unknow $x){
$this->obj=$x;
}
function read(){
$this->obj->Rdata();
}
function write(){
$this->obj->Wdata();
}
}
*/
//----------------------------------------------------------------------
/*
【方法二】
class unknow{
function __construct(){
echo "<font color=#ff0000>我是地球人未知的外星储存器,我有不同于地球储存器的存取方式:</font><br>";
}
function Rdata(){
echo "I'm reading now......<br>";
}
function Wdata(){
echo "I'm writing now......<hr>";
}
}
class Adpater extends unknow implements readandwrite{
function read(){
parent::Rdata();
}
function write(){
parent::Wdata();
}
}
*/
//------------------------------------------------------------------------
/*
【方法三】
*/
class unknow{
function __construct(){
echo "<font color=#ff0000>我是地球人未知的外星储存器,我有不同于地球储存器的存取方式:</font><br>";
}
function Rdata(){
echo "I'm reading now......<br>";
}
function Wdata(){
echo "I'm writing now......<hr>";
}
}
class Adpater implements readandwrite{
private $obj;
function __construct(unknow $x){
$this->obj=$x;
}
function read(){
$this->obj->Rdata();
}
function write(){
$this->obj->Wdata();
}
}
//【程序主体调用】
echo "<strong><font color=#990000 size=20px>面向对象程序设计——接口</font></strong><hr>";
$storage1=new flash();
$computer=new motherboard($storage1);
$computer->read();
$computer->write();
$storage2=new yingpan();
$computer=new motherboard($storage2);
$computer->read();
$computer->write();
$storage3=new disco();
$computer=new motherboard($storage3);
$computer->read();
$computer->write();
$un_storage=new unknow();
$apdaterx=new Adpater($un_storage);
$computer=new motherboard($apdaterx);
$computer->read();
$computer->write();
?>
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2024年11月19日
2024年11月19日
- 好薇2024《兵哥哥》1:124K黄金母盘[WAV+CUE]
- 胡歌.2006-珍惜(EP)【步升大风】【FLAC分轨】
- 洪荣宏.2014-拼乎自己看【华特】【WAV+CUE】
- 伊能静.1999-从脆弱到勇敢1987-1996精选2CD【华纳】【WAV+CUE】
- 刘亮鹭《汽车DJ玩主》[WAV+CUE][1.1G]
- 张杰《最接近天堂的地方》天娱传媒[WAV+CUE][1.1G]
- 群星《2022年度发烧天碟》无损黑胶碟 2CD[WAV+CUE][1.4G]
- 罗文1983-罗文甄妮-射雕英雄传(纯银AMCD)[WAV+CUE]
- 群星《亚洲故事香港纯弦》雨果UPMAGCD2024[低速原抓WAV+CUE]
- 群星《经典咏流传》限量1:1母盘直刻[低速原抓WAV+CUE]
- 庾澄庆1993《老实情歌》福茂唱片[WAV+CUE][1G]
- 许巍《在别处》美卡首版[WAV+CUE][1G]
- 林子祥《单手拍掌》华纳香港版[WAV+CUE][1G]
- 郑秀文.1997-我们的主题曲【华纳】【WAV+CUE】
- 群星.2001-生命因爱动听电影原创音乐AVCD【MEDIA】【WAV+CUE】