01-线程的定义和意义

线程的定义

  • 是轻量级的进程,线程的创建和切换成本比进程低

  • 同一进程中的多条线程将共享该进程中的全部系统资源,如虚拟地址空间,文件描述符和信号处理等等

  • 是操作系统能够进行运算调度的最小单位

  • java程序至少有一个线程main,main线程由JVM创建

为什么要有多线程

  • 可以充分利用多处理器核心

  • 更快的响应时间,可以将数据一致性要求不强的工作交给别的线程做

  • 更好的编程模型,例如可以使用生产者消费者模型进行解耦

并发编程需要注意的问题

上下文切换

cpu通过时间分片来执行任务,多个线程在cpu上争抢时间片执行,线程切换需要保存一些状态,再次切换回去需要恢复状态,此为上下文切换成本。

因此并不是线程越多越快,频繁的切换会损失性能

减少上下文切换的方法:

  • 无锁并发编程:例如把一堆数据分为几块,交给不同线程执行,避免用锁

  • 使用CAS算法:用自旋不用锁可以减少线程竞争切换,但是可能会更加耗cpu

  • 使用最少的线程

  • 使用协程:在一个线程里执行多个任务

死锁

死锁就是线程之间因争夺资源处理不当出现的相互等待现象

避免死锁的方法:

  • 避免一个线程同时获取多个锁

  • 避免一个线程在锁内同时占用多个资源,尽量保证每个锁只占用一个资源

  • 尝试使用定时锁,使用lock.tryLock(timeout)来替代使用内部锁机制

  • 对于数据库锁,加锁和解锁必须在一个数据库连接里,否则会出现解锁失败的情况

资源限制

程序的执行需要资源,比如数据库连接、带宽,可能会由于资源的限制,多个线程并不是并发,而是串行,不仅无优势,反而带来不必要的上下文切换损耗

常见资源限制

  • 硬件资源限制

    • 带宽

    • 磁盘读写速度

    • cpu处理速度

  • 软件资源限制

    • 数据库连接数

    • socket连接数

应对资源限制

  • 集群化,增加资源

  • 根据不同的资源限制调整程序的并发度,找到瓶颈,把瓶颈资源搞多一些,或者根据这个瓶颈调整线程数

最后更新于