类的依赖处理

博客主要探讨类的依赖处理,使用 TypeScript 示例代码。介绍了三种处理方式,不采用接口存在类间强耦合问题;采用接口时,客户端会用到自己用不到的方法;还提及了采用接口隔离的方式,但未详述其优缺点。

参考: https://blog.youkuaiyun.com/m0_37450089/article/details/81607363

类的依赖处理

示例代码用ts

一、不采用接口
class Car {
    constructor() {
        this.ligng = new Light()
        this.engin = new Engin()
    }

    // 刹车
    brake() {
        this.light.blink()
        this.engine.stop()
    }
}

// 车灯
class Light {
    blink() {
        console.error('刹车灯闪烁...')
    }
}

// 车发动机
class Engine {
    stop() {
        console.error('发动机熄火...')
    }
}

let car = new Car()
car.brake()

缺点:

  • 类之间强耦合
二、采用接口
interface StopInerface {
    // 引擎熄火
    stop(): void
    // 刹车灯闪烁
    blink(): void
}

class Car {
    // 刹车
    brake(i: StopInerface) {
        i.blink()
        i.stop()
    }
}

class Light implements StopInerface{
    constructor() {}

    blink() {
        console.error('刹车灯闪烁...')
    }

    // 必须实现接口
    stop() {}
}

class Engine implements StopInterface{
    // 必须实现接口
    blink() {}

    stop() {
        console.error('发动机熄火...')
    }
}

let car = new Car()
let light = new Light()
let engine = new Engine()
car.brake({
        blink: light.blink,
        stop: engine.stop
    })

缺点:

  • 客户端使用自己用不到的方法
三、采用接口隔离

interface LightStopInerface {
    blink(): void
}

interface EngineStopInterface {
    stop(): void
}

class Car {
    constructor() {}

    // 刹车
    brake(light: LightStopInerface, engine: EngineStopInterface) {
        light.blink()
        engine.stop()
    }
}

class Light implements LightStopInerface{
    constructor() {}

    blink() {
        console.error('刹车灯闪烁...')
    }
}

class Engine implements EngineStopInterface{
    constructor() {}

    stop() {
        console.error('发动机熄火...')
    }
}

let car = new Car()
let light = new Light()
let engine = new Engine()
car.brake({blink: light.blink}, {stop: engine.stop})

<全文结束>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值