又是美好而努力的一天呀~
__
/|
* * * * * * /
* * * / *
* * * / *
* * *
* *
* happy valentine's day *
* *
* *
* *
* *
* / *
/ * *
__/ * *
/| *
目录
ALT+Insert可以重新toString()方法
后面就是测试类里面可以不用进行强转,而是通过在其后面加入类名.class
context.getBean("User",User.class)
1.C命名和P命名空间注入
- P命名注入
- C命名注入
data:image/s3,"s3://crabby-images/8f5d1/8f5d13d037680eb4c49fbdd4d05839c2cea3ea60" alt=""
在官网里面
data:image/s3,"s3://crabby-images/d60bf/d60bfa7bf03f2153e34e22899f9ac3793333bdfa" alt=""
2.bean作用域
data:image/s3,"s3://crabby-images/47185/4718518bd022dbe7b682b2ec71c850a1f3cda00e" alt=""
这里的话,单例 模式适用于在单线程的情况下,而单例模式适用于多线程
3.自动装配Bean
data:image/s3,"s3://crabby-images/a9b0f/a9b0fe37dba4e8effaa6119c1baf9a43d2829ad0" alt=""
3.1、byName
会自动在容器上下文中查找,和自己对象set方法后面的值对应的bean id
data:image/s3,"s3://crabby-images/0fdb6/0fdb6c50893e4060b05072df8e7f139895348d40" alt=""
3.2、byType
会自动在容器上下文中查找,和自己对象属性类型相同的bean
data:image/s3,"s3://crabby-images/66e42/66e42b04fa3a549381cc8bd3024ced2c94729bb6" alt=""
3.注解装配
配置:
XML
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd">
<context:annotation-config/>
</beans>
aop和注解的配置 注意看是有很多相似的地方的。
data:image/s3,"s3://crabby-images/aeb5f/aeb5ff82d358c0e0c3da9e85afa0b508d6273089" alt=""
autowired
data:image/s3,"s3://crabby-images/1df6d/1df6d8e829c4292e8c8513d3e16920f015874512" alt=""
data:image/s3,"s3://crabby-images/8984b/8984b20375a366103c8b149a1e2efbfe7c308962" alt=""
data:image/s3,"s3://crabby-images/ecff9/ecff9c07b91f82bfeebb4dac2839ea66c0f56577" alt=""
Resoures
data:image/s3,"s3://crabby-images/5720c/5720ca57ad08149a4996f44d0710b98522dccc3b" alt=""
4.Spring注解开发
总结:这一部分的笔记截取的比较多,所以看起来会有点'乱',但是大致的知识点也就是这样了。
首先 就是在beans中导入注解相关的依赖,然后 知道@Component以及其衍生注解,@Value ,有自动装配功能的**@Autowired,@Nullable,@Resource** 注解的功能。接着 就是其作用域,单例模式,原型模式,用**@Scope** 。最后就是要知道xml和注解的区别。
在spring4之后,要使用注解开发,必须保证aop的导入了使用注解需要导入context约束,增加注解的支持!
4.1、bean
首先就是配置 aop和context的导入非常相似
data:image/s3,"s3://crabby-images/07353/07353c88279ed923d96a1d50f01d7dbf19f907c9" alt=""
4.2、属性如何注入
Component注解,表示组件的意思,
data:image/s3,"s3://crabby-images/a9e89/a9e891d879d7544877a64785d4fd602e49035eb8" alt=""
4.3、衍生的注解
data:image/s3,"s3://crabby-images/62a45/62a455f689758e346191b3e85fe267f508614f40" alt=""
4.4、自动装配
data:image/s3,"s3://crabby-images/8aa66/8aa664c5db27e36d930523474bc1caafb1dfb359" alt=""
4.5、作用域
data:image/s3,"s3://crabby-images/73fc6/73fc6b2a4ba2286fbced7e2bb1cfa7d304a9d74a" alt=""
4.6、小结
data:image/s3,"s3://crabby-images/cfbf2/cfbf2cf187bcf516b822af063ece2cd60f919ffc" alt=""
5.使用JavaConfig实现配置
这里就是完全使用注解了,小案例如下:
代码:
java
//1.ZhangConfig类
package org.example.Config;
import org.example.pojo.User;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
@Configuration
@ComponentScan("org.example.pojo")
public class ZhangConfig {
@Bean
public User getUser(){
return new User();
}
}
//2.User类
package org.example.pojo;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
@Component
public class User {
@Value("zhang")
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
//3.测试类
import org.example.Config.ZhangConfig;
import org.example.pojo.User;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
public class test {
public static void main(String[] args) {
ApplicationContext context = new AnnotationConfigApplicationContext(ZhangConfig.class);
User getUser = context.getBean("getUser", User.class); //这里的getUser就是User类里面的方法名
System.out.println(getUser.getName());
}
}
data:image/s3,"s3://crabby-images/baa32/baa32d4a2d94fec6af14f291bcc39980307752ab" alt=""
下面两张图是狂神 老师的代码讲解:
data:image/s3,"s3://crabby-images/0a612/0a6129ebab5f05d4c9115912e5a92a65c47fba9b" alt=""
data:image/s3,"s3://crabby-images/fdd5c/fdd5cd68228f333067956f5199c10eca0d2b00eb" alt=""
6.ERROR
data:image/s3,"s3://crabby-images/dac09/dac09e2ba69cfee7ccb0226b487f002dd218a2f4" alt=""
data:image/s3,"s3://crabby-images/18d62/18d62f2d901a327b1e26a167f856715d0ae38c91" alt=""
data:image/s3,"s3://crabby-images/d9bb1/d9bb17396ca2b126e028084fceeef92c29824133" alt=""
就是我的那个Configuration没有配置好,呜呜呜,我用了一个小时才发现!
7.代理模式
7.1、静态代理模式
主要就是集中体现第三方的功能,这里其实很好理解,看代码就行。
案例1:增删查改,且附加了一个增加日志的功能
有四个类:
data:image/s3,"s3://crabby-images/4ddbc/4ddbcd122e5a425ea013edfd3ef61d1ab006b790" alt=""
1、User是主程序
2、UserDao是接口,里面是四个方法:增删查改
3、UserDaolmpl实现了UserDao接口类
4.UserDaoService是静态代理类,在保证不改动原有实现类的基础上,添加其他的功能。
代码如下:
java
//1.User类
package com.zhang.dao;
public class User {
public static void main(String[] args) {
UserDaoService userDaoService=new UserDaoService();
UserDaolmpl userDaolmpl=new UserDaolmpl();
userDaoService.setUserDaolmpl(userDaolmpl);
userDaoService.add();
}
}
//2.UserDao类
package com.zhang.dao;
public interface UserDao {
void add();
void delete();
void update();
void query();
}
//3.UserDaolmpl类
package com.zhang.dao;
public class UserDaolmpl implements UserDao{
@Override
public void add() {
System.out.println("添加!");
}
@Override
public void delete() {
System.out.println("删除!");
}
@Override
public void update() {
System.out.println("更改!");
}
@Override
public void query() {
System.out.println("查找!");
}
}
//4.UserDaoService类
package com.zhang.dao;
//添加日志功能
public class UserDaoService {
private UserDaolmpl userDaolmpl;
public void setUserDaolmpl(UserDaolmpl userDaolmpl) {
this.userDaolmpl = userDaolmpl;
}
public void add() {
userDaolmpl.add();
log("添加");
}
public void query() {
userDaolmpl.query();
log("查找");
}
public void delete() {
userDaolmpl.delete();
log("删除");
}
public void update() {
userDaolmpl.update();
log("更改");
}
//添加日志函数
public void log(String msg){
System.out.println("使用了"+msg+"方法");
}
}
另外一个案例是买房案例,但是我觉得两者差不多,所以这里就不摆出来了,有需要的宝子和我说。
7.2、动态代理模式
狂神老师说了一句很有意思的一句话,永远不要在学生听不懂的地方过多停留。
言归正传,我觉得动态和静态相比,动态与其名字一样,很灵活,非常的方便。
案例1:
这个主要就是理解代码的作用:
工具类的思想
1.动态代理类
java
package org.example.demo02;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
public class ProxyInvocationHandler implements InvocationHandler {
//1.被代理的接口
private Object target;
public void setTarget(Object target) {
this.target = target;
}
//2.生成得到代理类
public Object getProxy(){
return Proxy.newProxyInstance(this.getClass().getClassLoader(), target.getClass().getInterfaces(),this);
}
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
log(method.getName()); //得到当前方法的名字
Object result=method.invoke(target,args);
return result;
}
//添加一个日志方法
public void log(String msg){
System.out.println("使用了"+msg+"方法");
}
}
2.测试类:
data:image/s3,"s3://crabby-images/4bf67/4bf678a4c304081cb93e9c4a2652e820b1b39a43" alt=""
data:image/s3,"s3://crabby-images/c85c8/c85c8dcbf4f3f4f930f889d5a511683ece416760" alt=""
data:image/s3,"s3://crabby-images/1be78/1be78eacd4cdf22d5e18850a7f0067fac9626d32" alt=""
data:image/s3,"s3://crabby-images/3eaa5/3eaa56ad897bc1a1b4583b1396a4bf4a30f46caf" alt=""
反射机制是什么呀!(没学,呜呜呜~)
7.2.3、Error
Exception in thread "main" java.lang.ClassCastException: class jdk.proxy1.Proxy0 cannot be cast to class org.example.demo01.Poxy (jdk.proxy1.Proxy0 is in module jdk.proxy1 of loader 'app'; org.example.demo01.Poxy is in unnamed module of loader 'app')
at org.example.demo02.Client.main(Client.java:13)
data:image/s3,"s3://crabby-images/0d495/0d4956d9ff53f1dfb47258fe5964139aa377345d" alt=""
解决:
我的问题有二
其一是在主程序里面引用的内容,也就是Proxy,是我上面一个包的类
其二是我没搞清楚代码的整个意思,所以就算是对照着狂神老师的代码也没瞧见错误。
更改如下:
data:image/s3,"s3://crabby-images/63871/6387199578f2ad37d410b997b0182669b91cae72" alt=""
画红线的部分要注意,getProxy()返回的是接口,而不是实体类。
data:image/s3,"s3://crabby-images/a794f/a794f6172554f4724c319d5629bc5c7176cfe357" alt=""
批量替换快捷键ctr+r
最后,祝大家身体健康,一天更比一天强!!!