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方法)运行–>死亡
本文深入探讨了并行与并发的区别,守护线程的作用,创建线程的多种方式,Runnable与Callable接口的不同之处,以及线程的五种基本状态,为理解并发编程提供了全面的视角。
2950

被折叠的 条评论
为什么被折叠?



