详解mvc执行流程

目录

写在前面

执行流程

总结


写在前面

对于javaer而言,使用的基本上是基于springmvc,使用的是springboot也好,也是基于springmvc的,而springmvc是基于servlet的,对于从事与web开发的同学(有一定追求的),仅仅对于会用是远远不够,我们还是要知道其中的处理逻辑,以便于更好的开发出好的项目。

执行流程

1:首先调用的就是处理业务逻辑方法 service

org.springframework.web.servlet.FrameworkServlet#service,发现走的是super.service(request, response);

2:调用父类的service方法,里面根据不同的请求类型调用不同的方法,下面以get为例

javax.servlet.http.HttpServlet#service(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse),

3:调用处理请求的方法

org.springframework.web.servlet.FrameworkServlet#doGet

4:调用处理请求接口

org.springframework.web.servlet.FrameworkServlet#processRequest

5:调用doService处理方法,来真正处理请求,service->doService spring代码的尿性

org.springframework.web.servlet.FrameworkServlet#doService

!!!发现doService是个抽象方法,并没有具体的实现

6:这时候才真正的进入到doService,在子类中实现,校验一系列的参数

org.springframework.web.servlet.DispatcherServlet#doService

7:放入分发器中去处理

org.springframework.web.servlet.DispatcherServlet#doDispatch

7.1:是否是文件类型

org.springframework.web.servlet.DispatcherServlet#checkMultipart

7.2:查找处理器映射器

org.springframework.web.servlet.DispatcherServlet#getHandler

7.3:查找处理器适配器

org.springframework.web.servlet.DispatcherServlet#getHandlerAdapter

7.4:查找视图

org.springframework.web.servlet.HandlerAdapter#handle

7.5:填充视图 -- 后置处理器

org.springframework.web.servlet.HandlerExecutionChain#applyPostHandle

7.6:处理分发结果

org.springframework.web.servlet.DispatcherServlet#processDispatchResult

总结

其实springmvc的执行流程相对来说还是比较简单的, 大致的流程是

service->doGet(doPost)->doService->doDispatch->校验一些参数->寻找对应的处理器

TIPS:在执行流程的第五条中,特别有意思的是,org.springframework.web.servlet.FrameworkServlet#doService,这个方法是一个空的,只是抛出了一个异常,但是这种姿势在sprin的源码中,或者是jdk的源码中经常出现的,把有些代码的实现放入到了子类中去是延迟实现,而这里是放到org.springframework.web.servlet.DispatcherServlet#doService中去实现的,这种方法用到了"模板方法"的设计模式,在AQS中的  tryAcquire (int arg)     tryAcquireShared(int arg)就用到了这种方式,其实我们在研读源码的同时,可以学习到好多新的东西,如果是之前学过的话,回过头来一看,才恍然大悟,有着一定的借鉴作用,最后希望每个人都可以不忘初衷,砥砺前行。

 

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spark的执行流程可以分为以下几个步骤。 首先,任务调度器(TaskScheduler)将序列化好的任务递交给执行器(Executor)。执行器将任务放入线程池中进行运行。 其次,当程序触发Action算子时,就会产生一个作业(Job),并调用DagScheduler中的runjob方法来提交任务。 接着,Master收到应用程序的注册请求后,根据自己的资源调度算法,在Spark集群的worker上启动一个或多个Executor进程。 然后,DagScheduler根据作业的依赖关系生成有向无环图(DAG),确定任务的执行顺序。 之后,任务分发器(TaskSetManager)将任务分发给Executor,并监控任务的执行状态。 每个Executor在执行任务之前会将依赖的数据分片(RDD)从存储节点(如HDFS)中读取到内存中。 任务执行器(TaskRunner)根据任务的类型(如map、reduce等)执行计算并生成结果。 最后,计算结果会被返回给Driver程序,供后续处理或输出。 总结起来,Spark的执行流程包括任务调度、作业提交、资源分配、任务分发、数据读取、任务执行和结果返回等步骤。这些步骤保证了Spark的高效计算和数据处理能力。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Spark执行流程详解](https://blog.csdn.net/qq_42456324/article/details/124499170)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值