麻绳先生

做一些记录性的工作

安装程序不支持配置安装通过usb或IEEE 1394端口链接的磁盘

无意中得到一台外星人Alpha,不过并没有硬盘,于是拆了一个1T机械作为系统盘,这个机械硬盘只能通过USB的方式连接到电脑,所以也只能通过USB安装系统到硬盘,于是发生了上述错误“安装程序不支持配置安装通过usb或IEEE 1394端口链接的磁盘”,这个问题并没有找到太多解决办法,网上大多采用“windows to go”的解决办法,我试了一试,很方便,不过和安装介质有些关系,一开始的u盘总是出错,换成硬盘就好了。

参考链接:https://bbs.luobotou.org/thread-2427-1-1.html

spring整合junit

测试人员和开发人员关注的内容是不同的。例如junit测试人员并不会关注他将要测试的程序是否是由Spring框架搭建的,所以开发人员不应该期望测试程序能够存在对开发框架的依赖性代码。而Spring框架需要IOC核心容器,junit如何处理这个问题呢?

配置方法

  1. 导入spring整合junit的jar文件
1
2
3
4
5
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>5.0.2.RELEASE</version>
</dependency>
  1. 使用junit提供的一个注解@RunWith把原有的main方法替换,替换为spring提供的
1
2
@RunWith(SpringJUnit4ClassRunner.class)
@ContentConfiguration(classes = SpringConfiguration.class)
  1. 告知spring运行器,spring和ioc创建是基于文件还是注解,并说明位置信息

@ContextConfiguration

  • locations:指定xml文件的位置,加上classpath关键字,表示在类路径下
  • classes:指定注解类所在位置

当Spring版本为5.x版本时,要求junit版本不低于4.12

spring中的注解二

前文中的注解能够对自己实现的类进行处理,但是对第三方的类则无法处理,只能使用XML的方式,为了解决这个问题,有必要提出新的注解。

创建一个新类,它是一个配置作用的类,作用与applicationcontent.xml一致。

@Configuration

作用:指定当前类是一个配置类
细节:当配置类作为AnnotationConfigApplicationContext对象创建时的参数时,该注解可以省略

@ComponentScan

作用:用于通过注解指定spring在创建容器时需要扫描的包路径
属性:value,它和basePackages的作用一致,都是用于指定创建容器时扫描的包路径,它替代了xml配置文件中的

1
<context:component-scan base-package="com.zkalan"></context:component-scan>
1
2
3
@Configuration
@ComponentScan(basePackages = "com.zkalan")
public class SpringConfigurtaion{}

@Bean

作用:用于把当前方法的返回值作为bean对象存入到spring中的ioc容器中
属性:name,用于指定bean的id,当不写时,默认值是当前方法的名字
细节:当我们使用注解配置方法时,如果方法有参数,spring矿建回去容器中查找有没有可用的bean对象,查找方式和@AutoWired注解一样

使用纯注解方式时,使用AnnotationConfigApplicationContext方法获取容器对象。

@Scope

设置bean对象的实现模式,例如singleton、prototype

@Import

作用:用于导入其他的配置类
属性:value,用于指定其他配置类的字节码;有Import注解的类是父配置类,被import的是子配置类

@PropertySource

1
@PropertySource("classpath:config.properties")

在实际中,自己写的类使用注解更方便,第三方类使用XML配置更方便。

spring中的注解

用于创建对象的注解

1
2
@component(value="accountService")
puclic class AccountServiceImpl implements IAccountService{}
  • 作用:用于当前类对象存入spring容器中
  • 属性value用于指定bean的id,默认为当前类名,并且首字母小写
1
<content:component-scan base-package="com.package"></content:component-scan>

Controller(表现层)、Service(业务层)、Repository(持久层)作用和属性与component完全一致,区分的意义在于使得三层对象更加清晰。

用于注入数据的注解

@Autowired

  • 作用:自动按照类型注入。只要容器中有唯一的bean对象类型和要注入的变量类型匹配;可以是变量上注解,也可以是方法上;如果ioc容器中没有任何bean和要注入的类型匹配,则报错;如果ioc容器中有多个类型匹配时,变量名和某个bean的id匹配时也可注入成功;
  • 在使用注解注入时,set方法是不必要的

@Qualifier

  • 作用:在按照类型注入的基础上再按照名称注入,它在给类成员变量注入时不能单独使用,要和autowired组合;但是在给成员方法参数进行注入时可以单独使用;
  • 属性value用于指定注入的bean的id

@Resource

  • 作用:直接按照bean的id注入,可以单独使用
  • 属性name用于指定bean的id
    以上三个注解只能注入其他bean类型数据,而基本类型和String类型无法使用上述注解实现,另外,集合类型的注入只能通过xml来实现。

@Value

  • 作用:用于注入基本数据类型和String类型的数据
  • 属性value用于指定数据的值,它可以使用spring中的SpEL,也就是spring的el表达式,SpEL的写法:${表达式}

用于改变作用范围的注解

@Scope

  • 作用:用于指定bean的作用范围
  • 属性value指定范围的取值,singleton、prototype

和生命周期有关的注解

@PreDestroy:指定销毁方法
@PostConstruct:指定初始化方法

spring中的依赖注入

依赖注入Dependency Injection;IOC的作用:降低程序之间的耦合、依赖关系;依赖关系的管理都交给spring维护;在当前类中需要的其他类的对象,由spring提供,只需要在配置文件中说明;依赖关系的维护称之为依赖注入。

依赖注入

能够注入的数据有三类

  • 基本数据类型和String
  • 其他bean类型(在配置文件或注解配置过的bean)
  • 复杂类型/集合类型
    注入的方式,三种
  • 使用构造函数提供
  • 使用set方法提供
  • 使用注解提供

构造函数注入

使用的标签:constructor-arg
标签出现的位置:bean标签的内部

1
<constructor-arg name="name"></constructor-arg>

标签中的属性:

  • type:用于指定要注入的构造函数参数列表中数据的数据类型
  • index:用于指定要注入的数据在构造函数参数列表中的索引值,从零开始
  • name:指定构造函数中的形式参数名称
  • value:用于提供基本数据类型和String类型的数据
  • ref:用于指定其他的bean类型数据,必须是在spring核心容器中出现过的bean对象

优势

在获取bean对象时,注入数据是必须的操作,否则无法创建对象

缺点

改变了bean对象的实例化方式,使我们在创建对象时必须提供指定的数据

set方法注入(更常用)

涉及的标签:property
出现的位置:bean标签内部
标签的属性

  • name:用于指定注入时使用的set方法名字,改名字是set方法去掉set后余下的部分,并且首字母小写
  • value:用于提供基本类型和String类型的数据
  • ref:用于指定其他的bean数据类型,必须是在spring核心容器中出现过的bean对象
    1
    <property name="username" value="test"></property>

复杂类型注入

用于给list结构集合注入使用标签list、array、set,可通用;
用于给map结构集合注入使用标签map、props,可通用;

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
<property name="mystring">
<list>
<value>abc</value>
<value>abc</value>
</list>
</property>
<property name="myarray">
<array>
<value>abc</value>
<value>abc</value>
</array>
</property>
<property name="myset">
<set>
<value>abc</value>
<value>abc</value>
</set>
</property>
<property name="mymap">
<map>
<entry key="a" value="1"></entry>
<entry key="b">
<value>2</value>
</entry>
</map>
</property>
<property name="myprop">
<props>
<entry key="a" value="1"></entry>
<entry key="b">
<value>2</value>
</entry>
</props>
</property>