2019-03-31Contract 契约模式

浅谈Laravel中的设计模式(四) Contract 契约模式

技术预备:熟悉Laravel的使用

契约模式(Contract)

一、首先什么是契约模式呢?

学过Java的童鞋一定知道interface、抽象类之类的概念。

主要就是为了具有相同操作的类定义一些共同的方法,但是具体逻辑就由具体类去实现,也就是为了降低耦合度。

另外就是为了定下一个相同的规范,因为在实际工作中很有可能相同功能的类是由不同的人员编写的,及早定下规范更便于使用。

二、契约模式有什么用呢?

在这里,我们使用Redis和Memcache举例。这两个都是缓存数据库,一些操作如:set、get之类的他们是共有的,那么就可以定下一个契约Cache,在其中定义共有的操作。

namespace App\Contract;

interface Cache{    

publicfunctionconnection($config);    

publicfunctionset($key,$value);    

publicfunctionget($key);    

publicfunctiondel($key);

}

然后定义了实现Cache的Redis和Memcache类

namespace App\Cache;

use App\Contract\Cache;

class Redis implements Cache{    

publicfunctionconnection($config)    {     // TODO: Implement connection() method.    }    

publicfunctionset($key,$value)    {        // TODO: Implementset() method.    }    

publicfunctionget($key)    {        // TODO: Implement get() method.    }    

publicfunctiondel($key)    {        // TODO: Implement del() method.    }

}

namespace App\Cache;

use App\Contract\Cache;

class Memcache implements Cache{    

publicfunctionconnection($config)    {        // TODO: Implement connection() method.    }    publicfunctionset($key,$value)    {        // TODO: Implementset() method.    }    publicfunctionget($key)    {        // TODO: Implement get() method.    }    

publicfunctiondel($key)    {        // TODO: Implement del() method.    }

}

在具体的逻辑代码中,我们使用了Redis作为缓存数据库。

use App\Cache\Redis;

class StudentController{    

private$cache;    

publicfunction__construct()    {$this->cache = new Redis();    }    

publicfunctiongetStudent()    {$this->cache->get('student');    }

}

但是当某一天,需要切换到Memcache作为缓存的时候,只需要把Redis类替换掉就能完美切换。

use App\Cache\Memcache;

class StudentController{    

private$cache;    

publicfunction__construct()    {$this->cache = new Memcache();    }    

publicfunctiongetStudent()    {$this->cache->get('student');    }

}

因为具体的set、get等操作是由类自己去实现的。而调用操作方法的参数在契约类Cache中已经定下了规范,并不会影响到其他逻辑。

看过前面篇章的童鞋估计已经想到了,这不就和Facade一样了吗!又是为了切换时可以无缝对接。

是的,如果说他们的效果的话的确是一样的,使用契约模式编写完Redis和Memcache类之后,的确可以放到Application中作为Facade来调用。

但是需要切换的时候,Facade对应的是全局的切换,而Contract就是局部的切换。例如我只想某个接口进行Redis到Memcache切换的话,那就需要用到Contract契约模式了。

三、结语

可以看到,Laravel中有着非常多的设计模式。从最前面的关注点分离(SoC),到外观模式(Facade)、容器(Container),最后到契约模式(Contract),很多都是为了解耦、为了无缝切换,是许许多多的程序员们被时常变更的需求给虐出来的。

但其实日常开发中,能用到这么多设计模式的机会是很少的。

有时我自己也在想,Laravel这个框架究竟是不是过度设计了?这个只能留给读者们自己思考了。

----- End -----

你可能感兴趣的:(2019-03-31Contract 契约模式)