zoukankan      html  css  js  c++  java
  • .NET 云原生架构师训练营(设计原则&&设计模式)学习笔记

    目录

    • 设计原则
    • 设计模式

    设计原则

    • DRY (Don't repeat yourself 不要重复)
    • KISS (Keep it stupid simple 简单到傻子都能看懂)
    • YAGNI (You Aren't Gonna Need It 你不会需要它的)
    • CCP 共同闭包
    • CRP 共同复用
    • 高内聚、低耦合
    • 惯例优先配置
    • SCO 关注点分离
    • ADP 无依赖环
    • SOLID 面向对象设计原则

    SOLID

    • S - Single-responsiblity Principle 单一职责
    • O - Open-closed Principle 对修改关闭,对扩展开放
    • L - Liskov Substitution Principle 里氏替换
    • I - Interface Segregation Principle 接口隔离
    • D - Dependency Inversion Principle 依赖反转

    设计模式

    模式通常是指那些在一些相同的领域和上下文内,解决同样的问题。所以一定要结合具体的使用场景去了解设计模式

    使用设计模式的目的是为了可重用代码,提高代码的可扩展性和可维护性

    设计模式主要分为三种类型:创建型,结构型,行为型

    创建型模式关注点是如何创建对象,其核心思想是要把对象的创建和使用相分离,这样使得两者能相对对立地变换

    结构型模式主要涉及如何组合各种对象以便获得更好、更灵活的结构。虽然面向对象的继承机制提供了最基本的子类扩展父类的功能,但结构型模式不仅仅简单地使用继承,而更多地通过组合与运行期的动态组合来实现更灵活的功能

    行为型模式主要涉及算法和对象间的职责分配。通过使用对象组合,行为型模式可以描述一组对象应该如何协作来完成一个整体任务

    类型 模式
    创建型 工厂方法:Factory Method;抽象工厂:Abstract Factory;建造者:Builder;原型:Prototype;单例:Singleton
    结构型 适配器;桥接;组合;装饰器;外观;享元;代理
    行为型 责任链;命令;解释器;迭代器;中介;备忘录;观察者;状态;策略;模板方法;访问者

    工厂方法:Kestrel Server 从网络监听

    意图:定义一个创建产品对象的工厂接口,将实际创建工作推迟到子类中

    何时使用:有多种类型需要根据特定的场景进行创建实例时(或单个对象的创建过程比较复杂时)

    外观模式:Kestrel Server 到请求执行调度

    为子系统中的一组接口提供一个一致的界面。Facade 模式定义了一个高层接口,这个接口使得这一子系统更加容易使用

    符合单一职责原则,不要将过多的逻辑封装在 TransportManager 类中

    KISS 原则,KEEP IT Stupid Simple

    源码

    https://github.com/dotnet/aspnetcore/

    目录 Microsoft.AspNetCore.Server.Kestrel.Core 下面的 KestrelServerImpl 类中有一个绑定方法

    options.EndPoint = await _transportManager.BindAsync(options.EndPoint, connectionDelegate, options.EndpointConfig, onBindCancellationToken).ConfigureAwait(false);
    

    这个方法是通过 TransportManager 实现的,它是 Facade 模式,所以直接用了一个类来实现

    在 TransportManager 的 StartAcceptLoop 方法中实现了绑定的功能,其实就是调用了其他的几个类

    private void StartAcceptLoop<T>(IConnectionListener<T> connectionListener, Func<T, Task> connectionDelegate, EndpointConfig? endpointConfig) where T : BaseConnectionContext
    {
        var transportConnectionManager = new TransportConnectionManager(_serviceContext.ConnectionManager);
        var connectionDispatcher = new ConnectionDispatcher<T>(_serviceContext, connectionDelegate, transportConnectionManager);
        var acceptLoopTask = connectionDispatcher.StartAcceptingConnections(connectionListener);
    
        _transports.Add(new ActiveTransport(connectionListener, acceptLoopTask, transportConnectionManager, endpointConfig));
    }
    

    在 TransportManager 的绑定方法中使用了 _transportFactory,它就是 IConnectionListenerFactory

    var transport = await _transportFactory.BindAsync(endPoint, cancellationToken).ConfigureAwait(false);
    

    IConnectionListenerFactory 转到实现可以看到 SocketTransportFactory,它在 Transport.Sockets 中

    除了 SocketTransportFactory,还有 QuicTransportFactory,它是 HTTP/3 协议的监听器

    多种实现最后都由 TransportManager 进行统一的管理

    工厂方法符合开闭原则,后期有新的类型的时候,只需要添加新的类型和对应的工厂即可。不需要对代码逻辑进行修改

    课程链接

    https://appsqsyiqlk5791.h5.xiaoeknow.com/v1/course/video/v_5f39bdb8e4b01187873136cf?type=2

    知识共享许可协议

    本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。

    欢迎转载、使用、重新发布,但务必保留文章署名 郑子铭 (包含链接: http://www.cnblogs.com/MingsonZheng/ ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。

    如有任何疑问,请与我联系 (MingsonZheng@outlook.com) 。

  • 相关阅读:
    Nginx如何配置基础缓存
    Websocket消息过长自动断开连接?
    Docker错误删除Postgresql容器如何恢复?
    Docker安装带中文全文搜索插件zhparser的Postgresql数据库
    Postgresql数据库安装中文全文搜索插件zhparser的问题
    Presto通过RESTful接口新增Connector
    在windows的IDEA运行Presto
    Druid.io通过NiFi摄取流数据
    Druid.io SQL乱码问题
    Druid.io启用SQL支持
  • 原文地址:https://www.cnblogs.com/MingsonZheng/p/15764162.html
Copyright © 2011-2022 走看看