springday03-go1

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预先实例化,,会输出前两项
}

}

时间: 2024-11-11 18:50:06

springday03-go1的相关文章

go1.8之安装配置

说明: 之前学习过go语言(大概是0.9版本),后来更新太快,也没怎么使用,就荒废掉了,今年有项目需要用go开发,重新捡起. 这是我在学习go语言过程中整理的内容,这里记录下,也方便我以后查阅. 操作系统: CentOS 6.9_x64 go语言版本: 1.8.3 安装go 这里直接安装二进制,其它方式请自行搜索. 1.下载并安装go 命令如下: wget https://storage.googleapis.com/golang/go1.8.3.linux-amd64.tar.gz --no-

go1.6的vendor不生效原因

用go1.6时,把自己写的包放在vendor目录里,发现go编译时并不去找vendor目录里的包,在各种google之后也没找到原因.仔细观察官方的示例才发现,使用vendor功能时包都在$GOPATH/src下,测试了一下,果然是这样.只有在$GOPATH/src下的包,才能使用vendor目录存放依赖包. 现在go对不在$GOPATH/src下开发的项目限制越来越多,看来以后只能在$GOPATH/src下新创建项目了.

Install go1.5 for CentOS7

https://golang.org/doc/install 下载好后,通过FTPS,传递到Linux里去,放哪里随便你自己,因为被墙了,所以在Windows通过旋风下载了这个玩意儿. 你也可以: wget https://storage.googleapis.com/golang/go1.5.linux-amd64.tar.gz //将go解压到/opt,个人喜好罢了 [[email protected] ~]# tar -C /opt -xzf ./go1.5.linux-amd64.tar

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

一.关于GO开发环境的安装和配置 在linux环境中安装编译好的go安装包,参考官方指南的步骤一步步走下来就可以了.需要注意的是以下几个环境变量的配置: GOROOT - go编译库的目录,类似于java的JAVA_HOME PATH - 注意把$GOROOT/bin添加上去 GOPATH - go工作目录,类似于eclipse的workspace 以下是具体的安装步骤和环境配置        $ wget https://storage.googleapis.com/golang/go1.6.

ubuntu上安装Go1.5

下载golang1.5.1编译后的可执行文件包:go1.5.1.linux-amd64.tar.gz.(官方下载地址:http://www.golangtc.com/download) 部署如下: 1.解压: [email protected]:/usr/local# tar -xzvf go1.5.1.linux-amd64.tar.gz 2./etc/profile文件最后添加如下内容: export GOROOT=/usr/local/goexport GOPATH=/home/tjy/g

安装配置go1.4及eclipse的go开发环境

首先从网上下载 golang 1.4版本 官方:http://code.google.com/p/gomingw/downloads/list 第三方:http://www.golangtc.com/static/go/go1.4.windows-amd64.zip 安装配置go1.4 将解压的go目录放任意目录.默认C:\go 配置系统环境变量:GOROOT 和GOPATH. <1>我们可直接在系统环境变量path添加GOBIN的目录C:\go\bin即可(系统将默认GOROOT:C:\go

Go1.5 改进摘要

Go1.5 改进简介 纯Go(+少量汇编)实现 runtime 和 编译器 改进 垃圾回收器, 支持 并发 (有个指标好像是 停顿在 10 毫秒以内). GOMAXPROCS 默认值改为 CPU 核数 internal 限制规则推广到第三方包 (之前只有 std 包启用) 增加 vendor 支持, 基本解决 第三方库的依赖问题和版本问题 增加 trace 命令, 更友好的剖析程序运行状态 增加 go doc 命令 语法变化 增加 map 字面量. 以前的代码: m := map[Point]s

CentOS7.6安装Go-1.12.9

安装步骤 Go的官网:https://golang.google.cn 1. 下载压缩包 wget https://dl.google.com/go/go1.12.9.linux-amd64.tar.gz<说明> 如果出现SSL证书错误问题,加上--no-check-certificate选项. 2. 解压到指定目录下 tar -C /usr/local -xzvf go1.12.9.linux-amd64.tar.gz<说明> 解压成功后,会在/usr/local目录下生成go目

Linux下go1.8安装方法

之前迷上了神奇的Go语言,就在windows上装上了Go1.8,挺顺风顺水的,不过最近换上了Linux时,编译安装就炸了,各种报错.今天就留个记录,备个份! 编译安装Go1.8的主体思路: 从github中clone下来 确保linux系统安装较新的libc,gcc(apt,yum随便搞上) 切换库分支至1.4(刚clone下来的库),去到src目录,执行all.bash 把编译安装完的1.4目录cp到/root/,并更名为go1.4 将刚刚的编译安装的仓库恢复原状(git clean -dfx

go1.13 mod 实践和常见问题

实践建议 0,go mod 要求所有依赖的 import path 的path 以域名开头,如果现有项目转1.13的go mod 模式,且不是以域名开头则需要修改. eg: code.be.mingbai.com/tools/any_test_del_free 1, 既然已经更新到1.13了,建议直接设置GO111MODULE="on" ,即开启go mod 模式.因为这也是以后的主流,path会慢慢的消失. go env -w GO111MODULE=on 2,给go mod 设置代