Java多线程总结

Posted chaunqi1995

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java多线程总结相关的知识,希望对你有一定的参考价值。

1.多线程开发又叫JUC开发(java.util.concurrent),至少5年以上才能涉及到,面试阿里常问

2.线程和进程有什么区别?

1)进程是资源(CUP,内存)分配的最小单位,线程是程序执行的最小单位。

2)一个程序至少有一个进程,一个进程至少有一个线程。

3.多线程的特点

三高:高并发,高可用,高性能。

4.线程核心概念

1)线程就是独立的执行路径。

2)在程序执行时,即使没有自己创建线程,后台也会存在多个线程,如GC线程,主线程。

3)main()称之为主线程,为系统的入口点,用于执行整个程序。

4)在一个进程中,如果开辟了多个线程,线程的运行由调度器安排调度,调度器是与操作系统紧密相关的,先后顺序是不能人为干预的。

5)对同一份资源操作时,会存在资源抢夺的问题,需要加入并发控制。

6)线程会带来额外的开销,如CUP调度时间,并发控制开销。

7)每个线程在自己的工作内存交互,加载和存储主内存控制不当会造成数据不一致。

5.Java中哪个方法必须在方法内部处理异常并且不能抛出?

多线程实现方法中,继承Thread的Run()方法是不能进行方法内部处理异常并且不能抛出的。

5.多线程的实现方式

1)继承Thread

public class MyThread extends Thread{
    
    @Override
    public void run() {
        for (int i = 1; i <= 50; i++) {
            System.out.println(Thread.currentThread().getName() + "---" + i);
        }
    }

}
public class Test {

    public static void main(String[] args) {
        MyThread m1 = new MyThread();
        MyThread m2 = new MyThread();
        m1.start();
        m2.start();
    }

}    

2)实现Runnable接口(推荐使用)

public class MyThread implements Runnable {
    
    @Override
    public void run() {
        for (int i = 1; i <= 50; i++) {
            System.out.println(Thread.currentThread().getName() + "---" + i);
        }
    }

}
public class Test {
public static void main(String[] args) { MyThread m = new MyThread(); Thread t1 = new Thread(m); Thread t2 = new Thread(m); t1.start(); t2.start(); }
}

3)实现Callable接口

<1>

/**
 * 实现Callable接口.相较于实现Runnable接口的方式,方法可以有返回值,并且可以抛出异常
 * 执行 Callable 方式,需要 FutureTask 实现类的支持,用于接收运算结果。  FutureTask 是  Future 接口的实现类
 * @author 奇
 *
 */
public class ThreadDemo implements Callable<Integer> {

    @Override
    public Integer call() throws Exception {
        int sum = 0;
        for (int i = 0; i < 50; i++) {
            sum += i; 
        }
        return sum;
    }

}
public class TestCallable {
public static void main(String[] args) { ThreadDemo td = new ThreadDemo(); //1.执行 Callable 方式,需要 FutureTask 实现类的支持,用于接收运算结果。 FutureTask<Integer> result = new FutureTask<Integer>(td); Thread t = new Thread(result); t.start(); //2.接收线程运算后的结果 try { //FutureTask 可用于 闭锁 类似于CountDownLatch的作用,在所有的线程没有执行完成之后这里是不会执行的 Integer sum = result.get(); System.out.println(sum); System.out.println("------------------------------------"); } catch (InterruptedException e) { e.printStackTrace(); } catch (ExecutionException e) { e.printStackTrace(); } }
}

<2>(面试中推荐说这个)

/**
 * 实现Callable接口,他有泛型
 * 实现Callable的call()方法
 * call()方法与run()方法的区别:有返回值,可以对异常类型进行抛出(throws)
 * run方法没有返回值,遇到异常必须try-catch处理
 * @author 奇
 *
 */
public class Test04 implements Callable<Integer> {
    
    @Override
    public Integer call() throws Exception {
        int sum = 0;
        for (int i = 0; i < 50; i++) {
            sum += i; 
        }
        return sum;
    }
    
    /**
     * 1.创建服务(线程池,里面放一个线程)
     * 2.提交线程
     * 3.获得结果对象
     * 4.通过结果对象的get方法来获得结果
     * 5.关闭服务
     * @param args
     * @throws InterruptedException
     * @throws ExecutionException
     */
    public static void main(String[] args) throws InterruptedException, ExecutionException {
        //与线程池有关
        Test04 t = new Test04();
        //创建一个线程池,也就是创建一个服务,线程池里面放了1个线程
        ExecutorService ser = Executors.newScheduledThreadPool(1);
        //提交执行
        //提交一个返回值的任务用于执行,返回一个表示任务的计算结果
        //Future表示异步计算结果,只能用get方法get()来拿到这个结果
        Future<Integer> res = ser.submit(t);
        //获得结果
        Integer r1 = res.get();
        System.out.println(r1);
        //关闭服务操作
        ser.shutdownNow();
    }

}

6.线程中常用的方法

1)获取线程名称:Thread.currentThread().getName();

2)设置线程名称:

<1>Thread.currentThread().setName("要设置的名字");

<2>实现Runnable()接口的时候new Thread(new StrartThread() , "要设置的名字").start();

7.使用start()方法会立即启动线程吗?

不会,他会通知CPU,CPU进行调度,说的专业点就叫时间片。









以上是关于Java多线程总结的主要内容,如果未能解决你的问题,请参考以下文章

经验总结:Java高级工程师面试题-字节跳动,成功跳槽阿里!

学习java第19天个人总结

号称史上最全Java多线程与并发面试题总结—基础篇

java多线程总结

Java多线程-线程池的使用与线程总结(狂神说含代码)

第十周java学习总结