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. c/c++编译时,指定程序运行时查找的动态链接库路径

    http://blog.csdn.net/tsxw24/article/details/10220735 c/c++编译时,指定程序运行时查找的动态链接库路径 分类: c/c++ linux 2013 ...

  2. (转)常用的js设计模式

    模式是解决或者避免一些问题的方案. 在JavaScript中,会用到一些常用的编码模式.下面就列出了一些常用的JavaScript编码模式,有的模式是为了解决特定的问题,有的则是帮助我们避免一些Jav ...

  3. VCL自带的TabControl真心不好用...

    不是说功能, 而是指自绘能力, 开启OwnerDraw以后, 画是可以画了, 可是为啥每个Tab页头的边框不能变捏 只能是灰秃秃的, 感觉很不和谐 RZ的TabControl很强大, 可惜想用它需要带 ...

  4. textview自适应高度的计算方法

    http://blog.csdn.net/smking/article/details/22221441

  5. sql性能优化小技巧(一)

    关于sql条件匹配对执行效率影响测试 首先,创建一个标量函数create function ff_test() returns int as begin declare @i int=0 while( ...

  6. oracle变量的定义和使用【转】

    在程序中定义变量.常量和参数时,则必须要为它们指定PL/SQL数据类型.在编写PL/SQL程序时,可以使用标量(Scalar)类型.复合(Composite)类型.参照(Reference)类型和LO ...

  7. 导航栏和里面的View设置的是同一颜色值,实际运行又不一样.

    导航栏和里面的View设置的是同一颜色值,实际运行又不一样.如何保证两者的颜色一致呢?  答案就是:( navigationBar.translucent = NO; )   去除 导航条的分割线(黑 ...

  8. Java学习-010-创建文件夹源代码

    此文源码主要为应用 Java 创建文件目录的源码.若有不足之处,敬请大神指正,不胜感激! 创建文件夹源代码如下所示: /** * @function 文件操作:创建文件夹.若文件夹不存在,则级联创建文 ...

  9. JavaScript实现进入某一页面时自动将鼠标光标放在某一textbox上

    <script language="javascript" type="text/javascript"> var txtText0 = " ...

  10. iOS工程如何支持64-bit

    苹果在2014年10月20号发布了一条消息:从明年的二月一号开始,提交到App Store的应用必须支持64-bit.详细消息地址为:https://developer.apple.com/news/ ...