(D): Aplicando o “Princípio da Inversão de Dependências” com Typescript e Java

(d): aplicando o

概念

solid 是一个缩写词,代表面向对象编程的五个基本原则,由 robert c. martin(鲍勃大叔)提出。在这里您可以阅读有关他的文章的更多信息。
这些原则旨在改进代码的结构和维护,使其更加灵活、可扩展且更易于理解。这些原则可以帮助程序员创建更有组织的代码、划分职责、减少依赖、简化重构过程并促进代码重用。

缩写中的“d”代表“依赖倒置原则”。 bob叔叔用来定义这个原则的一句话是:

“高层模块不应该依赖于低层模块。两者都应该依赖于抽象。抽象不应该依赖于细节。细节应该依赖于抽象”

依赖倒置原则旨在减少系统组件之间的耦合,提高灵活性、可维护性和可测试性。

dip 解决的问题

紧密耦合:当一个模块直接依赖于具体实现时,对该实现的更改可能会影响其他模块。测试难度:测试直接耦合到特定实现的代码单元更加复杂,因为它需要使用这些具体实现,因此很难创建模拟或存根。可重用性低:与具体细节高度耦合的模块在其他上下文中的可重用性较低。

实际应用

我们将创建一个代码负责通过电子邮件发送通知,以分析问题和可能的解决方案

VALL-E VALL-E

VALL-E是一种用于文本到语音生成 (TTS) 的语言建模方法

VALL-E 68 查看详情 VALL-E

爪哇

class emailservice {    public void sendemail(string message) {        system.out.println("sending email: " + message);    }}class notification {    private emailservice emailservice;    public notification() {        this.emailservice = new emailservice();    }    public void notify(string message) {        this.emailservice.sendemail(message);    }}// usopublic class main {    public static void main(string[] args) {        notification notification = new notification();        notification.notify("welcome to our service!");    }}

打字稿

class emailservice {    sendemail(message: string): void {        console.log(`sending email: ${message}`);    }}class notification {    private emailservice: emailservice;    constructor() {        this.emailservice = new emailservice();    }    notify(message: string): void {        this.emailservice.sendemail(message);    }}// usoconst notification = new notification();notification.notify("welcome to our service!");

问题:

notification 类直接依赖于具体实现(emailservice)。如果我们想更改通知渠道(例如:短信),我们需要更改通知代码。

解决方案和优点:

通知不需要知道消息如何发送的详细信息。易于更换或添加新的沟通渠道。我们可以单独测试通知,而不需要依赖实际的实现。

爪哇

public interface messageservice {    void sendmessage(string message);}public class emailservice implements messageservice {    @override    public void sendmessage(string message) {        system.out.println("sending email: " + message);    }}public class smsservice implements messageservice {    @override    public void sendmessage(string message) {        system.out.println("sending sms: " + message);    }}public class notification {    private final messageservice messageservice;    public notification(messageservice messageservice) {        this.messageservice = messageservice;    }    public void notify(string message) {        messageservice.sendmessage(message);    }}// usopublic class main {    public static void main(string[] args) {        notification emailnotification = new notification(new emailservice());        emailnotification.notify("welcome via email!");        notification smsnotification = new notification(new smsservice());        smsnotification.notify("welcome via sms!");    }}

打字稿

interface messageservice {    sendmessage(message: string): void;}class emailservice implements messageservice {    sendmessage(message: string): void {        console.log(`sending email: ${message}`);    }}class smsservice implements messageservice {    sendmessage(message: string): void {        console.log(`sending sms: ${message}`);    }}class notification {    private messageservice: messageservice;    constructor(messageservice: messageservice) {        this.messageservice = messageservice;    }    notify(message: string): void {        this.messageservice.sendmessage(message);    }}// usoconst emailnotification = new notification(new emailservice());emailnotification.notify("welcome via email!");const smsnotification = new notification(new smsservice());smsnotification.notify("welcome via sms!");

3. 单元测试

爪哇

public class mockmessageservice implements messageservice {    @override    public void sendmessage(string message) {        system.out.println("mock message sent: " + message);    }}// teste com o mockpublic class main {    public static void main(string[] args) {        messageservice mockmessageservice = new mockmessageservice();        notification mocknotification = new notification(mockmessageservice);        mocknotification.notify("test message");    }}

打字稿

class MockMessageService implements MessageService {    sendMessage(message: string): void {        console.log(`Mock message sent: ${message}`);    }}// Teste com o mockconst mockNotification = new Notification(new MockMessageService());mockNotification.notify("Test message");

结论

依赖倒置原则(dip)是灵活而健壮的项目的基本支柱。它允许您减少类之间的耦合,促进代码重用并提高应用程序的可测试性。通过依赖抽象,您的系统变得更能适应变化并可通过新功能进行扩展。实际示例展示了小的设计调整如何解决经常出现的维护问题。将 dip 与其他 solid 原则结合应用可确保更清晰的代码,为增长做好准备。采用这些概念对于寻求卓越软件架构的开发人员至关重要。

立即学习“Java免费学习笔记(深入)”;

参考书目

martin,robert c. 敏捷软件开发、原则、模式和实践。普伦蒂斯·霍尔,2002 年。蒂亚戈·莱特和卡瓦略。 面向对象。 casa do code,2014。

以上就是(D): Aplicando o “Princípio da Inversão de Dependências” com Typescript e Java的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/387635.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 14:22:35
下一篇 2025年11月6日 14:23:14

相关推荐

  • C++如何使用组合对象管理资源生命周期

    C++中通过组合对象实现RAII,将资源生命周期绑定对象生命周期。对象构造时获取资源,析构时自动释放,确保异常安全。如智能指针unique_ptr、shared_ptr管理内存,自定义FileHandle类封装文件操作,lock_guard管理互斥锁,均利用析构函数自动释放资源,避免泄露。 在C++…

    好文分享 2025年12月18日
    000
  • C++对象初始化与成员访问技巧详解

    C++对象初始化需优先使用成员初始化列表,因其可提升效率、满足const和引用成员的强制初始化要求,并正确处理无默认构造函数的成员。 C++对象初始化,说白了,就是给新诞生的对象一个“初见礼”,确保它从一开始就处于一个有效且可用的状态。而成员访问,则是我们与对象内部数据和功能交互的桥梁。这两块儿,看…

    2025年12月18日
    000
  • C++复合对象与内存分配优化策略

    答案:优化C++复合对象内存分配需从减少动态分配、提升数据局部性、利用现代C++特性到自定义分配器逐步深入。应优先使用栈或智能指针管理生命周期,通过移动语义和emplace避免拷贝开销,注意深拷贝陷阱与内存碎片,并在性能瓶颈时引入内存池,结合placement new实现高效内存控制。 在C++的世…

    2025年12月18日
    000
  • C++在Linux系统下环境搭建常见坑及解决方案

    答案是:Linux下C++开发环境搭建需先安装编译工具链,如Ubuntu下用apt安装build-essential,CentOS下用yum或dnf安装Development Tools;编译器找不到时应检查g++是否安装,通过g++ –version验证;头文件缺失需使用-I指定路径或…

    2025年12月18日
    000
  • C++函数模板与类模板结合使用实例

    通过类模板定义通用数据结构,结合函数模板实现灵活操作,支持类型自动推导与转换,利用友元函数或公共接口访问私有成员,并可通过函数对象实现自定义逻辑,提升代码复用性与扩展性。 C++函数模板和类模板结合使用,能极大提升代码的灵活性和复用性。简单来说,就是用模板类来存储数据,然后用模板函数来操作这些数据,…

    2025年12月18日
    000
  • C++如何使用std::variant实现多类型安全存储

    std::variant是C++17提供的类型安全多类型存储方案,相比union和基类指针,它在编译期确定所有可能类型,避免运行时类型错误。它通过std::get、std::holds_alternative和std::visit等机制实现安全访问,其中std::visit结合lambda可优雅处理…

    2025年12月18日
    000
  • C++如何使用匿名组合类型简化代码

    匿名组合类型主要指匿名联合体和匿名结构体,其成员直接提升至外层作用域,无需通过中间实例名访问。与普通组合类型相比,它省去命名层级,使代码更简洁,但不改变内存布局。匿名联合体需手动管理成员生命周期,且易引发类型安全问题,推荐配合判别器使用,并优先考虑std::variant等现代C++替代方案以提升安…

    2025年12月18日
    000
  • C++如何结合策略模式优化算法选择

    策略模式通过封装不同算法为可互换对象,实现算法与客户端解耦,提升灵活性与可维护性;在C++中,借助抽象基类定义策略接口,具体策略类实现算法,上下文类通过智能指针持有策略并委托执行,客户端可动态切换算法;相比传统if-else方式,避免代码膨胀,符合开闭原则;算法选择需综合性能、数据特性、资源限制与业…

    2025年12月18日
    000
  • C++异常处理与类成员函数结合使用

    C++中异常处理与类成员函数结合可提升程序健壮性。成员函数可在错误时抛出异常,如栈空时抛出underflow_error;构造函数因无法返回错误码,常通过异常表明初始化失败,如文件打开失败时抛出runtime_error;noexcept用于标记不抛异常的函数,确保移动操作等性能关键路径安全;异常安…

    2025年12月18日
    000
  • C++如何使用back_inserter和front_inserter插入元素

    back_inserter通过push_back在容器末尾插入,front_inserter通过push_front在开头插入,前者适用于vector等,后者仅用于list、deque等支持前端插入的容器。 在C++中,back_inserter 和 front_inserter 是用于向容器中插入…

    2025年12月18日
    000
  • C++如何在复合类型中实现条件初始化

    在C++中实现复合类型成员的条件初始化,核心是利用构造函数的成员初始化器列表结合条件表达式、辅助函数或Lambda表达式,确保成员在对象构造时即被正确初始化。由于初始化器列表只接受表达式而非语句,无法直接使用if-else等控制结构,因此需通过三元运算符、私有辅助函数或立即调用的Lambda来封装条…

    2025年12月18日
    000
  • 如何将一个C++的结构体或对象以二进制形式写入文件

    使用fstream的write方法可将POD类型结构体直接以二进制写入文件,非POD类型需手动序列化,如处理string时先写长度再写内容,读取时按相同格式恢复数据。 在C++中,将结构体或对象以二进制形式写入文件,通常使用标准库中的 fstream,并配合 write() 方法进行操作。这种方式直…

    2025年12月18日
    000
  • C++shared_ptr自定义删除器使用方法

    shared_ptr的自定义删除器使其能灵活管理非内存资源,通过lambda、函数对象或普通函数指定释放逻辑,确保文件句柄、数组等资源安全释放,实现RAII。 shared_ptr 的自定义删除器,本质上是赋予了智能指针超越简单 delete 操作的能力,让我们能以更灵活、更安全的方式管理那些非内存…

    2025年12月18日
    000
  • C++如何使用std::unique_lock和std::lock_guard

    std::lock_guard适用于固定作用域的简单锁管理,而std::unique_lock提供延迟锁定、手动控制、条件变量配合等高级特性,适用于复杂同步场景。 在C++多线程编程中, std::unique_lock 和 std::lock_guard 都是用于管理互斥锁( std::mutex…

    2025年12月18日
    000
  • C++shared_ptr共享资源管理方法解析

    std::shared_ptr通过引用计数实现共享所有权,自动管理对象生命周期,避免内存泄漏和悬空指针;使用std::make_shared可提升性能与异常安全;需警惕循环引用,可用std::weak_ptr打破;其引用计数线程安全,但被管理对象的并发访问仍需额外同步机制。 C++的 std::sh…

    2025年12月18日
    000
  • C++开发简单日志记录工具实例

    答案:文章介绍了一个轻量级C++日志工具的设计与实现,涵盖日志级别、线程安全、时间戳、输出格式等核心功能,采用单例模式和std::mutex保证多线程安全,通过宏简化调用接口,并探讨了自研日志在学习、轻量和定制化方面的优势,适用于小型项目或特定环境。 在C++开发中,一个简单但可靠的日志记录工具是调…

    2025年12月18日
    000
  • C++如何实现简易问卷调查程序

    答案是C++简易问卷程序通过定义问题结构、用户交互和文件存储实现,支持文本与单选题,利用枚举区分类型,结构体存储数据,fstream保存结果,可扩展为多态设计以增强灵活性和可维护性。 C++实现一个简易的%ignore_a_1%程序,核心思路其实不复杂:你需要定义好问卷的结构,比如每个问题长什么样,…

    2025年12月18日
    000
  • C++如何实现复合对象的移动语义

    实现复合对象的移动语义需定义移动构造函数和移动赋值运算符,通过std::move转移资源所有权而非深拷贝,提升效率;关键是要正确转移指针资源并置原对象为有效但未定义状态,且应声明noexcept以确保标准库能安全使用移动操作。 C++中实现复合对象的移动语义,简单来说,就是让对象内部的资源(比如指针…

    2025年12月18日
    000
  • C++开发环境如何在Windows上快速搭建

    选择适合的C++开发环境需根据开发方向决定:Windows原生开发首选Visual Studio(含MSVC编译器),跨平台或轻量开发推荐MinGW-w64配合VS Code;前者集成度高、调试强,后者灵活高效、支持多平台;配置时确保编译器路径加入系统PATH,并正确设置VS Code的c_cpp_…

    2025年12月18日
    000
  • C++异常传播与模板类函数结合技巧

    异常处理与模板结合需关注类型推导与异常安全。模板中异常传播遵循常规规则,但因类型延迟确定,行为可能随实例化类型变化。例如,SafeContainer::push 调用 vector::push_back 可能因 T 构造失败抛出异常,通过 catch(…) 捕获并重新抛出,确保异常向上传…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信