zoukankan      html  css  js  c++  java
  • [Study Note] Patterns in Practice 20100404

    [Cohesion And Coupling]

    1. keep things that have to change together as close together in the code as possible.
    2. Allow unrelated things in the code to change independently (also know as orthogonality).
    3. Minimize duplication in the code.

    Decrease coupling

    Coupling among classes or subsystems is a measure of how interconnected those classes or subsystems are.

    1. Make the code easier to read
    2. Make our classes easier to consume by other developers by hiding the ugly inner workings of our classes behind well-designed APIs.
    3. Isolate potential changes to a small area of code.
    4. Reuse classes in completely new contexts.

    Code Smells

    • Divergent Changes A single class that has to be changed in different ways for different reasons.
    • Feature Envy A method in ClassA seems way too interested in the workings and data fields of ClassB.
    • Shotgun Surgery A certain type of change in system repeatedly leads to making lots of small changes to a group of classes.

    Increase Cohesion

    The academic definition of cohesion is that it is a measure of how closely related all the responsibilities, data, and methods of a class are to each other.

    cohesion as a measure of whether a class has a well-defined role within the system.

    An easy test for cohesion is to look at a class and decide whether all the contents of the class are directly related to and described by the name of the class.

    put code where you’d expect to find it.

    Eliminate Inappropriate Intimacy

    Inappropriate intimacy refers to a method in a class that has too much intimate knowledge of another class.

    The Law of Demeter

    only talk to your immediate friends

    Tell, Don’t Ask

    tell objects what to do, not ask an object about its internal state, make some decisions about that state, then tell that object what to do.

    Information Expert pattern

    the candidate class for a new responsibility is the class who knows the information necessary to fulfill this responsibility.

    GRASP, General Responsibility Assignment Software Patterns

    • Information Expert
    • Creator
    • Controller
    • Low Coupling
    • High Cohesion
    • Polymorphism
    • Pure Fabrication
    • Indirection
    • Protected Variations

    Say It Once and Only Once

    One of the best ways to improve cohesion in your system is to eliminate duplication wherever you spot it.

    Wrapping Up

    [Design For Testability]

    The Value Proposition

    testability is all about creating rapid and effective feedback cycles in your development process to find problems in your code.

    problems are cheaper to fix the earlier they are detected.

    What Is Testability?

    The end goal of testability to create rapid feedback cycles in your development process in order to find and eliminate flaws in your code.

    • Repeatable
    • Easy to Write
    • Easy to Understand
    • Fast

    Mocking Best Practices

    1. Do not mock or fake out calls to fine-grained or chatty interfaces like ADO.NET that require a lot of calls.
    2. Do not mock any interface or class that you do not completely understand.
    3. If you find yourself repeating the same mocking setup across multiple tests, you may want to change your design to separate the code that forces the repetitive mocking setup.
    4. Do use mock objects as placeholders for class that don;t yet exist especially as a way to help determine what the public interface should be.

    Isolate the Ugly Stuff

    some things are just plain ugly to deal with in testing.

    ugly stuff list

    • Database access.
    • GUI technologies.
    • Active Directory access.
    • Web services.
    • Configuration files.

    SpecUnit

    Using Fakes to Establish Boundary Conditions

    Repository pattern

    Mediates between the domain and data mapping layers using a collection – like interface for accessing domain objects.

    A Repository mediates between the domain and data mapping layers, acting like an in-memory domain object collection. Client objects construct query specifications declaratively and submit them to Repository for satisfaction. Objects can added to and removed from the Repository, as they can from a simple collection of objects, and the mapping code encapsulated by the Repository will carry out the appropriate operations behind the scenes. Conceptually, a Repository encapsulates the set of Objects persited in a data store and the operations performed over them, providing a more object-oriented view of the persistence layer. Repository also supports the objective of achieving a clean separation and one-way dependency between the domain and data mapping layers.

    Aggregate is A cluster of associated objects that are treated as a unit for the purpose of data changes. External references are restricted to one member of the Aggregate, designated as the root. A set of consistency rules applies with the Aggregate’s boundaries.

    we don’t have a repository per entity!

    In a real application often several operations have to be executed inside a single transaction and thus inside a transaction and thus inside a single session (the reason is that a transaction cannot span multiple sessions – at least when not using distributed transactions).

    不得不说这是一篇好文章,至少让我明白了 Repository 并不只是字面上的含义,和我一样的 NHibernate 初学者,最好能够看一下前后这两篇文章:The Repository PatternNhibernate and the Unit of Work Pattern

    Unit of Work pattern, UoW

    Fake object, such as stubs or mocks, are a huge advantage for doing emergent or continuous design by allowing you to build and even design, a system incrementally by standing in for services that you haven’t ye created.

    The Gateway Pattern

    Gateway Pattern

    An object that encapsulates access to an external system or resource.

    Wrap all the special API code into a class whose interface looks like a regular object. Other objects access the resource through this Gateway, which translates the simple method calls into the appropriate specialized API.

    Integration Patterns

    • Pipes and Filters How do you implement a sequence of transformations so that you can combine an reuse them independently

     Pipes.and.Filters.Pattern

    Pipes and Filters provides a solution for moving the output of one system into another system. The pipe is the portion of the code that is connected to the source system and to the sink or the receiving system. The filter is the portion of the code that transforms the data so that the sink program can process it.

    • Gateway How can you make the application of an integration solution access without introducing many-to-one coupling between the application and the external system.

    Gateway.Pattern

    The Gateway pattern abstracts the access to an external system to a single interface.

    Separate Deciding from Doing

    treat performing an action and deciding to take an action as two separate responsibilities.

    • Prevent duplication in the code.
    • Makes the code simpler.
    • Infrastructure change easily (robust).

    Small Tests before Big Tests

    Smaller tests are cheaper to create, easier to understand, faster to run, and much simpler to debug.

    The Big Picture

    How can I test this in isolation?

  • 相关阅读:
    C语言之内存分配函数
    C语言const
    【Hihocoder 1167】 高等理论计算机科学 (树链的交,线段树或树状数组维护区间和)
    【HDU 1828】 Picture (矩阵周长并,线段树,扫描法)
    【 HDU 1255】 覆盖的面积(矩阵面积交,线段树,扫描法)
    【HDU 1542】Atlantis 矩形面积并(线段树,扫描法)
    【BZOJ 2333 】[SCOI2011]棘手的操作(离线+线段树|可并堆-左偏树)
    【20161108】总结
    【BZOJ 3110】 [Zjoi2013]K大数查询(整体二分)
    【Bzoj 3295】 动态逆序对(树套树|CDQ分治)
  • 原文地址:https://www.cnblogs.com/zhaorui/p/20100404_patterns_in_practice.html
Copyright © 2011-2022 走看看