进程、线程、微线程、并发、并行、同步、异步、阻塞、非阻塞
来源:互联网 发布:ubuntu系统 流畅 配置 编辑:程序博客网 时间:2024/05/22 03:03
进程(process):进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位。
线程(thread):线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位.线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的全部资源。
一个线程可以创建和撤销另一个线程;同一个进程中的多个线程之间可以并发执行。
微线程:又叫协程。 tasklet运行在伪并发中,使用channel机制进行同步数据交换。python中的greenlet提供了微线程的操作。不同于多线程,它给我们提供了一种更加轻量的异步编程模式。
协程(Coroutine)提供了不同于线程的另一种方式,它首先是串行化的。其次,在串行化的过程中,协程允许用户显式释放控制权,将控制权转移另一个过程。释放控制权之后,原过程的状态得以保留,直到控制权恢复的时候,可以继续执行下去。所以协程的控制权转移也称为“挂起”和“唤醒”。
并发(concurrency):并发是指二个和多个事件在同一时间间隔内发生。并发是在逻辑层面上的同时工作。
并行(parallelism):并行是指二个或多个事件在同一时刻发生。 并行是在物理层面上的同时工作。
同步(synchronous):在发出一个功能调用时,在没有得到结果之前,该调用就不返回。
异步(asynchronous):异步的概念和同步相对。当一个异步过程调用发出后,调用者不能立刻得到结果。实际处理这个调用的部件在完成后,通过状态、通知和回调来通知调用者。
阻塞:阻塞调用是指调用结果返回之前,当前线程会被挂起。函数只有在得到结果之后才会返回。
非阻塞:非阻塞和阻塞的概念相对应,指在不能立刻得到结果之前,该函数不会阻塞当前线程,而会立刻返回。
要注意同步和异步 与 阻塞和非阻塞 这两组概念之间的区别。
同步IO和异步IO的区别就在于:数据拷贝的时候进程是否阻塞。
阻塞IO和非阻塞IO的区别就在于:应用程序的调用是否立即返回。
- 进程、线程、微线程、并发、并行、同步、异步、阻塞、非阻塞
- 菜鸟备忘录[通识]——线程&进程;并行&并发;同步&异步and阻塞&非阻塞 必看必晕
- 并发,同步,异步,阻塞,非阻塞,线程
- 线程、进程、同步、异步、阻塞、非阻塞
- 并发 并行 同步 异步 多线程 多进程 阻塞 非阻塞
- 同步,异步,阻塞,非阻塞,并发,并行
- 并发 并行 同步 异步 阻塞 非阻塞
- 阻塞 非阻塞 同步 异步 线程 进程 任务
- 并发和并行,同步和异步,阻塞和非阻塞
- 并发 并行 同步 异步 多线程 阻塞 非阻塞的区别
- 并发 并行 同步 异步 多线程 阻塞 非阻塞的区别
- Java<并发,并行>,<同步,异步>,<阻塞,非阻塞>
- 并发 并行 同步 异步 多线程 阻塞 非阻塞的区别
- 深入理解并发/并行,阻塞/非阻塞,同步/异步
- 并发 并行 阻塞 非阻塞 同步 异步 互斥
- 【计算机原理】并发 并行 异步 同步 阻塞 非阻塞
- 深入理解并发/并行,阻塞/非阻塞,同步/异步
- 同步异步,线程,阻塞
- Mysql 相关命令
- Java泛型-类型擦除
- Axure支付宝首页广告轮播
- 解决Eclipse java build path中Web App Libraries无法自动找到WEB-INF的lib目录
- poj1325 Machine Schedule
- 进程、线程、微线程、并发、并行、同步、异步、阻塞、非阻塞
- 获取系统时间以及汉字转换为Unicode
- 使用VS Code 开发.NET Core 应用程序 部署到Linux 跨平台
- json
- 阿里面试题总结
- 示例代码
- 利用Java反射机制取代switch判断
- 敏捷开发之Scrum扫盲篇
- 图的割点、桥与双连通分支