对于线程这块的知识还是有些薄弱,写下这篇博客记录自己这段时间对于多线程的学习。
进程与线程
- 进程是指一个程序在计算机上运行时,全部的计算资源的合集;
- 线程是程序的最小执行单位,包含计算资源,任何一个操作的响应都是线程来完成的;
- 多线程是指多个线程并发执行;
- 多线程虽然能够提升程序的运行效率,但是消耗的资源更多,所以线程并不是越多越好。
硬件线程与软件线程
1.硬件线程
核处理器带有一个以上的物理内核–物理内核是真正的独立处理单元,多个物理内核使得多条指令能够同时并行运行。硬件线程也称为逻辑内核,一个物理内核可以使用超线程技术提供多个硬件线程。所以一个硬件线程并不代表一个物理内核;
2.软件线程
系统中每个运行的程序都是一个进程,每一个进程都会创建并运行一个或多个线程,这些线程称为软件线程。硬件线程就像是一条泳道,而软件线程就是在其中游泳的人。
并发与并行
并发与并行通过多线程执行的话,会基于CPU的资源进行执行。资源多的时候每个线程都可以分配到CPU资源,便可以实现并行;资源少的时候,每个CPU需要处理多个线程,便是并发。
对于CPU资源的调配,我们是无权参与的。
多线程是多个线程并发执行
1.并发
并发上限代表事件上限
- 每个线程并不是同一时间执行,而是通过竞争资源后执行。
- 多个几乎同时到达的请求看起来像同一时间处理
- 线程竞争CPU资源,从而得到执行资源。同一时间,一个CPU的资源只能分配给一个线程
2.并行
并行代表同时处理的事件数
- 每个线程真正意义上的同时执行,无需竞争CPU资源。