spring入门程序:

1、导入Spring的4个基础包以及commons-logging的JAR包复制到lib目录中

2、src->com.itheima.ioc包下:

①UserDao.java

 package com.itheima.ioc;

 public interface UserDao { // 创建接口UserDao
public void say(); // 只声明say()方法,不能定义
}

②UserDaoImpl.java

 package com.itheima.ioc;

 public class UserDaoImpl implements UserDao{ // 创建接口UserDao的实现类UserDaoImpl
public void say() {  // 需要定义接口中的say()方法
System.out.println("userDao say hello World !");
}
}

③控制反转测试类:TestIoC.java

 package com.itheima.ioc;

 import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; public class TestIoC {
public static void main(String[] args) {
// 1、初始化Spring容器,加载配置文件
String xmlPath = "beans.xml";
ApplicationContext applicationContext = new ClassPathXmlApplicationContext(xmlPath); // 2、通过容器获取userDao的Bean实例userDaoID
UserDao userDao = (UserDao) applicationContext.getBean("userDaoID"); // 3、调用实例中的say()方法
userDao.say(); //不需要自己new,都是从Spring容器直接获得
// 之前的实现:new 接口的实例
//UserDao userDao = new UserDaoImpl();
//userDao.say();
}
}

④UserService.java

 package com.itheima.ioc;

 public interface UserService { // 创建接口UserService
public void save(); // 只声明save()方法,不能定义
}

⑤UserServiceImpl.java

 package com.itheima.ioc;

 public class UserServiceImpl implements UserService{ // 创建接口UserService的实现类UserServiceImpl
// 之前的做法:方式1:接口 接口对象= new 实现类(),即
//private UserDao userDao = new UserDaoImpl();
//有了Spring之后(解耦:UserServiceImpl实现类使用了成员变量UserDao接口,不用知道接口具体的实现类),
// 方式2:接口+setter方法
// 1)、声明属性UserDao,(依赖的接口对象)
private UserDao userDao; // 2)、添加UserDao属性的setter方法,Spring才能将创建的接口对象userDao赋值给调用者的成员变量userDao(接口实例对象)!!!
public void setUserDao(UserDao userDao) {
this.userDao = userDao;
} // 3、实现接口中的方法,需要重新定义
public void save() {
// 调用成员变量userDao中的say()方法,并执行输出语句
this.userDao.say();
System.out.println("userService add a user!");
}
}

⑥依赖注入测试类:TestDI.java

 package com.itheima.ioc;

 import java.nio.channels.AcceptPendingException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; public class TestDI {
public static void main(String[] args) {
// 1、初始化spring容器,加载配置文件
String xmlPath = "beans.xml";
ApplicationContext applicationContext = new ClassPathXmlApplicationContext(xmlPath);
// 2、通过容器获取UserService的Bean实例userServiceID
//UserService userService = (UserService) applicationContext.getBean("userServiceID");
// 有了XML配置文件,那么Spring就可以通过配置文件中的bean-id来创建我们需要的对象,下面这样写就不用将其强转了
UserService userService = applicationContext.getBean("userServiceID", UserService.class);
// 3、调用实例中的save()方法
userService.save();
}
}

⑦配置文件:beans.xml

 <?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">
<!-- 上面是Spring的约束配置,无需手写,直接查文档 -->
<!-- 将指定类配置给Spring,让Spring创建其对象的实例 -->
<bean id="userDaoID" class="com.itheima.ioc.UserDaoImpl" ></bean>
<!-- 创建一个id为userDaoID的Bean实例,其中class属性用于指定需要实例化Bean的类 --> <!-- 添加一个id为userServiceID的Bean的实例 -->
<bean id="userServiceID" class="com.itheima.ioc.UserServiceImpl">
<!-- 将id为userDaoID的Bean实例注入到userService实例中,
即被依赖对象userDao也由Spring来管理,通过这种方法就降低了耦合度,完全由Spring的Bean来管理
-->
<property name="userDao" ref="userDaoID"></property>
<!-- property: 用于对属性赋值(注入),底层将执行setter方法
name:setter方法参数实例名,通过setter方法获得
ref:另一个bean的id值(接口实例类)的引用,创建userDao对象的bean的id值userDaoID
具体执行过程:先创建UserService对象,然后在根据property中的ref找到userDaoID并创建UserDao对象,
然后根据property中的name,通过setter方法对其赋值,这样就完成了依赖注入。
-->
</bean>
</beans>

3、执行结果:

Java EE学习笔记(一)的更多相关文章

  1. Java EE学习笔记(七)

    MyBatis的核心配置 1.MyBatis的核心对象 1).SqlSessionFactory是MyBatis框架中十分重要的对象,它是单个数据库映射关系经过编译后的内存镜像,其主要作用是创建Sql ...

  2. Java EE学习笔记(十)

    MyBatis与Spring的整合 1.整合环境搭建 1).要实现MyBatis与Spring的整合,很明显需要这两个框架的JAR包,但是只使用这两个框架中所提供的JAR包是不够的,还需要其他的JAR ...

  3. Java EE学习笔记(九)

    MyBatis的关联映射 1.关联关系概述 1).实际的开发中,对数据库的操作常常会涉及到多张表,这在面向对象中就涉及到了对象与对象之间的关联关系.针对多表之间的操作,MyBatis提供了关联映射,通 ...

  4. Java EE学习笔记(八)

    动态SQL 1.动态SQL中的元素 1).作用:无需手动拼装SQL,MyBatis已提供的对SQL语句动态组装的功能,使得数据库开发效率大大提高! 2).动态SQL是MyBatis的强大特性之一,My ...

  5. Java EE学习笔记(六)

    初识MyBatis 1.MyBatis的定义 1).MyBatis(前身是iBatis)是一个支持普通SQL查询.存储过程以及高级映射的持久层框架. 2).MyBatis框架也被称之为ORM(Obje ...

  6. Java EE学习笔记(五)

    Spring事务管理 1.Spring事务管理概述 1).在实际开发中,操作数据库时都会涉及到事务管理问题,为此Spring提供了专门用于事务处理的API.(事务特性:ACID,原子性,一致性,隔离性 ...

  7. Java EE学习笔记(四)

    Spring的数据库开发 1.Spring JDBC 1).Spring JDBC模块的作用:Spring的JDBC模块负责数据库资源管理和错误处理,大大简化了开发人员对数据库的操作,使得开发人员可以 ...

  8. Java EE学习笔记(三)

    Spring AOP 1.Spring AOP简介 1).AOP的全称是Aspect-Oriented Programming,即面向切面编程(也称面向方面编程).它是面向对象编程(OOP)的一种补充 ...

  9. Java EE学习笔记(二)

    Spring中的Bean 1.Bean的配置: a).Bean的本质就是Java中的类,而Spring中的Bean其实就是对实体类的引用,来生产Java类对象,从而实现生产和管理Bean . b).S ...

随机推荐

  1. hdu1198 Farm Irrigation —— dfs or 并查集

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1198 dfs: #include<cstdio>//hdu1198 dfs #includ ...

  2. Yii的缓存机制之片段缓存

      一.首先在main.php配置缓存组件 在components里面添加cache项.代码如下: // application components 'components'=>array( ...

  3. World Finals 2017 (水题题解)

    看大佬做2017-WF,我这种菜鸡,只能刷刷水题,勉强维持生活. 赛后补补水题. 题目pdf链接,中文的,tls翻译的,链接在这里 个人喜欢在vjudge上面刷题. E Need for Speed ...

  4. 【C/C++】计算两个整数的最大公约数和最小公倍数

    算法一 任何>1的整数都可以写成一个或多个素数因子乘积的形式,且素数乘积因子以非递减序出现. 则整数x,y可以分别标记为:x=p1x1p2x2...pmxm y=p1y1p2y2...pmym ...

  5. No java virtual machine ....

    运行Eclipse提示No java virtual machine   版权声明:本文原创作者:一叶飘舟 作者博客地址:http://blog.csdn.net/jdsjlzx http://blo ...

  6. TortoiseGit创建本地库并提交到远程服务器

    前半部分参考网上的例子:http://www.showerlee.com/archives/1300,但会出现“Git did not exit cleanly (exit code 128)”错误 ...

  7. 《Kubernetes权威指南第2版》学习(二)一个简单的例子

    1: 安装VirtualBox, 并下载CentOS-7-x86_64-DVD-1708.iso, 安装centOS7,具体过程可以百度. 2:开启centOS的SSH, 步骤如下: (1) yum ...

  8. JS搜索商品(跟外卖app店内搜索商品一样) ,keyup函数和click函数调用

    HTML: input输入框: <input id="sea" type="text"> JS: //点击搜索商品 $('#mys').click( ...

  9. IOS远程推送证书的制作步骤

    今天还在看环信的使用方法,在环信的官网上发现了这组制作远程推送证书的一组图片,正好之前本人没有写过关于远程证书的笔记,这里要写一篇博文,整理一下远程推送证书的制作流程,尽管如此,本篇博文依然是作者原创 ...

  10. Kafka入门之生产者消费者测试

    目录: kafka启动脚本以及关闭脚本 1. 同一个生产者同一个Topic,两个相同的消费者相同的Group 2. 同一个生产者同一个Topic,两个消费者不同Group 3. 两个生产者同一个Top ...