Spring三种对象创建方式

1、创建方式1:无参构造
我们先创建一个User类:

public class User {private String name;private int age;public User() {System.out.println("无参构造方法");}public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}}

在spring的环境配置文件里配置:

<bean name="user" class="cn.it.bean.User"></bean>

注:上面已经配置好了,这个就不单独演示了,三种方法放在一起测试

2、创建方式二:静态工厂
创建一个UserFactory类,代码如下:

public class UserFactory {public static User createUser() {System.out.println("静态工厂");return new User();}
}

在配置文件里配置:

<!-- 调用静态工厂 --><bean name="user2" class="cn.it.create.UserFactory" factory-method="createUser"></bean>

第二种方式已经准备好了。

3、创建方式三:实例工厂:
在上面的UserFactory改成如下代码:

public class UserFactory {public static User createUser() {System.out.println("静态工厂");return new User();}public  User createUser2() {System.out.println("实例工厂");return new User();}
}

在配置文件里配置:

<!-- 调用实例工厂 --><bean name="user3" factory-bean="userFactory" factory-method="createUser2"></bean><bean name="userFactory" class="cn.it.create.UserFactory"></bean>

上面三种创建方式已经准备好了,接下来我们写一个测试类:

public class Demo {@Test//创建方法一:空参构造public void fun1() {//每次容器启动就会创建容器中所配置的所有对象ApplicationContext as = new ClassPathXmlApplicationContext("cn/it/create/applicationContext.xml");User user = (User) as.getBean("user");System.out.println(user);}@Test//创建方法二:静态工厂public void fun2() {//每次容器启动就会创建容器中所配置的所有对象ApplicationContext as = new ClassPathXmlApplicationContext("cn/it/create/applicationContext.xml");User user = (User) as.getBean("user2");System.out.println(user);}@Test//创建方法二:实例工厂public void fun3() {//每次容器启动就会创建容器中所配置的所有对象ApplicationContext as = new ClassPathXmlApplicationContext("cn/it/create/applicationContext.xml");User user = (User) as.getBean("user3");System.out.println(user);}
}

结果:
在这里插入图片描述
在最后,我想写一下ApplicationContext的创建方式:
ApplicationContext每次创建或者启动就会创建容器里配置的所有对象。所以列如在我们使用:

User user = (User) as.getBean("user");

获取User的对象时,user已经存在了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/380917.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《Windows核心编程》の窗口过程的使用

1&#xff09;设计一个窗口过程&#xff1a; 下面的实例代码展现了经典的窗口过程的结构。窗口过程使用switch语句处理传入的消息参数uMsg&#xff0c; LRESULT CALLBACK MainWndProc( HWND hwnd, // handle to window UINT uMsg, // message identifier WPARAM …

Anti-Screen Capture(Prevent Screen Captures)截屏与反截屏

1.数字图片使用类似与动画的方式显示&#xff0c;每次显示的是数字的一部分&#xff0c;当动态显示的时候人眼是可以分辨出具体数字的。但是截图的话就只能截取一部分&#xff0c;参考&#xff1a; cups.cs.cmu.edu/soups/2007/posters/p147_lim.pdf 2.屏蔽系统按键&#xff1…

unity中链接字符串和变量显示_理解Unity中的优化(六):字符串和文本

字符串和文本&#xff1a;在Unity项目中&#xff0c;处理字符串和文本经常会产生性能问题。在C#中&#xff0c;字符串是不变的。任何对字符串的操作都会重新分配新的字符串&#xff0c;这个代价是非常昂贵的。如果在多重循环中重复地执行字符串连接操作&#xff0c;就会造成性能…

Bean的scope属性

1、singleton&#xff08;默认值&#xff09;&#xff1a;单列对象&#xff0c;被标识为单例的对象在spring容器中只会存在一个实例 测试如下&#xff1a; 我们创建一个User类&#xff1a; public class User {private String name;private int age;public User() {System.out…

Oracle 索引扫描的五种类型

之前在讨论CBO和RBO的时候提到了索引扫描的几种类型。 Oracle Optimizer CBO RBO http://blog.csdn.net/tianlesoftware/archive/2010/08/19/5824886.aspx Oracle 索引 详解 http://blog.csdn.net/tianlesoftware/archive/2010/03/05/5347098.aspx Oracle Explain Plan http:/…

VS中标志寄存器表示

溢出标志OF(Over flow flag) OV(1) NV(0) 方向标志DF(Direction flag) DN(1) UP(0) 中断标志IF(Interrupt flag) EI(1) …

mysql修改表的结构_MySQL修改表结构

我们在修改表字段类型和约束条件的时候&#xff0c;如果表中的字段已经有值了&#xff0c;但是你修改的这个类型和字段里边的值不匹配是不允许修改的&#xff0c;就比如说你当初设置字段的时候&#xff0c;字段的值是允许存空值&#xff0c;并且字段里边已经存储空值了&#xf…

导入其他spring模块配置

列如下图中有两个spring的配置文件&#xff0c;我们想把上面的配置文件导入到下面的文件中去&#xff0c;该如何操作&#xff1a; 打开下面的配置文件&#xff0c;配置属性import,在import的resource配置上面配置文件的路径就可以了&#xff0c;如下&#xff1a; <import …

vs2019编写Linux c/c++项目

最近一直在阅读ovs的源码&#xff0c;看到用户态代码的时候&#xff0c;需要对用户态的代码进行调试&#xff0c;一开始想直接使用linux中的GDB进行调试&#xff0c;但是ovs的工程太过于复杂&#xff0c;从网上找了些文章&#xff0c;发现vs2017能够支持linux c程序的调试&…

mysql workbench 6.2_MySQL Workbench 6.2.4 下载 因为移动网络打不开官方也可能是国内网络问题 备用自己...

linux下好用的mysql gui 不多啊&#xff0c;除非在wine下 不太习惯phpmyadmin除了这个貌似在linux的就不多了&#xff0c;这里就用官方的管理工具吧win版本&#xff1a;http://dev.mysql.com/get/Downloads/MySQLGUITools/mysql-workbench-community-6.2.4-win32.msihttp://dev…

spring属性注入的set方法注入

1、值注入 创建我们要使用的User类&#xff1a; package cn.it.bean;public class User {private String name;Overridepublic String toString() {return "User [name" name ", age" age "]";}private int age; // private Car car; // /…

MySQLdb安装的错误说明

1、从http://www.codegood.com/上下载到国外有人编译好的&#xff0c;自己就免去这一环节 2、import MySQLdb时出现如下错误&#xff1a; Warning (fromwarnings module): File "C:\Python26\lib\site-packages\MySQLdb\__init__.py", line 34fromsets importImmuta…

excel oledb mysql_OLEDB操作Excel

使用OLEDB操作Excel 的方法OleDbConnection conn null;try{//fileName 表示要操纵的Excel的文件路径&#xff0c;如果excel不存在&#xff0c;现创建它&#xff0c;可以通过模版文件复制创建。string strConn;strConn "ProviderMicrosoft.Jet.OLEDB.4.0;" "Da…

系统蓝屏的几种姿势

前言 在 蓝屏&#xff08;BSOD&#xff09;转储设置&#xff0c;看本文就够了&#xff01; 这篇文章里比较详细的介绍了蓝屏转储设置。做好设置后&#xff0c;我们就可以在需要的时候使系统蓝屏了。这样我们就可以拿到一份系统转储&#xff0c;供我们分析问题了。本文介绍几种可…

Java基础:int和Integer的区别

1、基本使用对比&#xff1a; &#xff08;1&#xff09;&#xff1a;Integer是int的包装类&#xff1b;int是基本数据类型&#xff1b; &#xff08;2&#xff09;&#xff1a;Integer变量必须实例化后才能使用&#xff1b;int变量不需要&#xff1b; &#xff08;3&#xff…

nginx lua mysql 性能_深入浅出 nginx lua 为什么高性能

最近很多人问我nginx lua的优势是什么&#xff1f;为什么&#xff1f;一、同步和异步、阻塞和非阻塞如果要说清楚这个问题首先要了解&#xff1a;同步和异步、阻塞和非阻塞的关系同步&#xff1a;php、java的正常代码都是同步执行的异步&#xff1a;javascript的回调函数就是异…

我们的生命,不因别人的喜欢而存在

我们的生命&#xff0c;不因别人的喜欢而存在 过去咱们中国人讲的是“路遥知马力&#xff0c;日久见人心”“人不可貌相&#xff0c;海水不可斗量”&#xff0c;比较注重的是心灵美。大家都在一个村庄住着&#xff0c;谁是个什么人&#xff0c;彼此心里都有数。生活节奏慢&…

RtlAdjustPrivilege() 提权函数

RtlAdjustPrivilege(SE_DEBUG_NAME,1,0,NULL);这玩意是在 NTDLL.DLL 里的一个不为人知的函数,MS没有公开,原因就是这玩意实在是太NB了,以至于不需要任何其他函数的帮助,仅凭这一个函数就可以获得进程ACL的任意权限! 先来看看这个函数的定义(Winehq给出)&#xff1a; NTSTATUS …

求两个数字的乘积,如果大于0,说明两个数字同号,如果小于0,说明两个数字异号,如果等于0,说明其中一个是0

学了java基础东西&#xff0c;就写了这个编程&#xff0c;求两个数字的乘积&#xff0c;如果大于0&#xff0c;说明两个数字同号&#xff0c;如果小于0&#xff0c;说明两个数字异号&#xff0c;如果等于0&#xff0c;说明其中一个是0 首先程序要求我们输入两个数字&#xff0c…

mysql gtid 开启失败_mysql开启GTID跳过错误的方法【转】

1、数据库版本MySQL> select version()-> ;-------------------------------------------| version() |-------------------------------------------| 5.7.17 |------------------------------------…