基础知识:线程,进程。多进程,多线程。并发,并行的区别
2016-05-12 17:33
525 查看
一:线程与进程
1.概念
线程:是程序执行流的最小单元,是系统独立调度和分配CPU(独立运行)的基本单位。进程:是资源分配的基本单位。一个进程包括多个线程。
2.区别:
1.线程与资源分配无关,它属于某一个进程,并与进程内的其他线程一起共享进程的资源。2.每个进程都有自己一套独立的资源(数据),供其内的所有线程共享。
3.不论是大小,开销线程要更“轻量级”
4.一个进程内的线程通信比进程之间的通信更快速,有效。(因为共享变量)
二.多线程与多进程
多线程:同一时刻执行多个线程。用浏览器一边下载,一边听歌,一边看视频,一边看网页。。。多进程:同时执行多个程序。如,同事运行YY,QQ,以及各种浏览器。
三.并发与并行
并发当有多个线程在操作时,如果系统只有一个CPU,则它根本不可能真正同时进行一个以上的线程,它只能把CPU运行时间划分成若干个时间段,再将时间 段分配给各个线程执行,在一个时间段的线程代码运行时,其它线程处于挂起状。.这种方式我们称之为并发(Concurrent)。并行:当系统有一个以上CPU时,则线程的操作有可能非并发。当一个CPU执行一个线程时,另一个CPU可以执行另一个线程,两个线程互不抢占CPU资源,可以同时进行,这种方式我们称之为并行(Parallel)。
强烈注意:多核,多cup,多机是不同的概念。
相关文章推荐
- 绕过苹果审核机制
- 正则表达式
- Redis主从环境配置
- elk平台搭建
- C# 后台请求web服务方法
- POI XSSF与HSSF的 使用区别
- Java 1.5并发包之一:Lock
- Ecshop与Jquery冲突的解决方案2
- tomcat8设置https连接
- mysql死锁示例
- 三种线性排序算法: 计数排序、桶排序与基数排序
- 卡特兰数相关问题
- WP8.1简单项目 《在线词典》
- dmalloc用法快速入门
- js事件行为
- IntelliJ IDEA启动web项目时突然变慢的原因
- zkfc报错:java.net.NoRouteToHostException: No route to host
- nginx学习笔记之一:nginx介绍及其编译安装
- 酷炫的下载的进度动画2
- java中的常见异常及错误和处理方法