多线程:专题

本文详细介绍了多线程的基本概念,包括线程、进程、协程的区别,上下文切换,线程安全,Java多线程的实现方式,线程池的工作原理,以及并发编程中的同步和锁机制。此外,还探讨了JMM内存模型,线程间的通信和协作,以及常见的并发工具如CyclicBarrier、CountDownLatch和Semaphore。最后,文章提到了阻塞队列在生产者消费者模型中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

说明

下面是多线程面试题的总结,后续碰到重点的新题型会不断继续更新。

一、基本概念

多线程有什么用?

单核:比如一个线程使用的时候CPU计算,IO空闲,IO操作时候CPU空闲,当CPU空闲时,执行另一个线程IO操作对方迟迟没有返回,这时CPU就空闲,而用户阻塞。为了防止阻塞,我们开启多线程。这样提高CPU利用率。
多核,提高CPU利用率,多核分别执行多个线程。比如一个复杂任务,让多核并行,提高效率。

**问题:**内存泄漏、上下文切换、死锁还有受限于硬件和软件的资源闲置问题。

线程、进程、协程的区别

进程是系统分配资源都基本单元,有独立的内存空间 比如一个迅雷应用程序,既不共享堆,亦不

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值