纯手写springIOC
大家好啊~ 那么今天来带大家写一下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的更多相关文章
- springmvc 动态代理 JDK实现与模拟JDK纯手写实现。
首先明白 动态代理和静态代理的区别: 静态代理:①持有被代理类的引用 ② 代理类一开始就被加载到内存中了(非常重要) 动态代理:JDK中的动态代理中的代理类是动态生成的.并且生成的动态代理类为$Pr ...
- 简易-五星评分-jQuery纯手写
超级简单的评分功能,分为四个步骤轻松搞定: 第一步: 引入jquery文件:这里我用百度CDN的jquery: <script src="http://apps.bdimg.com/l ...
- vue10行代码实现上拉翻页加载更多数据,纯手写js实现下拉刷新上拉翻页不引用任何第三方插件
vue10行代码实现上拉翻页加载更多数据,纯手写js实现下拉刷新上拉翻页不引用任何第三方插件/库 一提到移动端的下拉刷新上拉翻页,你可能就会想到iScroll插件,没错iScroll是一个高性能,资源 ...
- 超级简单的jQuery纯手写五星评分效果
超级简单的评分功能,分为四个步骤轻松搞定: 第一步: 引入jquery文件:这里我用百度CDN的jquery: <script src="http://apps.bdimg.com/l ...
- 纯手写Myatis框架
1.接口层-和数据库交互的方式 MyBatis和数据库的交互有两种方式: 使用传统的MyBatis提供的API: 使用Mapper接口: 2.使用Mapper接口 MyBatis 将配置文件中的每一个 ...
- 《四 spring源码》手写springioc框架
手写SpringIOCXML版本 /** * 手写Spring专题 XML方式注入bean * * * */ public class ClassPathXmlApplicationContext { ...
- SQL纯手写创建数据库到表内内容
建表啥的只点点鼠标,太外行了,不如来看看我的纯手写,让表从无到有一系列:还有存储过程临时表,不间断的重排序: 一:建数据库 create Database Show on primary ( name ...
- 框架源码系列二:手写Spring-IOC和Spring-DI(IOC分析、IOC设计实现、DI分析、DI实现)
一.IOC分析 1. IOC是什么? IOC:Inversion of Control控制反转,也称依赖倒置(反转) 问题:如何理解控制反转? 反转:依赖对象的获得被反转了.由自己创建,反转为从IOC ...
- 纯手写SpringMVC到SpringBoot框架项目实战
引言 Spring Boot其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置. 通过这种方式,springboot ...
随机推荐
- 在javaScript中检测数据类型的几种方式
类型检测的方法 typeof instanceof Object.protype.toString constructor duck type:鸭子类型 typeof 返回一个字符串,适合函数对象和基 ...
- 深入学习MySQL事务:ACID特性的实现原理
事务是MySQL等关系型数据库区别于NoSQL的重要方面,是保证数据一致性的重要手段.本文将首先介绍MySQL事务相关的基础概念,然后介绍事务的ACID特性,并分析其实现原理. MySQL博大精深,文 ...
- 讲解:为什么重写equals时必须重写hashCode方法
一 :string类型的==和equals的区别: 结论:"=="是判断两个字符串的内存地址是否相等,equals是比较两个字符串的值是否相等,具体就不做扩展了,有兴趣的同学可以去 ...
- PBFT概念与Go语言入门(Tendermint基础)
Tendermint作为当前最知名且实用的PBFT框架,网上资料并不很多,而实现Tendermint和以太坊的Go语言,由于相对小众,也存在资料匮乏和模糊错漏的问题.本文简单介绍PBFT概念和Go语言 ...
- Dotnet全平台下APM-Trace探索
背景 随着支撑的内部业务系统越来越多,向着服务化架构进化,在整个迭代过程中,会逐渐暴露出以下问题. 传统依赖于应用服务器日志等手段的排除故障原因的复杂度越来越高,传统的监控服务已经无法满足需求. 终端 ...
- 关于php-fpm比较重要的几个参数
pm.max_children 设置多大合适? php-fpm.conf有两个至关重要的参数: 一个是”max_children”,另一个是”request_terminate_timeout”. p ...
- Android之日志管理(Log)
##文章大纲一.为什么要使用日志管理工具二.日志管理工具实战三.项目源码下载 ##一.为什么要使用日志管理工具###1. 对IT安全至关重要 当您使用强大的日志管理软件自动触发以保护您的系统时,您已 ...
- Windows Server 安装后无法使用无线与音频
1.无线 运行powershell,输入命令: install-windowsfeature Wireless-Networking 之后重启. 运行cmd输入: sc config WlanSvc ...
- Storm入门(十一)Twitter Storm源代码分析之CoordinatedBolt
作者: xumingming | 可以转载, 但必须以超链接形式标明文章原始出处和作者信息及版权声明网址: http://xumingming.sinaapp.com/811/twitter-stor ...
- Dapeng框架-开源高性能分布式微服务框架
我们公司性质是新零售,公司也有专门的框架组.这群大牛自己开发了一整套分布式微服务框架.我们也在使用这套框架,有很多心得体会. 该框架既Dapeng也!开源github地址:https://github ...