依赖倒置原则 个人理解

依赖倒置原则核心:

上层模块不应该依赖底层模块,它们都应该依赖于抽象。

抽象不应该依赖于细节,细节应该依赖于抽象。

 

OR
高层模块不应该依赖低层模块,二者都应该依赖其抽象;抽象不应该依赖细节;细节应该依赖抽象。

 

 

上层模块是我们要做什么,下层模块是怎么做

例如:Eat里面我们要吃什么就是所谓的上层 而面包类,包子类 就是下层模块,

 

例如我要实现一个吃面包过程

里面包含三个部分,一个是吃的什么,一个是开始吃的命令,还有一个是输出吃.

 public class Bread {
           public void Being_eaten()
            {
                Console.WriteLine("我是面包我被吃了");
            }
            
        }

        public class Eat {
            public void eat(Bread bread) {
                bread.Being_eaten();
            }

        }

        static void Main(string[] args)
        {
            //实例化面包
            Bread bread = new Bread();
            //实例化吃的方法
            Eat eat = new Eat();

            //开始吃
            eat.eat(bread);
            Console.ReadLine();
        }

 

ok上面是一个很完整的吃面包过程,那么这个时候,我不仅仅是想吃面包了,我还想吃包子怎么办?

 

        public class Bread {
           public void Being_eaten()
            {
                Console.WriteLine("我是面包我被吃了");
            }
            
        }
        public class Bun
        {
            public void Being_eaten()
            {
                Console.WriteLine("我是包子!!我被吃了");
            }

        }
        public enum Food
        {
            Bread, Bun
        }
        public class Eat {
            public void eat(Food _food) {
                if (_food == (Food)0)
                {
                    Bread bread = new Bread();
                    bread.Being_eaten();
                } else if (_food==(Food)1)
                {
                    Bun bun = new Bun();
                    bun.Being_eaten();
                }
            }

        }

        static void Main(string[] args)
        {
            //实例化面包
        //    Bread bread = new Bread();
            //实例化吃的方法
            Eat eat = new Eat();
            //开始吃
            eat.eat((Food)1);
            Console.ReadLine();
        }

 

看着用很轻松的解决了吃包子跟面包的问题,但是我们明显发现了Eat这个类因为要吃的东西变多所以做了很明显的改变,那我们现在吃包子跟面包,那如果我要吃满汉全席,是不是得写108个 else if??

所以我们需要依赖倒置的写法,这种方法不会破坏Eat这个动作.

 

 

你要怎么办?

 

   public interface IFood
        {
            void Being_eaten();
        }  

        public class Bread: IFood
        {
           public void Being_eaten()
            {
                Console.WriteLine("我是面包我被吃了");
            }
            
        }
        public class Bun: IFood
        {
            public void Being_eaten()
            {
                Console.WriteLine("我是包子!!我被吃了");
            }

        }

        public class Eat {
            public void eat(IFood Food) {
                Food.Being_eaten();
            }

        }

        static void Main(string[] args)
        {
            //实例化面包
            Bread bread = new Bread();
            //实例化吃包子方法
            Bun bun = new Bun();
            //实例化吃的方法
            Eat eat = new Eat();
            //开始吃
            eat.eat(bread);
            Console.ReadLine();
        }

通过上面的代码我们发现,吃什么已经不在是Eat这个类所需要考虑的事情了,外部无论有多少类要吃东西,对我们的Eat类都没有影响,这样我们程序在开发过程中才可以健壮.

 

转载于:https://www.cnblogs.com/zcl-cnblogs/p/9700895.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值