laravel 契约(Contracts)
2016-09-21 本文已影响650人
smallnews
laravel 契约(Contracts)
本文重在记录自己的理解和一些心得,如果有什么错误,或者不足,欢迎抛砖!!!
关于契约是否仅仅是这种用法, 和什么时候应该使用契约还是得猿们自行研究,有什么问题欢迎一起探讨!
契约是什么
Laravel中的契约是指框架提供的一系列定义核心服务的接口,比如缓存,队列,日志的接口,契约就是接口
为什么要定义接口
定义接口目的为了解耦
当我们依赖注入缓存实例的时候laravel实现如下:
例如:我们选择使用memcached 缓存驱动
use Illuminate\Contracts\Cache\Repository as Cache;
class Repository{
/**
* 创建一个新的Repository实例
*
* @param Cache $cache
* @return void
*/
public function __construct(Cache $cache)
{
$this->cache = $cache;
}
}
Paste_Image.png
不定义接口
如果不定义接口我们必须这样写
use Memcached;
class Repository{
/**
* 创建一个新的Repository实例
*
* @param Cache $cache
* @return void
*/
public function __construct(Memcached $cache)
{
$this->cache = $cache;
}
}
这样当我们需要切换缓存驱动为redis 的时候,我们必须去控制器中把依赖注入的类型约定修改成redis,因为redis 的实现,和Memcached 并不一定完全相同,这就说明Memcached缓存紧密耦合与laravel
什么才算是松耦合
什么才算松耦合,当系统升级,需要对一种实现进行修改(如从Memcached 需要升级到Redis)时,能够不对代码库进行修改,只需要对配置进行修改就能完成升级的时候就算是松耦合了!
一个契约两种,或者多种实现
个人感觉,契约既然定了,那么对应的实现应该是两种,或者更多的实现,或者在不久的将来会有两个或者更多的实现,契约就是来规定这么多实现的。如果肯定只有一种实现,感觉契约就没啥用了!
总结
- 定义契约,是为了一组功能实现的一个约定,方便第三方接口开发人员的开发
- 契约更像一个框架的一个目录索引,所有契约的实现组成了框架所有的核心服务,并且可以通过契约快速了解这一组功能是干什么的
- 对于缓存类来说,缓存的契约,就是为了规定各种缓存实现(Memcached,Redis,文件缓存)需要实现的功能