Java 多线程异步处理demo

java中实现多线程

1)继承Thread,重写里面的run方法

2)实现runnable接口
通过源码发现:
第一种方法说是继承Tread然后重写run方法,通过查看run方法的源码,发现run方法里面调用是runnable接口中抽象的run()方法。
既然这样不如直接使用第二种方法,使用第二种方法,第一 java没有单继承的限制,第二 还可以隔离代码

言归正传下面是第二种方法的demo

1.处理业务代码

 //根据传参打印对应的名字
private void printName(String name) throws Exception{
System.out.println(name);
}

2.创建内部类实现Runnable接口

 private class PrintName implements Runnable{
private String name; public PrintName(String name){
this.name = name;
} //Runnable接口中的抽象方法
@Override
public void run(){
try {
printName(name);
}catch (Exception e){
System.out.println(e);
} }
}

3. 创建线程对象并执行线程

 private void createThead() throws Exception {
String name = "hello world";
Thread thread = new Thread(new PrintName(name));
thread.start();
}

现在附上全部代码:

 package com.ieou.demo.controller;

 import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; @RestController
@RequestMapping("/")
public class Demo1Controller { /** java 多线程 异步实现demo */ //第一步 处理业务代码
//根据传参打印对应的名字
private void printName(String name) throws Exception{
System.out.println(name);
} //创建内部类实现Runnable接口
private class PrintName implements Runnable{
private String name; public PrintName(String name){
this.name = name;
} //Runnable接口中的抽象方法
@Override
public void run(){
try {
printName(name);
}catch (Exception e){
System.out.println(e);
} }
} //第三部 创建线程对象
private void createThead() throws Exception {
String name = "hello world";
Thread thread = new Thread(new PrintName(name));
thread.start();
} @GetMapping("/name")
public String findName() throws Exception{
System.out.println("name1");
createThead();
System.out.println("name3");
return "1";
}

执行结果:Java 多线程异步处理demo

上一篇:redis的安装部署启动停止<17.3.21已更新>


下一篇:[AirFlow]AirFlow使用指南一 安装与启动