springday02项目下新建包annotation1
1.复制xml文件到包annotation1下,并添加组件扫描方式代码
2.Waiter类实现序列化接口,构造函数,并使用特定注解标记waiter这个bean的id
3.Bar类中waiter为其成员变量,有参和无参构造器,get/set方法,以及toString方法
4.特定注解标记Bar这个bean的id,在构造器前面使用@Autowired和@Qualifier
5.test1中测试这种注解方式可以实现依赖注入
6.Bar2类与Bar的区别就是,将@Autowired和@Qualifier写在属性前,这种注入方式不会去调用set方法
7.test2测试Bar2
8.Bar3与Bar的区别就是,在set方法前使用@Resource(name="wt"),同样,也可以写在属性前
9.test3对Bar3进行测试
10.Student类添加pageSize和name属性,实现无参构造器,set/get方法,toString方法
11.使用Component注解,设定bean的id为stu
12.新建config.properties文件
13.修改xml文件,通过设定id和location属性,采用集合的方式读取properties文件。
14.为sdu的属性设置基本值,即使用spring表达式
15.test4对Student类进行测试

Waiter.java:

package container.annotation1;

import java.io.Serializable;

import org.springframework.stereotype.Component;

@Component("wt") //此bean的id为wt,若不写,则为类名的小写
public class Waiter implements Serializable {

public Waiter() {
System.out.println("Waiter的构造器");
}

}

Bar.java:

package container.annotation1;

import java.io.Serializable;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Component;

@Component("bar")
public class Bar implements Serializable {

private Waiter wt;

public Bar() {
System.out.println("Bar的无参构造器");
}

@Autowired //此标注加在构造器前面
//@Qualifier中的参数是要注入的bean的id,而在Waiter中我们
//已经用Component命名为wt
public Bar(@Qualifier("wt") Waiter wt) {
System.out.println("Bar的带参构造器");
this.wt = wt;
}

@Override
public String toString() {
return "Bar [wt=" + wt + "]";
}

}

Bar2.java:

package container.annotation1;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Component;

@Component("bar2")
public class Bar2 {

@Autowired //表示set方式注入,如果这样写,就不用再写set/get方法
@Qualifier("wt") //表示注入的参数bean为wt
private Waiter wt;

public Bar2() {
System.out.println("Bar2的无参构造器");
}

public Waiter getWt() {
return wt;
}

// @Autowired
// public void setWt(@Qualifier("wt") Waiter wt) {
// System.out.println("set方式注入");
// this.wt = wt;
// }

@Override
public String toString() {
return "Bar2 [wt=" + wt + "]";
}

}

Bar3.java:

package container.annotation1;

import javax.annotation.Resource;

import org.springframework.stereotype.Component;

@Component("bar3")
public class Bar3 {
@Resource(name="wt") //如果写在这里,是采用set方式注入,只是单纯的赋值语句,但它不会调用set这个方法,
//如果是写在set方法前面,则会调用set方法
private Waiter wt;

public Bar3() {
System.out.println("Bar3的无参构造器");
}

public Waiter getWt() {
return wt;
}

// @Resource(name="wt") //如果不写name,那么容器中可能会出现多个Waiter的bean,
// //建议写上name,name指定要注入的bean的id
// public void setWt(Waiter wt) {
// System.out.println("set方式注入");
// this.wt = wt;
// }

@Override
public String toString() {
return "Bar3 [wt=" + wt + "]";
}

}

student.java:

package container.annotation1;

import java.io.Serializable;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

@Component("stu")
public class Student implements Serializable{

@Value("#{jdbc.pageSize}")
private String pageSize;
@Value("李白")
private String name;

public Student() {
System.out.println("Student的无参构造器方法");
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public String getPageSize() {
return pageSize;
}

public void setPageSize(String pageSize) {
this.pageSize = pageSize;
}

@Override
public String toString() {
return "Student [pageSize=" + pageSize + ", name=" + name + "]";
}

}

xml:

<context:component-scan
base-package="container.annotation1"/>

<util:properties id="jdbc"
location="classpath:container/annotation1/config.properties"/>

config.properties:

pageSize=10

TestCase.java:

package container.annotation1;

import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import container.annotation.Waiter;

public class TestCase {
@Test
public void test1(){
String cfg = "container/annotation1/applicationContext.xml";
ApplicationContext ac =
new ClassPathXmlApplicationContext(cfg);
// Waiter wt = ac.getBean("wt",Waiter.class);
// System.out.println(wt);

Bar bar = ac.getBean("bar",Bar.class);
System.out.println(bar);
}


@Test
public void test2(){
String cfg = "container/annotation1/applicationContext.xml";
ApplicationContext ac =
new ClassPathXmlApplicationContext(cfg);
Bar2 bar2 = ac.getBean("bar2",Bar2.class);
System.out.println(bar2);
//因为是单例,组件扫描会对所有的bean预先实例化,,会输出前两项
}

@Test
public void test3(){
String cfg = "container/annotation1/applicationContext.xml";
ApplicationContext ac =
new ClassPathXmlApplicationContext(cfg);
Bar3 bar3 = ac.getBean("bar3",Bar3.class);
System.out.println(bar3);
//因为是单例,组件扫描会对所有的bean预先实例化,,会输出前两项
}

@Test
public void test4(){
String cfg = "container/annotation1/applicationContext.xml";
ApplicationContext ac =
new ClassPathXmlApplicationContext(cfg);
Student stu = ac.getBean("stu",Student.class);
System.out.println(stu);
//因为是单例,组件扫描会对所有的bean预先实例化,,会输出前两项
}

}

springday03-go1的更多相关文章

  1. Go1.7改善了编译速度并且会生成更快的代码

    Go1.7的开发周期正在接近它的下一个里程碑,Go的提交者Dave Cheney报告了子即将发布的版本中,团队成员在语言工具链上的努力. Cheney称,基于当前的开发状态,Go1.7将会很容易就成为 ...

  2. python2.7 与 go1.2简单性能比较

    过完年刚上班,项目还没有开始,对于即将到来的项目,想尝试是否可以找到一个开发效率接近python,运行效率接近静态语言的编程语言,选择基本就是scala和go,公司的技术组成基本都是c派的,scala ...

  3. go1.8之安装配置具体步骤

    操作系统: CentOS 6.9_x64 go语言版本: 1.8.3 安装go 这里直接安装二进制,其它方式请自行搜索. 1.下载并安装go 命令如下: ? 1 2 3 wget https://st ...

  4. go1.8之安装配置

    说明: 之前学习过go语言(大概是0.9版本),后来更新太快,也没怎么使用,就荒废掉了,今年有项目需要用go开发,重新捡起. 这是我在学习go语言过程中整理的内容,这里记录下,也方便我以后查阅. 操作 ...

  5. Ubuntu16.04 LTS上安装Go1.10

    原因 Ubuntu资源库上默认使用的是Go1.6.2版本,给最新版本代码编译带来了不少问题.本文就记录下在Ubuntu下直接安装Go最新版1.10的步骤. 准备工作 1.卸载已有版本 # 卸载已经安装 ...

  6. GO1.6语言学习笔记2-安装配置及代码组织

    一.关于GO开发环境的安装和配置        在linux环境中安装编译好的go安装包,参考官方指南的步骤一步步走下来就可以了.需要注意的是以下几个环境变量的配置:        GOROOT - ...

  7. Go程序开发---Go环境配置:CentOS6.5+Go1.8标准包安装

    1.Go安装 1.1Go的三种安装方式 Go有多种安装方式,可以选择自己习惯的方式进行,这里介绍三种安装方式: 1)Go源码安装 2)Go标准包安装 3)第三方工具安装 这里主要介绍下Go标准包在Ce ...

  8. 【linux】【Go】Centos7安装go1.13环境

    前言     Go(又称Golang)是Google开发的一种静态强类型.编译型.并发型,并具有垃圾回收功能的编程语言. 罗伯特·格瑞史莫(Robert Griesemer),罗勃·派克(Rob Pi ...

  9. go1.13 mod 实践和常见问题

    实践建议 0,go mod 要求所有依赖的 import path 的path 以域名开头,如果现有项目转1.13的go mod 模式,且不是以域名开头则需要修改. eg: code.be.mingb ...

  10. Go1.13 标准库的 http 包爆出重大 bug,你的项目中招了吗? 原创: 王亚楼 Go语言中文网 今天

    Go1.13 标准库的 http 包爆出重大 bug,你的项目中招了吗? 原创: 王亚楼 Go语言中文网 今天

随机推荐

  1. IIS绑定Active Directory账号自动登录网站的方法

    满足使用Request.ServerVariables["REMOTE_USER"]的条件: 1.IIS配置网站的目录安全性取消“启用匿名访问(&A)” 2.启用 “集成 ...

  2. ASP.NET一些公共方法commTools

    using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Secu ...

  3. session和cookie区别

    <?php session_start(); ?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//E ...

  4. php内容

    PHP语言原理:先把代码显示在源代码中,再通过浏览器解析在网页上 PHP中关键字通常分为四种类型: 1. 用于数据类型定义的关键字,如:int,string,bool,classic,object和a ...

  5. JAVA缓存技术之EhCache

    最近再ITEYE上看到关于讨论JAVA缓存技术的帖子比较多,自己不懂,所以上网大概搜了下,找到一篇,暂作保存,后面如果有用到可以参考.此为转贴,帖子来处:http://cogipard.info/ar ...

  6. 解读ClassLoader

    ClassLoader一个经常出现又让很多人望而却步的词,本文将试图以最浅显易懂的方式来讲解 ClassLoader,希望能对不了解该机制的朋友起到一点点作用.    要深入了解ClassLoader ...

  7. 物联网操作系统HelloX V1.80测试版发布

    经过HelloX开发团队近半年的努力,在HelloXV1.79版本基础上,增加许多功能特性,并对V1.79版本的一些特性进行了进一步优化之后,正式形成HelloX V1.80测试版本.经相对充分的测试 ...

  8. Java迭代 : Iterator和Iterable接口

    从英文意思去理解 Iterable :故名思议,实现了这个接口的集合对象支持迭代,是可迭代的.able结尾的表示 能...样,可以做.... Iterator:   在英语中or 结尾是都是表示 .. ...

  9. 【Android测试】【第一节】性能——CPU

    ◆版权声明:本文出自胖喵~的博客,转载必须注明出处. 转载请注明出处:http://www.cnblogs.com/by-dream/p/5065083.html 前言 本来打算写完全部的自动化测试之 ...

  10. express 查看版本号

    新安装了express,但是当查看版本号输入: express -v 时出现如下错误: 网上查找了相关资料才发现express查看版本 的命令是 express -V (即V大写) 再次尝试: 发现同 ...