Java并发编程的艺术-并发编程的挑战

并发编程的挑战

1、上下文切换

CPU通过给每个线程分配CPU时间片来实现多线程机制。时间片是CPU分配给各个线程的时间,这个时间非常短,一般是几十毫秒。 CPU通过时间片分配算法来循环执行任务,当前任务执行一个时间片后会切换到下一个任务,但是 ,在切换前会保存上一个任务的状态,以便下次切换回这个任务时,可以再加载这个任务的状态。所以任务从保存到再加载的过程就是一次上下文切换。

1.1、如何减少上下文切换

  • 无锁并发编程
    多任务处理数据时,可以用一些办法避免使用锁,如将数据ID按照HASH算法取模分段,不同的线程处理不同段的数据。
  • CAS算法
  • 使用最少线程
    任务很少时,避免创建不需要的线程

2、死锁

3、资源限制的挑战

你可能感兴趣的:(读书笔记,java,多线程)