Struts2的流程(一)
Struts2的流程分为三个步骤:
第一步,在服务器启动的时候,执行init方法,init方法做了两件事:第一件事就是解析N多配置文件,比如struts-default.xml,struts-Plugin.xml,default.properties,struts.xml......第二件事就是静态注入(把上述配置文件的bean解析完),还有一点就是静态注入都是通过dispatcher.getContainer().getInstance获取的,通过静态注入获取ValueStack
第二就是过滤器,过滤器的第一个任务(编码就不说了啊,在web中最激动人心的技术就是过滤器和监听器....)是createActionContext,在创建ActionContext时,并没有创建action。创建ActionContext做的工作:1.在actionContext中存在一个Map<String, Object>2.ValueStack stack = dispatcher.getContainer().getInstance(ValueStackFactory.class).createValueStack();这一行代码意味着在创建ActionContext时ValueStack就创建了,通过静态注入创建ValueStack的实现类:OgnlValueStack . 3.ValueStack中的map栈跟ActionContext中的Map是一样的。4.通过ActionContext.setContext(ctx);就把actionContext放到ThreadLocal中,这样就数据安全了(ThreadLocal这个类非常重要,java面试中的高频考点,最下面会说到这个类)ValueStack的创建发生在action创建中,值栈在前(ActionContext在action之前被创建)
第三ActionProxy的创建:1.ActionProxy proxy= config.getContainer().getInstance(ActionProxyFactory.class).createActionProxy(namespace, name, method, extraContext, true, false);2.在createActionProxy的时候,创建了DefaultActionInvocation。ActionInvocation inv = new DefaultActionInvocation(extraContext, true);在创建ActionProxy的时候就已经执行了invocation的init方法(invocation的init方法做的事情:创建所有的action和所有拦截器),然后在执行invocation中的invoke方法(invoke方法执行了所有的interceptor,执行了当前请求的action,执行了结果集)
关于java中ThreadLocal的一些说法:
1.ThreadLocal存放的值是线程封闭的,线程间互斥,主要用于线程共享一些数据,避免通过参数来传递;
2.线程的角度看,每个线程都持有一个对其线程局部变量副本的隐式引用,只要线程是活动的并且ThreadLocal实力是可以访问的;在线程消失之后,其局部线程实例的所有副本都会被垃圾回收;
3.在THreadLocal类中有一个Map,用于存储每一个线程的变量的副本;
4.对于多线程资源共享的问题,同步机制采用了以时间换空间的方式,而ThreadLocal采用了以空间换时间的方式;
5.ThreadLocal是一种多线程间并发访问变量的解决方案,它完全不提供锁,以空间换时间为每个线程提供变量的独立副本以保障线程安全;
6.在高并发量或者锁竞争激烈的场合,使用ThreadLocal可以在一定程度上减少锁竞争。
(以上前4点是牛客网上的关于ThreadLocal的一个题目,后面2点是我在书上看到的)