大家好啊~ 那么今天来带大家写一下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. 记一次重大生产事故,在那 0.1s 我想辞职不干了!

    一.发生了什么? 1.那是一个阳光明媚的下午,老婆和她的闺蜜正在美丽的湖边公园闲逛(我是拎包拍照的). 2.突然接到甲方运营小妹的微信:有个顾客线上付款了,但是没有到账,后台卡在微信支付成功(正常状态 ...

  2. 【STM32H7教程】第4章 STM32H7工程模板建立(MDK5)

    完整教程下载地址:http://forum.armfly.com/forum.php?mod=viewthread&tid=86980 第4章   STM32H7工程模板建立(MDK5) 本章 ...

  3. Redis--Memched--Cache缓存介绍使用

    目录:  一.分布式缓存—Redis与Memched的区别 1.1.      数据支持类型 1.2.      持久性 1.3.      内存利用情况 1.4.      数据一致性 1.5.   ...

  4. asp.net core系列 56 IS4使用OpenID Connect添加用户认证

    一.概述 在前二篇中讲到了客户端授权的二种方式: GrantTypes.ClientCredentials凭据授权和GrantTypes.ResourceOwnerPassword密码授权,都是OAu ...

  5. 【极简版】SpringBoot+SpringData JPA 管理系统

    前言 只有光头才能变强. 文本已收录至我的GitHub仓库,欢迎Star:https://github.com/ZhongFuCheng3y/3y 在上一篇中已经讲解了如何从零搭建一个SpringBo ...

  6. 【干货分享】可能是东半球最全的.NET Core跨平台微服务学习资源

    如果你发现还有西半球的资源,烦请相告,不胜感谢! 一..NET Core基础 微软英文官网 .NET Core 微软中文官网 GitHub 用ASP.NET内核和Azure构建现代Web应用程序 博客 ...

  7. Java对字符串加密并返回星号※

     If you don't look back, you'll never know I waiting for you behind you. Java对字符串加密并返回星号※ PasswordUt ...

  8. headfirst设计模式(9)—模板方法模式

    前言 这一章的模板方法模式,个人感觉它是一个简单,并且实用的设计模式,先说说它的定义: 模板方法模式定义了一个算法的步骤,并允许子类别为一个或多个步骤提供其实践方式.让子类别在不改变算法架构的情况下, ...

  9. 史上最详尽的NLP预处理模型汇总

    文章发布于公号[数智物语] (ID:decision_engine),关注公号不错过每一篇干货. 转自 | 磐创AI(公众号ID:xunixs) 作者 | AI小昕 编者按:近年来,自然语言处理(NL ...

  10. python3.6+selenium3.13 自动化测试项目实战一(增加自动发送邮件报告接口)

    说明: 继实战项目一的基础上添加自动发送报告邮件接口,代码有部分调整,可以结合实战一和上篇文章学习 变动: 1.增加文本文档SendToUserinfo.txt 用来保存邮件接收者的信息 2.修改测试 ...