大家好啊~ 那么今天来带大家写一下spring的ioc。

其实也很简单,首先我们明白两点,java解析xml和java的反射机制,因为ioc就是主要是基于这两个来实现,今天只是简单的来大家实现下。

废话不多说直接上代码。

1.首先加入maven依赖我们这里用到的xml解析是dem4j,先看下项目结构吧。

2.导入maven依赖

 <?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <groupId>com.gd</groupId>
<artifactId>mySpringIOC</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>jar</packaging> <dependencies>
<dependency>
<groupId>dom4j</groupId>
<artifactId>dom4j</artifactId>
<version>1.6.1</version>
</dependency>
</dependencies>
</project>

3.首先我们来看MyApplicationContext这个接口

package org.zgw.framework.spring.ioc;

/**
* @DATA 2018-12-30 23:05
* @Author zhangguowei WeChat:17630376104
* @Description TODO
*/
public interface MyApplicationContext {
Object getBean(String beanId); Object getBean(Class clazz);
}

  这个接口中有个两个getbBean();重栽的方法。这两个接口也就是ioc的id大家用过spring 的应该都知道,这里不过多的解释。

4.接着看我们的MyClassPathXmlApplicationContext这个实现类。

package org.zgw.framework.spring.ioc;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.zgw.framework.spring.ioc.model.BeanDefinition;
import org.zgw.framework.spring.ioc.model.PropertyDefinition; import java.io.InputStream;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import java.util.Map; /**
* @DATA 2018-12-30 23:07
* @Author zhangguowei WeChat:17630376104
* @Description TODO
*/
public class MyClassPathXmlApplicationContext implements MyApplicationContext { private Map<String, BeanDefinition> stringBeanDefinitionMap = new HashMap<String, BeanDefinition>(); public MyClassPathXmlApplicationContext(String xmlName) {
loadXml(xmlName);
} private void loadXml(String xmlName) {
SAXReader reader = new SAXReader();
//读取xml
InputStream inputStream = Thread.currentThread().getContextClassLoader().getResourceAsStream(xmlName);
try {
Document document = reader.read(inputStream);
// 获取标签
Element element = document.getRootElement();
System.out.println("根节点:" + element.getName());
List<Element> elementList = element.elements();
for (Element beanlist : elementList) {
System.out.println("子节点:" + beanlist.getName() + "\t" + beanlist.attributeValue("id") + "\t" + beanlist.attributeValue("class")); BeanDefinition beanDefinition = new BeanDefinition();
//读取name的值
beanDefinition.setName(beanlist.attributeValue("name"));
//读取class的值
beanDefinition.setClassStr(beanlist.attributeValue("class")); List<Element> proList = beanlist.elements();
for (Element element1 : proList) {
System.out.println(element1.getName() + "\t" + element1.attributeValue("name") + "\t" + element1.getText());
PropertyDefinition propertyDefinition = new PropertyDefinition();
propertyDefinition.setName(element1.attributeValue("name"));
propertyDefinition.setValue(element1.attributeValue("value"));
beanDefinition.getPropertyDefinitionMap().put(propertyDefinition.getName(), propertyDefinition); }
stringBeanDefinitionMap.put(beanDefinition.getName(), beanDefinition);
} } catch (DocumentException e) {
e.printStackTrace();
} } public Object getBean(String beanId) {
BeanDefinition beanDefinition = stringBeanDefinitionMap.get(beanId);
String clazzStr = beanDefinition.getClassStr();
Object beanobj = null;
try {
Class clazz = Class.forName(clazzStr);
beanobj = clazz.newInstance();
// 给属性赋值
Collection<PropertyDefinition> propertyDefinitions = beanDefinition.getPropertyDefinitionMap().values();
for (PropertyDefinition propertyDefinition : propertyDefinitions) {
String setterMethodStr = propertyDefinition.getName();
//因为spring读的是他个set方法,一般set方法都为大写开头所以这里进行转换
String firstChar = setterMethodStr.substring(0, 1).toUpperCase();
setterMethodStr = "set" + firstChar + setterMethodStr.substring(1);
System.out.println("-------- 拼接出来的set方法" + setterMethodStr);
Method setMathod= clazz.getMethod(setterMethodStr,String.class);
setMathod.invoke(beanobj,propertyDefinition.getValue()); }
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InstantiationException e) {
e.printStackTrace();
} catch (NoSuchMethodException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
} return beanobj;
} public Object getBean(Class clazz) {
return null;
}
}

  基本的注释我都写有,这些大家应该能看的懂。

5.还有一点就是两个实体的类,因为她们得对应spring的属性

package org.zgw.framework.spring.ioc.model;

import java.util.HashMap;
import java.util.Map; /**
* @DATA 2018-12-30 23:15
* @Author zhangguowei WeChat:17630376104
* @Description TODO
*/
public class BeanDefinition {
private String name; private String classStr; private Map<String, PropertyDefinition> propertyDefinitionMap = new HashMap<String, PropertyDefinition>(); public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getClassStr() {
return classStr;
} public void setClassStr(String classStr) {
this.classStr = classStr;
} public Map<String, PropertyDefinition> getPropertyDefinitionMap() {
return propertyDefinitionMap;
} public void setPropertyDefinitionMap(Map<String, PropertyDefinition> propertyDefinitionMap) {
this.propertyDefinitionMap = propertyDefinitionMap;
}
}

  

package org.zgw.framework.spring.ioc.model;

/**
* @DATA 2018-12-30 23:17
* @Author zhangguowei WeChat:17630376104
* @Description TODO
*/
public class PropertyDefinition
{
private String name;
private String value; public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getValue() {
return value;
} public void setValue(String value) {
this.value = value;
}
}

  这个只是基于xml的ioc,直接上代码,可以拷贝走尝试下,方便大家理解。后续还有ioc的注解方式实现。

纯手写springIOC的更多相关文章

  1. springmvc 动态代理 JDK实现与模拟JDK纯手写实现。

    首先明白 动态代理和静态代理的区别: 静态代理:①持有被代理类的引用  ② 代理类一开始就被加载到内存中了(非常重要) 动态代理:JDK中的动态代理中的代理类是动态生成的.并且生成的动态代理类为$Pr ...

  2. 简易-五星评分-jQuery纯手写

    超级简单的评分功能,分为四个步骤轻松搞定: 第一步: 引入jquery文件:这里我用百度CDN的jquery: <script src="http://apps.bdimg.com/l ...

  3. vue10行代码实现上拉翻页加载更多数据,纯手写js实现下拉刷新上拉翻页不引用任何第三方插件

    vue10行代码实现上拉翻页加载更多数据,纯手写js实现下拉刷新上拉翻页不引用任何第三方插件/库 一提到移动端的下拉刷新上拉翻页,你可能就会想到iScroll插件,没错iScroll是一个高性能,资源 ...

  4. 超级简单的jQuery纯手写五星评分效果

    超级简单的评分功能,分为四个步骤轻松搞定: 第一步: 引入jquery文件:这里我用百度CDN的jquery: <script src="http://apps.bdimg.com/l ...

  5. 纯手写Myatis框架

    1.接口层-和数据库交互的方式 MyBatis和数据库的交互有两种方式: 使用传统的MyBatis提供的API: 使用Mapper接口: 2.使用Mapper接口 MyBatis 将配置文件中的每一个 ...

  6. 《四 spring源码》手写springioc框架

    手写SpringIOCXML版本 /** * 手写Spring专题 XML方式注入bean * * * */ public class ClassPathXmlApplicationContext { ...

  7. SQL纯手写创建数据库到表内内容

    建表啥的只点点鼠标,太外行了,不如来看看我的纯手写,让表从无到有一系列:还有存储过程临时表,不间断的重排序: 一:建数据库 create Database Show on primary ( name ...

  8. 框架源码系列二:手写Spring-IOC和Spring-DI(IOC分析、IOC设计实现、DI分析、DI实现)

    一.IOC分析 1. IOC是什么? IOC:Inversion of Control控制反转,也称依赖倒置(反转) 问题:如何理解控制反转? 反转:依赖对象的获得被反转了.由自己创建,反转为从IOC ...

  9. 纯手写SpringMVC到SpringBoot框架项目实战

    引言 Spring Boot其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置. 通过这种方式,springboot ...

随机推荐

  1. Spring Boot 2.0 图文教程 | 集成邮件发送功能

    文章首发自个人微信公众号: 小哈学Java 个人网站: https://www.exception.site/springboot/spring-boots-send-mail 大家好,后续会间断地奉 ...

  2. WebView,我已经长大了,知道自己区分是否安全了!

    一.前言 如果你在用 Android 原生系统(Google Play 服务),在使用 WebView 加载某些网页时,一定遇到过以下的安全警告红屏. 这是 WebView 的安全浏览保护策略,在 A ...

  3. 一个Java程序猿眼中的前后端分离以及Vue.js入门

    松哥的书里边,其实有涉及到 Vue,但是并没有详细说过,原因很简单,Vue 的资料都是中文的,把 Vue.js 官网的资料从头到尾浏览一遍该懂的基本就懂了,个人感觉这个是最好的 Vue.js 学习资料 ...

  4. DevOps实践之一:基于Docker构建企业Jenkins CI平台

    基于Docker构建企业Jenkins CI平台 一.什么是CI 持续集成(Continuous integration)是一种软件开发实践,每次集成都通过自动化的构建(包括编译,发布,自动化测试)来 ...

  5. 简单工厂模式(Simple Factory Pattern)

    简单工厂模式概述 定义:定义一个工厂类,他可以根据参数的不同返回不同类的实例,被创建的实例通常都具有共同的父类 在简单工厂模式中用于被创建实例的方法通常为静态(static)方法,因此简单工厂模式又被 ...

  6. Android Glide详细使用教程

    此处我只是做个记录,后边再补充 原文地址:http://www.jufanshare.com/content/35.html 这篇文章写的比较清楚,还附有Demo代码.算是不错的Android Gli ...

  7. Git - git branch - 查看远端所有分支

    索引: 目录索引 一.示例: git branch -r 二.说明: 该命令将列出仓库中所有存在的远端分支,无论该分支是否已签出到本地. 蒙 2018-09-29 19:59 周六

  8. 1. [mmc subsystem] 概念与框架

    一.概念 1.mmc的概念 mmc有很多种意义,具体如下: mmc MultiMedia Card,多媒体存储卡, 但后续泛指一个接口协定(一种卡式),能符合这接口的内存器都可称作mmc储存体. 主要 ...

  9. c/c++ open函数的阻塞和非阻塞

    调用open函数时,可以指定是以阻塞方式还是以非阻塞方式打开一个文件描述符. 阻塞方式打开: int fd = open("/dev/tty", O_RDWR|O_NONBLOCK ...

  10. docker 发布到私有docker registry

    1.使用vs发布项目到文件夹: 2.在文件夹中新建dockerfile文件, 内容: FROM mcr.microsoft.com/dotnet/core/aspnet:2.2-stretch-sli ...