扫码关注公众号

多线程和并发之多线程的创建
05-27
165观看
01

关于多线程和多线程编程,以下哪些说法正确的()

正确答案是A、B、DA.不同进程有不同的页表,对应着不同的物理地址空间,因此进程间通信需要使用IPC或者socket。而线程可以共享了进程的地址空间,所以A对。B.与A的原因类似,进程创建是操作系统要为它分配内存,销毁时收回。而线程不需要,所以线程的创建与销毁更快。B对。C.当存在大量计算需求的时候,比如需要并发计算时,会频繁的切换进程/线程。而线程切换的成本小于进程,因此选择多线程模型。C对。D.同一进程中的不同线程共享地址空间,所以一个线程挂掉可能会导致整个进程挂掉。D对。

来自:多线程和线程池-多线程的创建和执行
02

java线程的状态不包含哪种()

正确答案是D线程在一定条件下,状态会发生变化。线程一共有以下几种状态:1、新建状态(New):新创建了一个线程对象。2、就绪状态(Runnable):线程对象创建后,其他线程调用了该对象的start()方法。该状态的线程位于“可运行线程池”中,变得可运行,只等待获取CPU的使用权。即在就绪状态的进程除CPU之外,其它的运行所需资源都已全部获得。3、运行状态(Running):就绪状态的线程获取了CPU,执行程序代码。4、阻塞状态(Blocked):阻塞状态是线程因为某种原因放弃CPU使用权,暂时停止运行。直到线程进入就绪状态,才有机会转到运行状态。   阻塞的情况分三种:(1)、等待阻塞:运行的线程执行wait()方法,该线程会释放占用的所有资源,JVM会把该线程放入“等待池”中。进入这个状态后,是不能自动唤醒的,必须依靠其他线程调用notify()或notifyAll()方法才能被唤醒,(2)、同步阻塞:运行的线程在获取对象的同步锁时,若该同步锁被别的线程占用,则JVM会把该线程放入“锁池”中。(3)、其他阻塞:运行的线程执行sleep()或join()方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入就绪状态。5、死亡状态(Dead):线程执行完了或者因异常退出了run()方法,该线程结束生命周期。

来自:多线程和线程池-线程池
03

java线程常见的创建方式有哪四种?

1继承Thread类并重写run方法。实现简单,但不符合里氏替换原则,不可以继承其他类。2实现Runnable接口并重写run方法。避免了单继承局限性,编程更加灵活,实现解耦。3实现Callable接口并重写call方法。可以获取线程执行结果的返回值,并且可以抛出异常。4通过Executors创建线程池

来自:多线程和线程池-线程池
04

java线程池里核心线程数和最大线程数的区别是什么?

这道题考查的是线程池的运行策略,要理解两个参数:corePoolSize:核心线程数;maximunPoolSize:最大线程数每当有新的任务到线程池时,第一步:先判断线程池中当前线程数量是否达到了corePoolSize,若未达到,则新建线程运行此任务,且任务结束后将该线程保留在线程池中,不做销毁处理,若当前线程数量已达到corePoolSize,则进入下一步;第二步:判断工作队列(workQueue)是否已满,未满则将新的任务提交到工作队列中,满了则进入下一步;第三步:判断线程池中的线程数量是否达到了maxumunPoolSize,如果未达到,则新建一个工作线程来执行这个任务,如果达到了则使用饱和策略来处理这个任务。注意:在线程池中的线程数量超过corePoolSize时,每当有线程的空闲时间超过了keepAliveTime,这个线程就会被终止。直到线程池中线程的数量不大于corePoolSize为止。

来自:多线程和线程池-线程池
课程
专栏
Java 实现多线程的四种方式 超详细
csdn
Java 多线程:彻底搞懂线程池
当我们线程创建过多时,就有必要使用线程池的技术
csdn
线程池
【校招VIP】Java多线程创建与运行
csdn
多线程创建与运行
java语言-多线程和线程池-多线程的创建和执行
3专栏
1课程
4 试题