spring基础学习01
spring基础
Spring是一个开放源代码的设计层面框架,他解决的是业务逻辑层和其他各层的松耦合问题,因此它将面向接口的编程思想贯穿整个系统应用
IOC控制反转
把创建对象和维护对象之间的关系权利转交给spring管理,spring容器控制对象的创建,注入需要注入的对象
aop面向切面编程
通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术
隔离业务逻辑,降低耦合度,提高可用性和开发效率,主要用于日志记录,事务管理,异常处理等等
模块化
3.0版本后,根据需要引入模块需要的包,进行模块开发

小demo
测试配置文件
创建对象
@Data
public class Person {
private String name;
}
创建配置文件,为了方便测试放在同级目录下
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="person" class="top.mjsmry.demo01.Person" name="person">
</bean>
</beans>
创建测试方法
public class SpringDemoTest {
@Test
public void tes01() {
//实例化管理对象
ClassPathResource resource = new ClassPathResource("/top/mjsmry/demo01/spring-config.xml");
XmlBeanFactory factory = new XmlBeanFactory(resource);
//1根据id创建
Person u = (Person) factory.getBean("person");
u.setName("lili");
System.out.println(u);
}
}
三种获取实例化的方式,上面已经写了一种
//2根据name和class
Person person = factory.getBean("person2", Person.class);
person.setName("lili");
//3直接根据字节码 但是配置文件必须唯一,一个对象配置多个bean的话,spring会无法选择
Person bean = factory.getBean(Person.class);
System.out.println(person);
Application和BeanFactory
- 创建对象的时机是
- ApplicationContext在创建工厂的时候就会把bean实例化,优先加载
- BeanFactory使用对象时才会实例化
- 关系
- ApplicationContext实现BeanFactory
- ApplicationContext更强大
- ApplicationContext实现懒加载
- 全局:default-lazy-init="true"
单独节点: lazy-init="true"
spring测试
spring测试可以在不启动spring项目情况下进行单元测试
@ContextConfiguration("spring-config.xml")
@RunWith(SpringJUnit4ClassRunner.class)
public class SpringTest {
@Autowired
Person person;
@Test
public void test() {
person.setName("lili");
System.out.println(person);
}
}
singletonAndprototype
<bean id="person" class="top.mjsmry.singletonAndprototype.Person" scope="prototype"/>
scope prototype多例 singleton单例
public class SpringTest {
@Test
public void test() {
ApplicationContext ac=new ClassPathXmlApplicationContext("top/mjsmry/singletonAndprototype/spring-config.xml");
Person person1= (Person) ac.getBean("person");
Person person2= (Person) ac.getBean("person");
//单例的话就是同一个对象
System.out.println(person1==person2);//true
}
}
bean与bean之间的关系
继承
- 通过parent指定继承
- 有abstract属性的bean不能被实例化
子bean可以覆盖父bean
依赖
- 可以通过depends-on="其他beani定依赖关系
- 如果依赖了abstract的bean也不能实例化
<!-- 模板bean -->
<bean id="p" class="top.mjsmry.beanAndBean.Person" abstract="true">
<property name="name" value="张三"></property>
</bean>
<bean id="person" class="top.mjsmry.beanAndBean.Person" parent="p"/>
<bean id="person2" class="top.mjsmry.beanAndBean.Person" parent="p">
<property name="name" value="子覆盖了"></property>
</bean>
@Test
public void test() {
ApplicationContext ac=new ClassPathXmlApplicationContext("top/mjsmry/beanAndBean/spring-config.xml");
Person person= (Person) ac.getBean("person");
System.out.println(person);
Person person2= (Person) ac.getBean("person2");
System.out.println(person2);
}
生命周期
基本声明周期
<!-- 生命周期
构造方法
getset
init-method 初始化
destroy-method 销毁
-->
<bean id="person" class="top.mjsmry.beancycle.Person" init-method="init" destroy-method="destory"/>
bean
@Data
public class Person {
private String name;
public Person() {
System.out.println("构造方法调用了");
}
private void init() {
System.out.println("--init--");
}
private void destory() {
System.out.println("--destory--");
}
}
补充周期
<!--
实现BeanPostProcessor 细致的声明周期
postProcessBeforeInitialization 初始化方法之前
postProcessAfterInitialization 初始化方法之后
-->
<bean id="personBeanPostProcessor" class="top.mjsmry.beancycle.PersonBeanPostProcessor"/>
实现接口
public class PersonBeanPostProcessor implements BeanPostProcessor {
@Override
public Object postProcessBeforeInitialization(Object o, String s) throws BeansException {
System.out.println("postProcessBeforeInitialization");
return o;
}
@Override
public Object postProcessAfterInitialization(Object o, String s) throws BeansException {
System.out.println("postProcessAfterInitialization");
return o;
}
}
测试
@Test
public void test() {
ClassPathXmlApplicationContext ca=new ClassPathXmlApplicationContext("top/mjsmry/beancycle/spring-config.xml");
Person person= (Person) ca.getBean("person");
ca.close();
}
注入测试
spring原生注入方式实现三层架构
dao
public class TestDao {
public int add() {
return 1;
}
}
service
public interface TestService {
String add();
}
@Data
public class TestServiceImpl implements TestService {
private TestDao testDao;
@Override
public String add() {
return testDao.add()==1?"添加成功":"添加失败";
}
}
controller
@Data
public class TestController {
private TestService testService;
public String add() {
return testService.add();
}
}
配置文件
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<!-- set注入 -->
<bean id="testController" class="top.mjsmry._01.controller.TestController">
<property name="testService" ref="testService"/>
</bean>
<bean id="testService" class="top.mjsmry._01.service.impl.TestServiceImpl">
<property name="testDao" ref="testDao"/>
</bean>
<bean id="testDao" class="top.mjsmry._01.dao.TestDao"></bean>
</beans>
test
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("/spring-config.xml")
public class MyTest {
@Autowired
private TestController testController;
@Test
public void test01() {
String result = testController.add();
System.out.println(result);
}
}
测试结果

注入BasicDataSource
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-4.2.xsd
">
<context:property-placeholder location="classpath:db.properties"/>
<!-- 配置一个DBCP的Bean -->
<bean name="dateSource" class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close">
<!-- 注意:这里我们不是使用的ref引用,而是直接写的value,因此注入的数据是一个变通的值 -->
<property name="driverClassName" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</bean>
</beans>
db.properties
jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/jdbcwork?useSSL=false&serverTimezone=UTC
jdbc.username=xxx
jdbc.password=xxx
测试
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("spring-config.xml")
public class DataSourceTest {
@Autowired
BasicDataSource basicDataSource;
@Test
public void test01() {
try {
Connection connection = basicDataSource.getConnection();
connection.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
无报错测试通过
其他注入
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Person {
private String username;
private Car car;
private String[] strings;
private List<String> list;
private Set<String> set;
private List<Wife> wifeList;
private Properties p1;
private Properties p2;
}
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:util="http://www.springframework.org/schema/util"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util.xsd">
<!-- 外部bean注入 -->
<bean id="car" class="top.mjsmry._05other.Car">
<property name="price" value="1.0"/>
<property name="type" value="bwm"/>
</bean>
<bean id="person" class="top.mjsmry._05other.Person">
<property name="username" value="张三"/>
<property name="car" ref="car"/>
</bean>
<!-- 内部bean定义 -->
<bean id="person2" class="top.mjsmry._05other.Person">
<property name="username" value="张三"/>
<property name="car">
<bean class="top.mjsmry._05other.Car">
<property name="price" value="1.0"/>
<property name="type" value="bwm"/>
</bean>
</property>
</bean>
<!-- 其他类型的注入 -->
<bean id="person3" class="top.mjsmry._05other.Person">
<property name="username" value="张三"/>
<property name="car">
<bean class="top.mjsmry._05other.Car">
<property name="price" value="1.0"/>
<property name="type" value="bwm"/>
</bean>
</property>
<!-- 数组 -->
<property name="strings" value="lili,keke"/>
<!-- 集合 -->
<property name="list">
<list>
<value>1</value>
<value>2</value>
<value>3</value>
</list>
</property>
<!-- set -->
<property name="set">
<set>
<value>k</value>
<value>e</value>
<value>w</value>
</set>
</property>
<!-- 泛型 -->
<property name="wifeList">
<list>
<bean class="top.mjsmry._05other.Wife">
<property name="username" value="lili"/>
</bean>
</list>
</property>
<!-- Properties注入-->
<property name="p1">
<value>proKey1=proValue1</value>
</property>
<property name="p2">
<props>
<prop key="键1">值1</prop>
</props>
</property>
</bean>
</beans>
测试
public class OtherTest {
@Test
public void test01() {
ApplicationContext ac=new ClassPathXmlApplicationContext("/top/mjsmry/_05other/spring-config.xml");
Person person= (Person) ac.getBean("person");
Person person2= (Person) ac.getBean("person2");
Person person3= (Person) ac.getBean("person3");
System.out.println(person);
System.out.println(person2);
System.out.println(person3);
}
}
关注我的个人博客林中小屋
更多内容关注我的个人博客林中小屋
spring基础学习01的更多相关文章
- spring基础学习
ClassXmlAplicationContext和FileSystemXmlApplicationContext的区别 https://www.cnblogs.com/sxdcgaq808 ...
- Spring基础学习(四)—AOP
一.AOP基础 1.基本需求 需求: 日志功能,在程序执行期间记录发生的活动. ArithmeticCalculate.java public interface ArithmeticCal ...
- Spring基础学习(一)—初识Spring
一.Spring的使用 1.导入jar包 2.编写实体类 Person.java public class Person{ private String name; public void say() ...
- Spring基础学习,附例子代码讲解
什么是Spring.IOC.AOP.DI? Spring是一个基于IOC和AOP的结构J2EE系统的框架. IOC(Inversion Of Control)控制反转(Spring的基 ...
- Spring框架学习01——使用IDEA开发Spring程序
1.创建项目 点击“Create New Project”,新建项目 选择Maven项目 项目配置 使用本地安装的Maven 一直点击Next,最后点击完成当控制台中出现“BUILD SUCCESS” ...
- 使用JavaConfig方式-Spring 基础学习
在Spring的使用中,大量采用xml方式配置类之间的关系太过于繁琐(个人这么认为),而在学习了Spring4后发下使用JavaConfig方式来配置这些关系会更加的简单明了. 测试环境 1. Apa ...
- spring boot学习01【搭建环境、创建第一个spring boot项目】
1.给eclipse安装spring boot插件 Eclipse中安装Spring工具套件(STS): Help -> Eclipse Marketplace... 在Search标签或者Po ...
- Spring基础学习笔记
1. Spring入门 1. 1 Spring的体系结构 1.2 HelloWorld 1.2.1 Maven的使用 1)maven 的javase工程目录结构: 2)maven的settings.x ...
- T-SQL 基础学习 01
--新建数据库 create database Studentdb go --使用数据库 use Studentdb go --新建表 create table Username ( StudentN ...
随机推荐
- 面试中常用的六种排序算法及其Java实现
常见排序算法的时间复杂度以及稳定性: 1 public class Sort { public static void main(String[] args){ int[] nums=new int[ ...
- jvm系列(七):如何优化Java GC「译」
本文由CrowHawk翻译,地址:如何优化Java GC「译」,是Java GC调优的经典佳作. Sangmin Lee发表在Cubrid上的”Become a Java GC Expert”系列文章 ...
- HDU 6242
题意略. 思路:这个题的思路非常诡异.由于题目保证存在这样一个圆,那么每个点在这个圆上的概率是1/2,我任选3个点,这3个点都在这个圆上的概率是1 / 8. 不都在这个圆上的概率是7 / 8,在这样选 ...
- 使用Eclipse开发动态Javaweb项目
使用Eclipse开发动态Javaweb项目 一.Eclipse的使用 1. 把开发选项切换到 JavaEE 2. 可以在 Window -> Show View 中找到 Package Exp ...
- MSIL实用指南-this的生成
C#关键字是非静态方法体内部,用Ldarg_0指代this例子ilGenerator.Emit(OpCodes.Ldarg_0);
- Anaconda的详细安装步骤图文并茂
Anaconda(官方网站)就是可以便捷获取包且对包能够进行管理,同时对环境可以统一管理的发行版本.Anaconda包含了conda.Python在内的超过180个科学包及其依赖项. 事实上Anaco ...
- bzoj 2001 CITY 城市建设 cdq分治
题目传送门 题解: 对整个修改的区间进行分治.对于当前修改区间来说,我们对整幅图中将要修改的边权都先改成-inf,跑一遍最小生成树,然后对于一条树边并且他的权值不为-inf,那么这条边一定就是树边了. ...
- codeforces 814 C. An impassioned circulation of affection(二分+思维)
题目链接:http://codeforces.com/contest/814/problem/C 题意:给出一串字符串然后q个询问,问替换掉将m个字符替换为字符c,能得到的最长的连续的字符c是多长 题 ...
- hdu 3265 Posters(线段树+扫描线+面积并)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3265 题意:给你一张挖了洞的墙纸贴在墙上,问你总面积有多少. 挖了洞后其实就是多了几个矩形墙纸,一张墙 ...
- vim 同时操作多行
使用 vim 的时候,经常会有同时注释或解开注释的情况,逐行编辑很浪费时间,下面的同时操作多行的方式 删除操作 control+v 进入 visual block 模式 选中要删除几行文字 d删除 插 ...