Java多线程面试题24-28

本文深入探讨了并行与并发的区别,守护线程的作用,创建线程的多种方式,Runnable与Callable接口的不同之处,以及线程的五种基本状态,为理解并发编程提供了全面的视角。

24.并行和并发有什么区别?

1.并行指的是同一时刻同时执行多个程序(多个cpu执行多个程序)
2.并发:指的是同一时间间隔内同时执行多个程序(一个cpu同时执行多个,只 是看起来是多个,实际上是cpu轮流切换执行多个程序);

总结:并发是为了提高cpu的执行效率,就是cpu的利用率

25.守护线程是什么?

线程宏观分类:
守护线程:垃圾回收线程,是最经典的守护线程
用户线程:用户自定义的线程

守护线程:指的是服务线程,为其他(用户自定义的线程)服务的,比如当一个程序的main方法结束了,守护线程不会立即结束(因为可能还有其他的自定义线程在运行,只要有自定义线程在运行守护线程就不会结束),当jvm关闭的时候,这个时候守护线程才会结束;

26:创建线程有哪几种方式?

  • 1.继承Thread类,重写run方法
  • 2.实现Runnable接口,实现run方法,把实现的方法当做Thread的构造参数实现多线程
  • 3.实现Runnable接口,调用call()方法和线程池实现多线程
  • 4.实现Runnable接口,调用call()方法,通过FutureTask包装器容器实现

27:.说一下 runnable 和 callable 有什么区别?

  • 1.runnable调用run方法,无法通过throws抛出异常,只能通过UnCheckException在内部进行处理,
    callable调用call方法,可以直接抛出异常

  • 2.Runnable调用run方法没有返回值,Callable调用call方法有返回值,返回值标示任务执行的结果,但是获取这个值是通过excutor.submit(myCallable)返回的对象 FutureTask通过调用get方法获取到 的结果,这个get方法是一个阻塞方法,只有当程序执行完成才会获取到结果

  • 3.Runnable可以通过Thread的构造参数实现多线程,还可以通过线程池实现
    Thread thread=new Thread(myRunnable);构造参数
    excutor.submit(myRunnable);线程池
    Callable 只能通过线程池实现多线程
    executor.submit(myCallable);线程池

28:线程有哪些状态?

图片: ![Alt]线程间的状态转换图

线程的5种状态:新建,就绪,运行,阻塞,死亡
  • 1:新建(run方法)–>就绪(获得执行权)–>运行(start方法)—>死亡
  • 2:新建(run方法)–>就绪(获得执行权)–>(失去执行权)就绪—>(start方法)运行–>死亡
  • 3:新建(run方法)–>就绪(获得执行权)–>其他阻塞(sleep,join,io)–>(sleep时间到,join结束,io完成)就绪–>(start方法)运行–>死亡
  • 4:新建(run方法)–>就绪(获得执行权)–>同步阻塞(synchronized)–>(锁可用)就绪–>(start方法)运行–>死亡
  • 5:新建(run方法)–>就绪(获得执行权)–>等待阻塞(wait)–>同步阻塞(synchronized)–>(锁可用)就绪–>(start方法)运行–>死亡
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值