wordpress网站静态化/智能优化大师下载
文章目录
- 动态代理( cglib 与 JDK)
- 如何强制使用CGLIB实现AOP?
- JDK动态代理和CGLIB字节码生成的区别?
- Spring MVC 运行流程
- Spring 框架中用到了哪些设计模式
- 谈谈Hibernate与Ibatis的区别,哪个性能会更高一些
- Netty-为什么选择 Netty
动态代理( cglib 与 JDK)
java动态代理是利用反射机制生成一个实现代理接口的匿名类,在调用具体方法前调用
InvokeHandler来处理。
而cglib动态代理是利用asm开源包,对代理对象类的class文件加载进来,通过修改其字节
码生成子类来处理。
1、如果目标对象实现了接口,默认情况下会采用JDK的动态代理实现AOP
2、如果目标对象实现了接口,可以强制使用CGLIB实现AOP
3、如果目标对象没有实现了接口,必须采用CGLIB库,spring会自动在JDK动态代理和
CGLIB之间转换
如何强制使用CGLIB实现AOP?
(1)添加CGLIB库,SPRING_HOME/cglib/*.jar
(2)在spring配置文件中加入<aop:aspectjautoproxy proxytargetclass=“true”/>
JDK动态代理和CGLIB字节码生成的区别?
(1)JDK动态代理只能对实现了接口的类生成代理,而不能针对类
(2)CGLIB是针对类实现代理,主要是对指定的类生成一个子类,覆盖其中的方法
因为是继承,所以该类或方法最好不要声明成final
参考链接:http://www.cnblogs.com/leifei/p/8263448.html
Spring MVC 运行流程
一、先用文字描述
-
1.用户发送请求到DispatchServlet
-
2.DispatchServlet根据请求路径查询具体的Handler
-
3.HandlerMapping返回一个HandlerExcutionChain给DispatchServlet
HandlerExcutionChain:Handler和Interceptor集合
-
4.DispatchServlet调用HandlerAdapter适配器
-
5.HandlerAdapter调用具体的Handler处理业务
-
6.Handler处理结束返回一个具体的ModelAndView给适配器
ModelAndView:model–>数据模型,view–>视图名称
-
7.适配器将ModelAndView给DispatchServlet
-
8.DispatchServlet把视图名称给ViewResolver视图解析器
-
9.ViewResolver返回一个具体的视图给DispatchServlet
-
10.渲染视图
-
11.展示给用户
二、画图解析
SpringMvc 的配置
Spring 框架中用到了哪些设计模式
Spring框架中使用到了大量的设计模式,下面列举了比较有代表性的:
-
代理模式—在AOP和remoting中被用的比较多。
-
单例模式—在spring配置文件中定义的bean默认为单例模式。
-
模板方法—用来解决代码重复的问题。比如. RestTemplate, JmsTemplate, JpaTemplate。
-
工厂模式—BeanFactory用来创建对象的实例。
-
适配器–spring aop
-
装饰器 –spring data hashmapper
-
观察者 spring 时间驱动模型
-
回调–Spring ResourceLoaderAware回调接口
-
前端控制器–spring用前端控制器DispatcherServlet对请求进行分发
谈谈Hibernate与Ibatis的区别,哪个性能会更高一些
答:
-
Hibernate偏向于对象的操作达到数据库相关操作的目的;而ibatis更偏向于sql语句的优化。
-
Hibernate的使用的查询语句是自己的hql,而ibatis则是标准的sql语句。
-
Hibernate相对复杂,不易学习;ibatis类似sql语句,简单易学。
性能方面:
-
如果系统数据处理量巨大,性能要求极为苛刻时,往往需要人工编写高性能的sql语句或存错过程,此时ibatis具有更好的可控性,因此性能优于Hibernate。
-
同样的需求下,由于hibernate可以自动生成hql语句,而ibatis需要手动写sql语句,此时采用Hibernate的效率高于ibatis。
Netty-为什么选择 Netty
Netty 是业界最流行的 NIO 框架之一,它的健壮性、功能、性能、可定制性和可扩展性在同
类框架中都是首屈一指的,它已经得到成百上千的商用项目验证,例如 Hadoop 的 RPC 框
架 Avro 使用 Netty 作为通信框架。很多其它业界主流的 RPC 和分布式服务框架,也使用
Netty 来构建高性能的异步通信能力。
Netty 的优点总结如下:
API 使用简单,开发门槛低;
功能强大,预置了多种编解码功能,支持多种主流协议;
定制能力强,可以通过 ChannelHandler 对通信框架进行灵活的扩展;
性能高,通过与其它业界主流的 NIO 框架对比,Netty 的综合性能最优;
社区活跃,版本迭代周期短,发现的 BUG 可以被及时修复,同时,更多的新功能会被
加入;
经历了大规模的商业应用考验,质量得到验证。在互联网、大数据、网络游戏、企业应
用、电信软件等众多行业得到成功商用,证明了它完全满足不同行业的商用标准。
正是因为这些优点,Netty 逐渐成为 Java NIO 编程的首选框架。