美文网首页编程
C#笔记—对于面向接口(抽象)编程的思考

C#笔记—对于面向接口(抽象)编程的思考

作者: 指间_璇律 | 来源:发表于2015-07-26 20:05 被阅读326次

先模拟如下业务场景:

定义一个manager(管理员)类,一个Article(文章)类,管理员分为普通管理员和超级管理员,文章有编辑功能,只有超级管理员有权限对文章进行编辑;下面用代码模拟场景:

//为了方便表示管理员权限,使用枚举方式

enum Level

{

normal = 0,   //普通

super = 1      //超级

}

//管理员类

class Manager

{

private int _id;

private string _name;

private int _level;

public Manager(int id, string name, int level)

{

_id = id;

_name = name;

_level = level;

}

public bool CheckPower()

{

if (_level.Equals(Convert.ToInt32(Level.super)))

{

return true;

}

return false;

}

}

//文章类class Article

{

private int _id;

private string _title;

public Article(int id, string title)

{

_id = id;

_title = title;

}

public void Edit()

{

Console.WriteLine("{0} has been edited!", _title);

}

}

//客户端实现

static void Main(string[] args)

{

Manager manager = new Manager(1, "ycj", Convert.ToInt32(Level.normal));

Article art = new Article(1, "test");

if (manager.CheckPower())

{

art.Edit();

}

else

{

Console.WriteLine("Sorry, your have no RIGHT!");

}

Console.ReadKey();

}

我们在管理员类中实现了CheckPower()方法来判断是否具有相应权限来操作文章,现在假设需求变动, 需要增加一个writer(作者)类,也对作者类进行文章编辑的权限控制,代码如下:

class Writer

{

private int _id;

private string _name;

private int _level;

public Writer(int id, string name, int level)

{

_id = id;

_name = name;

_level = level;

}

public bool CheckPower()

{

if (_level.Equals(Convert.ToInt32(Level.super)))

{

return true;

}

return false;

}}

客户端修改如下:Manager manager = new Manager(1, "ycj", Convert.ToInt32(Level.normal));

Writer writer = new Writer(2, "jlf", Convert.ToInt32(Level.super));

Article art = new Article(1, "test");

if (manager.CheckManagerPower())

{

art.Edit();

}

else

{

Console.WriteLine("Sorry, your have no RIGHT!");

}

if (writer.CheckWriterPower())

{

art.Edit();

}

else

{

Console.WriteLine("Sorry, your have no RIGHT!");

}

发现在客户端实现较为冗长,可以在Art类中进行修改:class Article{

...//一些代码

public void Edit(Manager manager)

{

if (manager.CheckManagerPower())

{

Console.WriteLine("{0} has been edited!", _title);

}

else

{

Console.WriteLine("Sorry, your have no RIGHT!");

}

}

public void Edit(Writer writer)

{

if (writer.CheckWriterPower())

{

Console.WriteLine("{0} has been edited!", _title);

}

else

{

Console.WriteLine("Sorry, your have no RIGHT!");

}

}

}

我们对Article类中的Edit方法进行重载,即可实现同时满足manager和writer的方法 。

问题来了,如果新的需求需要实现一个形如Reader类,也对Article进行可编辑的权限控制呢?是否仍然继续添加对于Reader类的一个Edit的重载?这样是否太繁琐?

经过思考发现, 造成需求复杂的原因是,不断的会有新的实体类加进来,需要实现对于Edit()方法的权限判断,造成了新的实体类和Article类的耦合,因此需要借助一个中间层把新的实体类和Article类进行解耦;而这个中间层就是 接口!

我们可以引入如下接口进行解耦:interface ICheckPower

{

bool CheckPower();

}

对Manager类和Aritle类进行改造:

class Manager : ICheckPower

{

....// 一些代码

public bool CheckPower()

{

if (_level.Equals(Convert.ToInt32(Level.super)))

{

return true;

}

return false;

}

}

class Article

{

...//一些代码

public void Edit(ICheckPower check)

{

if (check.CheckPower())

{

Console.WriteLine("{0} has been edited!", _title);

}

else

{

Console.WriteLine("Sorry, your have no RIGHT!");

}

}}

我们将Manager类继承ICheckPower接口,实现CheckPower()方法,在Article类中,把Edit方法中的参数替换为接口的实现(ICheckPower check),这样就可以实现继承于ICheckPower接口的任何实体类的引用,客户端代码如下:

static void Main(string[] args)

{

Manager manager = new Manager(1, "ycj", Convert.ToInt32(Level.normal));

Article art = new Article(1, "test");

art.Edit(manager);

Console.ReadKey();

}

我们只需要在Edit()方法中载入Manager类即可,因为它继承了ICheckPower接口并且实现了方法CheckPower();

假设新增了一个Writer类:

class Writer : ICheckPower

{

...//一些代码

public bool CheckPower()

{

if (_level.Equals(Convert.ToInt32(Level.super)))

{

return true;

}

return false;

}

}

只需要让Writer类继承ICheckPower即可,Article类本身并不需要做任何修改;

这样就实现了新的实体类和Article类的解耦,双方各自做变化,互不干扰,客户端实现为:

static void Main(string[] args)

{

Manager manager = new Manager(1, "ycj", Convert.ToInt32(Level.normal));

Writer writer = new Writer(2, "jlf", Convert.ToInt32(Level.super));

Article art = new Article(1, "test");

art.Edit(manager);

art.Edit(writer);

Console.ReadKey();

}

简单而优雅 :-)

总结:面向抽象或面向接口,其实就是对于变化的封装,通过引入接口这一个中间层,将两个原本耦合的类进行解耦,使其可以各自独立的变化;

相关文章

  • C#笔记—对于面向接口(抽象)编程的思考

    先模拟如下业务场景: 定义一个manager(管理员)类,一个Article(文章)类,管理员分为普通管理员和超级...

  • 【spring框架】什么是面向抽象(接口)编程

    课程地址:面向抽象(接口)编程的好处就是灵活性 面向抽象(接口)编程的好处就是灵活性 例子:对于一个User的Ja...

  • 类、抽象类、接口和设计模式

    通过研究设计模式,了解了接口编程以及抽象类编程,1,其实面向对象的编程本质是对于类方法的调用,只是利用接口等方式,...

  • Java抽象类与接口

    对于面向对象编程来说,抽象是它的一大特征之一。在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类。接口...

  • 设计模式——工厂模式

    工厂模式类型 1、简单工厂模式2、工厂方法模式3、抽象工厂模式 面向接口编程 面向接口编程1、每个模块负责自己的职...

  • 第十八节:详解Java抽象类和接口的区别

    前言 对于面向对象编程来说,抽象是它的特征之一。 在Java中,实现抽象的机制分两种,一为抽象类,二为接口。抽象类...

  • 设计模式 -- 依赖倒置原则

    表述(面向接口编程) “针对接口编程,不要针对实现编程”就是依赖倒转原则的最好体现:接口(也可以是抽象类)就是一种...

  • 工厂模式实战

    设计模式最重要的是解耦,(面向抽象编程,面向接口编程)简单工厂是产品的工厂,工厂方法是工厂的工厂,抽象工厂是复杂产...

  • Java 中接口和抽象类的 7 大区别!

    Java 是一门面向对象的编程语言,面向对象的编程语言有四大特征:抽象、封装、继承和多态。 而本文介绍的接口和抽象...

  • 深入理解Java的接口和抽象类

    原文链接: 深入理解Java的接口和抽象类 - 海 子 - 博客园 对于面向对象编程来说,抽象是它的一大特征之一。...

网友评论

    本文标题:C#笔记—对于面向接口(抽象)编程的思考

    本文链接:https://www.haomeiwen.com/subject/yejmqttx.html