process vs thread

http://blog.csdn.net/mishifangxiangdefeng/article/details/7588727

6.进程与线程的区别:系统调度是对进程还是线程,线程与进程共享的内存空间、公共地址空间等;

A.操作系统只调度进程,不调度线程

B.线程共享内存地址空间,进程不共享

C.线程间可共享内存数据,但进程不可以

D.进程可以通过IPC通信,但线程不可以
7.内存管理:段页式管理,地址映射表是?(操作系统方面的知识也不能掉以轻心呀)

A. 每个作业或进程一张段表,一张页表

B. 每个作业或进程的每个段一张段表,一张页表

C. 每个作业或进程一张段表,每个段一张页表

D. 每个作业一张页表,每个段一张段表

多线程编程,如何安全退出线程。

比较mutex和临街区之间的区别,并说明其使用场景。

spinlock

什么是用户级线程和内核级线程?区别。

内核线程:线程切换由内核控制,切换的时候,要从用户态进入内核态,切换完毕要从内核态返回用户态;可以很好的利用smp,即利用多核cpu。windows线程就是这样的。
用户级线程:用户态程序自己调度线程切换,不需要内核干涉,少了进出内核态的消耗,但不能很好的利用smp。目前linux pthread大体是这么做的。

process vs thread

一个program可以由多个process,一个process可以由多个thread,其中一个是main thread。

process有独立的虚拟地址空间,一个process异常不会影响其他process

thread共享process的虚拟地址空间和所有资源,一个thread异常导致其他thread异常。

processer处理机分给thread,即真正在处理机上运行的是thread。

thread的创建,执行速度比process更快,不需要context切换,耗费资源较少,比process更lightweight

thread的好处:易于调度,并发性高,开销小。

http://www.cnblogs.com/lmule/archive/2010/08/18/1802774.html

http://blog.csdn.net/dazhong159/article/details/7896070

http://blog.csdn.net/column/details/killthreadseries.html

进程与线程的区别:

(1)调度:process作为拥有资源的基本单位,thread作为调度和分配的基本单位

(2)并发性:不仅process之间可以并发执行,同一个process的多个thread之间也可并发执行

(3)拥有资源:process是拥有资源的一个独立单位,thread不拥有系统资源,但可以访问隶属于process的资源

(4)系统开销:在创建或撤消process时,由于系统都要为之分配和回收资源,导致系统的开销明显大于创建或撤消thread时的开销。

process的基本状态及状态之间的关系

Ready<---->Running--->Blocked--->Ready

process间通信的方式?

(1)管道(pipe)及有名管道(named pipe):管道可用于具有亲缘关系的父子进程间的通信,有名管道除了具有管道所具有的功能外,它还允许无亲缘关系进程间的通信。

(2)信号(signal):信号是在软件层次上对中断机制的一种模拟,它是比较复杂的通信方式,用于通知进程有某事件发生,一个进程收到一个信号与处理器收到一个中断请求效果上可以说是一致的。

(3)消息队列(message queue):消息队列是消息的链接表,它克服了上两种通信方式中信号量有限的缺点,具有写权限得进程可以按照一定得规则向消息队列中添加新信息;对消息队列有读权限得进程则可以从消息队列中读取信息。

(4)共享内存(shared memory):可以说这是最有用的进程间通信方式。它使得多个进程可以访问同一块内存空间,不同进程可以及时看到对方进程中对共享内存中数据得更新。这种方式需要依靠某种同步操作,如互斥锁和信号量等。

(5)信号量(semaphore):主要作为进程之间及同一种进程的不同线程之间得同步和互斥手段。

(6)套接字(socket):这是一种更为一般得进程间通信机制,它可用于网络中不同机器之间的进程间通信,应用非常广泛。

thread间通信?

(1) global volatile variable

(2) message: PostMessage PostThreadMessage

thread的同步和互斥?

mutex

semaphore

critical section

进程如何同步?

http://www.cnblogs.com/sooner/tag/%E8%BF%9B%E7%A8%8B%E9%80%9A%

秒杀多线程系列

http://blog.csdn.net/dazhong159/article/details/7948327

http://blog.csdn.net/morewindows/article/details/7470936

c++多线程编程

http://blog.sina.com.cn/s/articlelist_1650383371_1_1.html

criticalsection

http://blog.163.com/ctct7833@126/blog/static/16162469020117119125560/

process vs thread的更多相关文章

  1. Linux process vs thread

    Linux process vs thread Question I have a query related to the implementation of threads in Linux. L ...

  2. Linux Process VS Thread VS LWP

    Process program program==code+data; 一个进程可以对应多个程序,一个程序也可以变成多个进程.程序可以作为一种软件资源长期保存,以文件的形式存放在硬盘 process: ...

  3. Activity, Service,Task, Process and Thread之间的关系

    Activity, Service,Task, Process and Thread之间到底是什么关系呢? 首先我们来看下Task的定义,Google是这样定义Task的:a task is what ...

  4. kafka.common.KafkaException: Failed to acquire lock on file .lock in /tmp/kafka-logs. A Kafka instance in another process or thread is using this directory.

    1.刚才未启动zookeeper集群的时候,直接启动kafka脚本程序,kafka报错了,但是进程号启动起来来,再次启动出现如下所示的问题,这里先将进程号杀死,再启动脚本程序. [hadoop@sla ...

  5. Failed to acquire lock on file .lock in /tmp/kafka-logs. A Kafka instance in another process or thread is using this directory.

    1. 问题现象 启动 kafka 时报错:Failed to acquire lock on file .lock in /tmp/kafka-logs. A Kafka instance in an ...

  6. yum安装提示错误Thread/process failed: Thread died in Berkeley DB library

    问题描述: yum 安装更新提示 rpmdb: Thread/process failed: Thread died in Berkeley DB library 问题解决: 01.删除yum临时库文 ...

  7. Difference between Process and thread?

    What are the differences between a process and a thread? How are they similar? How can 2 threads com ...

  8. C# - 多线程 之 Process与Thread与ThreadPool

    Process 进程类, // 提供对本地和远程进程的访问,启动/停止本地系统进程 public class Process : Component { public int Id { get; } ...

  9. Process and Thread

    A process is a completely independent program that has its own address space, while a thread is a se ...

随机推荐

  1. poj2763 树链剖分(线段树)

    注意这里都是把边放到线段树中,所以lca的时候,要注意如果top[x]==top[y] && x==y 的时候已经完成了. 仔细想想边和点的不同之处!!! #include<ma ...

  2. Lucene 4.7 --高亮显示

    jar lucene-analyzers-common-4.7.0.jar lucene-analyzers-smartcn-4.7.0.jar lucene-core-4.7.0.jar lucen ...

  3. Java虚拟机的功能

    1:通过ClassLoader寻找和装载class文件 2:解释字节码成为指令并执行,提供class文件的运行环境.即将字节码转换为不同OS下可执行的机器码指令. 3:进行垃圾回收. 4:提供与硬件交 ...

  4. SSL、TLS协议格式、HTTPS通信过程、RDP SSL通信过程

    相关学习资料 http://www.360doc.com/content/10/0602/08/1466362_30787868.shtml http://www.gxu.edu.cn/college ...

  5. 一个完整的编译器前端-A.1 源语言

    这个语言的一个程序由一个块组成,该块中包含可选的声明和语句.语法符号basic表示基本类型. program –> block block   –> { decls stmts } dec ...

  6. C语言学习-01第一个C语言程序

    一 C语言的历史 C语言是一门通用计算机编程语言,应用广泛.C语言的设计目标是提供一种能以简易的方式编译.处理低级存储器.产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言. 尽管C语言提供 ...

  7. 2016年4月7日 js的全选和反选

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"/> <title> ...

  8. Hbase Shell常用命令

    hbase shell常用的操作命令有create,describe,disable,drop,list,scan,put,get,delete,deleteall,count,status等,通过h ...

  9. NYOJ 77 开灯问题

    #include <stdio.h> #include <string.h> #define maxn 1050 int a[maxn]; int main(void) { i ...

  10. phpcms 网站迁移服务器

    相信很多人不知道怎么去把PHPCMS V9进行搬家 在本地测试好的phpcms v9网站需要搬到服务器上,可以用以下方法: 1.上传所有的程序文件(如果主机支持压缩包在线解压,那么就打成zip的包,f ...