构造方法与setter方法
上一个随笔提到了constructor-arg子标签,此随笔将会介绍一些类型的赋值方法
①String类型、基本数据类型或其包装类都可以使用value标签属性赋值
String类型和基本类型的操作如下:
//User.java文件中的代码
public User(int id){
System.out.println("序号"+ id);
}
public User(String name){
System.out.println("姓名" + name);
}
<!-- application.xml文件中的代码-->
<bean class="com.zzj.ov.User">
<constructor-arg type="int" value="21"></constructor-arg>
<constructor-arg type="String" value="朱祖杰"></constructor-arg>
</bean>
//测试文件的代码
public class Test {
public static void main(String[] args){
new ClassPathXmlApplicationContext("application.xml");
}
}
②类类型(自定义类型)
类类型的操作如下(以Date类型为例):
//User.java文件中的代码
public User(Date birth){
System.out.println("生日" + birth);
}
<!-- application.xml文件中的代码-->
<!-- 将Date类引用 -->
<bean name="bi" class="java.util.Date"></bean>
<!-- 使用ref-->
<bean class="com.zzj.ov.User">
<constructor-arg ref="bi"></constructor-arg>
</bean>
//测试文件的代码
public class Test {
public static void main(String[] args){
new ClassPathXmlApplicationContext("application.xml");
}
}
③数组类型
constructor-arg ——>array——>value(String类型、基本数据类型或其包装类),ref>bean类类型(自定义类型)
数组类型的操作如下:
//User.java文件中的代码
public User(Object[] array){
System.out.println("数组");
for(Object object: array){
System.out.println(object);
}
}
<!-- application.xml文件中的代码-->
<!-- 将Date类引用 -->
<bean name="bi" class="java.util.Date"></bean>
<bean class="com.zzj.ov.User">
<constructor-arg>
<array>
<!--同样的基本类型和String类型直接使用value赋值-->
<value>12</value>
<value>Tom</value>
<!--类类型使用ref引用-->
<ref bean="bi"/>
<!--或者直接使用bean将类引用-->
<bean class="java.lang.String">
<constructor-arg value="HAHA"></constructor-arg>
</bean>
</array>
</constructor-arg>
</bean>
//测试文件的代码
public class Test {
public static void main(String[] args){
new ClassPathXmlApplicationContext("application.xml");
}
}
④集合类型
List:constructor-arg ——>list——>value(String类型、基本数据类型或其包装类),ref>bean类类型(自定义类型)
//User.java文件中的代码
public User(List<Object> list){
System.out.println("List集合");
for(Object object: list){
System.out.println(object);
}
}
<!--application.xml文件中的代码-->
<bean name="bi" class="java.util.Date"></bean>
<bean class="com.zzj.ov.User">
<constructor-arg>
<list>
<value>12</value>
<value>Tom</value>
<ref bean="bi"/>
<bean class="java.lang.String">
<constructor-arg value="HAHA"></constructor-arg>
</bean>
</list>
</constructor-arg>
</bean>
//测试文件的代码
public class Test {
public static void main(String[] args){
new ClassPathXmlApplicationContext("application.xml");
}
}
Set:constructor-arg ——>set——>value(String类型、基本数据类型或其包装类),ref>bean类类型(自定义类型)
//User.java文件中的代码
public User(Set<Object> set){
System.out.println("Set集合");
for(Object object: set){
System.out.println(object);
}
}
<!--application.xml文件中的代码-->
<bean name="bi" class="java.util.Date"></bean>
<bean class="com.zzj.ov.User">
<constructor-arg>
<set>
<value>12</value>
<value>Tom</value>
<ref bean="bi"/>
<bean class="java.lang.String">
<constructor-arg value="HAHA"></constructor-arg>
</bean>
</set>
</constructor-arg>
</bean>
//测试文件的代码
public class Test {
public static void main(String[] args){
new ClassPathXmlApplicationContext("application.xml");
}
}
Map:constructor-arg ——>map——>
entry:key或value是String类型、基本数据类型或其包装类,则分别使用entry标签中key和value标签属性
entry:key或value是类类型(自定义类型),应该使用对相应的key-ref或value-ref
//User.java中的代码
public User(Map<String,Object> map){
System.out.println("Map集合");
Set<String> keys = map.keySet();
for(String key : keys){
System.out.println(key + ":" + map.get(key));
}
}
<!--application.xml文件中的代码-->
<bean name="bi" class="java.util.Date"></bean>
<bean class="com.zzj.ov.User">
<constructor-arg>
<map>
<entry key="name" value="Tom"></entry>
<entry key="age" value="12"></entry>
<entry key="birth" value-ref="bi"></entry>
</map>
</constructor-arg>
</bean>
//测试文件的代码
public class Test {
public static void main(String[] args){
new ClassPathXmlApplicationContext("application.xml");
}
}
⑤Properties:constructor-arg ——>props——>prop 只能配置String类型
//User.java文件中的代码如下
public User(Properties properties){
System.out.println(properties.get("driver"));
System.out.println(properties.get("userName"));
System.out.println(properties.get("password"));
System.out.println(properties.get("url"));
}
<!--application.xml文件中的代码-->
<bean name="bi" class="java.util.Date"></bean>
<bean class="com.zzj.ov.User">
<constructor-arg>
<props>
<prop key="driver">com.mysql.jdbc.Driver</prop>
<prop key="userName">root</prop>
<prop key="password">root</prop>
<prop key="url">jdbc:mysql://127.0.0.1:3306/test</prop>
</props>
</constructor-arg>
</bean>
//测试文件的代码
public class Test {
public static void main(String[] args){
new ClassPathXmlApplicationContext("application.xml");
}
}
⑥setter方法(两种,需要在命名空间中选中p)
//User.java中的代码
private String id;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
} private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
<!--application.xml文件中的代码-->
<!--第一种直接在bean标签里用p方法,第二种使用property标签-->
<bean class="com.zzj.ov.User" p:id-ref="bi" p:name="Tom">
<property name="name" value="Tom"></property>
<property name="id" ref="bi"></property>
</bean>
//测试文件的代码
public class Test {
public static void main(String[] args){
new ClassPathXmlApplicationContext("application.xml");
}
}
构造方法与setter方法的更多相关文章
- Java中构造方法与setter方法
今天在重温Java的同时,一个不是问题的问题,突然地冒出来,不知道大家是不是和我一样,也有过这个比较尴尬的问题 不啰嗦了,那咱就直接说问题吧~~~ 那么首先我们在Java中都会写构造函数,目的是在 ...
- spring 构造方法注入和setter方法注入的XML表达
1.构造方法注入 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE beans PUBLIC ...
- spring构造函数注入、setter方法注入和接口注入
Spring开发指南中所说的三种注入方式: Type1 接口注入 我们常常借助接口来将调用者与实现者分离.如: public class ClassA { private InterfaceB clz ...
- 基于注解处理器开发自动生成getter和setter方法的插件
昨天无意中,逛到了lombok的网站,并看到了首页的5分钟视频,视频中的作者只是在实体类中写了几个字段,就可以自动编译为含setter.getter.toString()等方法的class文件.看着挺 ...
- 一篇文章看懂java反射机制(反射实例化对象-反射获得构造方法,获得普通方法,获得字段属性)
Class<?> cls = Class.forName("cn.mldn.demo.Person"); // 取得Class对象传入一个包名+类名的字符串就可以得到C ...
- spring--Autowired setter 方法
在Spring中,可以使用 @Autowired 注解通过setter方法,构造函数或字段自动装配Bean.此外,它可以在一个特定的bean属性自动装配. 注 @Autowired注解是通过匹配数据类 ...
- Spring-Context之六:基于Setter方法进行依赖注入
上文讲了基于构造器进行依赖注入,这里讲解基于Setter方法进行注入.在Java世界中有个约定(Convention),那就是属性的设置和获取的方法名一般是:set+属性名(参数)及get+属性名() ...
- IOS model的getter和setter方法
总结: 当使用 self.str1 = @"xxx";时, 系统自动调用 setter方法 param_str = self.str1; 自动调用getter方法注意: 只在对象点 ...
- ARC以及MRC中setter方法
ARC以及MRC中setter方法的差异 有时候,你会需要重写setter或者getter方法,你知道么,ARC与MRC的setter方法是有着差异的呢. 先看下MRC下的setter方法: 在看下A ...
随机推荐
- 8 HTML DOM 元素的查找与改变&改变CSS样式&HTML事件
HTML DOM(Document Object Model)文档对象模型 当网页被加载时,浏览器会创建页面的文档对象模型. HTMLDOM 定义了用于HTML的一系列标准的对象.通过DOM,你可以访 ...
- ehcache配置文件
ehcache.xml: <?xml version="1.0" encoding="UTF-8"?><ehcache xmlns:xsi=& ...
- 记一次安装体验:pwn工具
几天前删了JDK,结果和VM在一个目录中,结果VM全没了,重安走起 记载一下安装虚拟机出现的问题,官网一个字....慢,于是找了百度网盘,据说win10版本太低没法用,我就下了vw15.5.0(建立在 ...
- luogu P4014 分配问题
简单的费用流问题,每个人对每个任务连边,每个任务对汇点连,源点对每个人连,最大费用取反即可 #include<bits/stdc++.h> using namespace std; #de ...
- jstl.jar下载
jakarta开源java项目 http://attic.apache.org/projects/jakarta.html 根据其官网信息项目已于2011年退休. 不过上面官方链接可以点击Downlo ...
- 纪录片 - Why Are We Fat?(全3集)
1. 传送门:https://www.bilibili.com/video/av13977351?spm_id_from=333.338.__bofqi.16 2. 笔记 第一型糖尿病是天生的,第二型 ...
- C++11并发编程2------线程管理
本节内容: 启动一个线程 每个程序都至少会有一个线程,main函数是执行入口,我们称之为主线程,其余子线程有各自的入口函数,主线程和子线程同时运行.子线程在std::thread对象创建时启动. 1. ...
- BUAA软工第一次作业-热身
第一次作业-热身 项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) (北京航空航天大学 - 计算机学院) 这个作业的要求在哪里 第一次作业-热身作业(阅读) 我在这个课程 ...
- markdown基本语法教程
标题 一级标题 二级标题 三级标题 以此类推,总共六级标题,建议在警号后面加一个空格,这是最标准的markdown语法 列表 在markdown下: 列表的显示只需要在文字前加上-.+或*即可变为无序 ...
- JS原生编写实现留言板功能
实现这个留言板功能比较简单,所以先上效果图: 实现用户留言内容,留言具体时间. <script> window.onload = function(){ var oMessageBox = ...