laravel 契约(Contracts)

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;
    }
}

不定义接口

如果不定义接口我们必须这样写
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,文件缓存)需要实现的功能

你可能感兴趣的:(laravel 契约(Contracts))