总结
在这里,由于面试中MySQL问的比较多,因此也就在此以MySQL为例为大家总结分享。但是你要学习的往往不止这一点,还有一些主流框架的使用,Spring源码的学习,Mybatis源码的学习等等都是需要掌握的,我也把这些知识点都整理起来了
演示:
package com;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.Date;
import javax.servlet.AsyncContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
- Servlet implementation class AsyncDemoServlet
*/
@WebServlet(urlPatterns = “/AsyncDemoServlet”, asyncSupported = true)
public class AsyncDemoServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
- @see HttpServlet#HttpServlet()
*/
public AsyncDemoServlet() {
super();
// TODO Auto-generated constructor stub
}
/**
-
@see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse
-
response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType(“text/html; charset=UTF-8”);
PrintWriter out = response.getWriter();
out.print(“
进入servlet时间” + new Date().toLocaleString() + “
”);AsyncContext asctx = request.startAsync();
new Thread(new Executor(asctx)).start();
out.print(“
退出servlet时间” + new Date().toLocaleString() + “
”);out.flush();
}
/**
-
@see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse
-
response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// TODO Auto-generated method stub
doGet(request, response);
}
}
class Executor implements Runnable {
private AsyncContext ctx = null;
public Executor(AsyncContext asCtx) {
ctx = asCtx;
}
@Override
public void run() {
try {
Thread.sleep(10000);
PrintWriter out = ctx.getResponse().getWriter();
out.print(“
子线程执行完毕” + new Date().toLocaleString() + “
”);out.flush();
ctx.complete();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
其中:
(1)在”WebServlet“注释中配置属性支持异步操作:@WebServlet(urlPatterns = "/AsyncDemoServlet", asyncSupported = true)
;
(2)创建子线程构建耗时操作:
class Executor implements Runnable {
private AsyncContext ctx = null;
//借助构造方法进行传参
public Executor(AsyncContext asCtx) {
ctx = asCtx;
}
@Override
//线程真正的操作在run方法中
总结
大型分布式系统犹如一个生命,系统中各个服务犹如骨骼,其中的数据犹如血液,而Kafka犹如经络,串联整个系统。这份Kafka源码笔记通过大量的设计图展示、代码分析、示例分享,把Kafka的实现脉络展示在读者面前,帮助读者更好地研读Kafka代码。
麻烦帮忙转发一下这篇文章+关注我
373582689)]