zoukankan      html  css  js  c++  java
  • 控制反转(IOC原型)

    控制反转(IOC原型)

    今天感觉终于理解了控制反转的意思,感谢秦老师。

    总结一下简单的例子

    为什么需要控制反转?

    在我们之前的业务中,用户的需求可能会影响我们原来的代码,我们需要根据用户的需求去修改源代码!如果程序代码量十分大,修改一次的成本代价十分昂贵!

    我们通过使用一个Set接口实现,使程序发生了革命性的变化!

    之前,程序是主动创建对象!控制权在程序员手上!

    使用了set注入后,程序不再具有主动性,而是变成了被动的接收对象!

    我们通过一个例题来了解为什么说使程序发生了革命性的变化!

    例:

    项目结构:

    UserMapper:

    package com.lenovo.dao;
    
    public interface UserMapper {
        void getUser();
    }
    

    UserMapperImpl:

    package com.lenovo.dao;
    
    public class UserMapperImpl implements UserMapper {
        @Override
        public void getUser() {
            System.out.println("默认获取用户的数据");
        }
    }
    
    

    UserMySQLImpl:

    package com.lenovo.dao;
    
    public class UserMySQLImpl implements UserMapper {
        @Override
        public void getUser() {
            System.out.println("mysql默认获取用户的数据");
        }
    }
    
    

    UserService:

    package com.lenovo.service;
    
    public interface UserService {
        void getUser();
    }
    

    1、未使用控制反转时

    UserServiceImpl:

    package com.lenovo.service;
    
    import com.lenovo.dao.UserMapper;
    import com.lenovo.dao.UserMapperImpl;
    import com.lenovo.dao.UserMySQLImpl;
    
    public class UserServiceImpl implements UserService {
       // private UserMapper userMapper=new UserMapperImpl();
        private UserMapper userMapper=new UserMySQLImpl();
        public void getUser() {
            userMapper.getUser();
        }
    
    }
    

    MyTest(对应用户):

    import com.lenovo.service.UserServiceImpl;
    import org.junit.Test;
    
    public class MyTest {
        @Test
        public void test(){
            UserServiceImpl userService = new UserServiceImpl();
            userService.getUser();
        }
    }
    
    

    2、使用控制反转后

    UserServiceImpl:

    package com.lenovo.service;
    
    import com.lenovo.dao.UserMapper;
    import com.lenovo.dao.UserMapperImpl;
    
    public class UserServiceImpl implements UserService {
        private UserMapper userMapper;
    
        //利set.进行动态实现值的注入!
        public void setUserMapper(UserMapper userMapper) {
           this.userMapper = userMapper;
        }
    
        public void getUser() {
            userMapper.getUser();
        }
    
    }
    

    MyTest(对应用户):

    import com.lenovo.dao.UserMySQLImpl;
    import com.lenovo.service.UserServiceImpl;
    import org.junit.Test;
    
    public class MyTest {
        @Test
        public void test(){
            UserServiceImpl userService = new UserServiceImpl();
            userService.setUserMapper(new UserMySQLImpl());
            userService.getUser();
        }
    }
    
    

    我们都知道service调dao层,原来在UserServiceImpl创建对象,用户的需求是什么,我们需要对此进行更改,现在使用set方法在MyTest创建对象,用户想要什么自己可以自己点击创建使用

    这种思想,从本质上解决了问题,我们程序员不用再去管理对象的创建了。系统的耦合性大大降低,可以更加专注在业务的实现上。这是IOC的原型!

    可参考bi站秦疆老师的视频学习,再次感谢秦疆老师!

  • 相关阅读:
    自动化测试项目实战训练【广州8月】
    RFT基础使用手册
    TestComplete自动化测试实战训练【6月11、12号】
    Jubula Eclipse开源功能测试工具
    网络管理自动化测试应用
    IBM RFT自动化测试实战课程
    GUI自动化测试原理剖析—JAVA测试篇
    简易自动化测试设计之(一) 基于RFT的自动化测试层次
    录制,到底给我们带来了什么?
    IBM Rational Functional Tester(RFT) 自动化测试框架ITCL
  • 原文地址:https://www.cnblogs.com/zhuchengbo/p/12295808.html
Copyright © 2011-2022 走看看