hello啊,各位观众姥爷们!!!本baby今天来报道了!哈哈哈哈哈嗝
维度 | 并发(Concurrency) | 并行(Parallelism) |
---|---|---|
核心 | 处理多任务的能力(不要求同时执行) | 同时执行多任务(物理上同步) |
资源依赖 | 单核即可实现(通过时间片切换) | 必须依赖多核/多机(如GPU、分布式集群) |
目标 | 提高资源利用率(如IO阻塞时切换任务) | 缩短任务完成时间(拆分任务并行计算) |
synchronized
、ReentrantLock
(避免竞态条件)。AtomicInteger
)、Disruptor环形队列。ForkJoinPool
、C++的OpenMP。问题类型 | 并发 | 并行 |
---|---|---|
常见挑战 | 死锁、线程切换开销、资源竞争 | 任务拆分不均、通信延迟、同步成本高 |
优化手段 | 协程(减少上下文切换)、异步IO | 负载均衡(如Work Stealing算法) |
并发(交替执行)
# 单核CPU通过时间片处理两个线程
import threading
def task1():
while True: print("Task1")
def task2():
while True: print("Task2")
threading.Thread(target=task1).start()
threading.Thread(target=task2).start()
# 输出交替打印,但实际任一时刻只有一个线程在运行
并行(同时执行)
# 多核CPU同时执行两个进程
from multiprocessing import Process
def task1():
while True: print("Task1")
def task2():
while True: print("Task2")
if __name__ == '__main__':
Process(target=task1).start()
Process(target=task2).start()
# 两个进程可能同时在不同核心上运行