Linux下的进程与线程(一)—— 进程概览
进程是操作系统分配资源的基本单位.线程是操作系统进行运行和调度的基本单位.
进程之间可以切换,以便轮流占用CPU,实现并发.一般进程运行在用户模式下,只能执行指令集中的部分指令.
当进程进行上下文切换的时候,需要从用户模式转变为内核模式.
用户模式转为内核模式的方法有系统调用(异常),中断,故障.下面一个一个解释:
系统调用(在CS:APP这本书里,系统调用是异常的一种):实际上是一种代理请求的方式,是进程申请使用操作系统提供的服务程序来完成工作.一些常用的系统调用函数有fork,sleep,read,write等.本质上,系统调用是使用中断来完成的.
中断:异步发生,是来自处理器外部的I/O设备信号的结果.比如,读写硬盘完成后,会产生响应的中断.当某个进程运行了较长时间,也会产生中断,此后由内核切换进程.
故障:这个很好理解,比如除法错误,缺页错误等,不严谨地说,故障和错误有些类似.
在内核模式下,进程可以执行指令集中的任何指令,访问系统中存储器的任何位置.
当切换到另一个进程之后,进程再次进入用户模式.
进程:
进程的创建:
Linux下创建进程的函数是fork,fork函数有以下特点:
- 调用一次,返回两次.返回到父进程的值是子进程的pid(process id),返回到子进程的值是0
- 并发执行.父进程和子进程的执行顺序不固定.
- 地址空间内容相同,但相互独立.
进程的状态:
从程序员角度看,进程一直处于以下三种状态之一:
- 运行,在此状态下可调度
- 停止(非终止),进程被挂起,在此状态下不可调度.进程收到SIGSTOP等信号时进入此状态.当收到SIGCONT信号后结束此状态,然后继续运行.
- 终止,进程永远停止了.有三种原因进入此状态:(1)收到了停止信号,(2)从主程序返回(比如调用了return),(3)调用exit函数
进程的终止:
子进程终止后,由父进程负责回收.若不回收,则占用系统资源.
若父进程在回收子进程之前就终止了,内核会安排init进程(pid = 1)来回收
回收进程使用函数waitpid,wait(waitpid的简单版本)
进程的回收是一个较为复杂的问题,这个会在以后的文章中继续探讨.
关于execve函数:
在Linux的Shell和Web服务器中,广泛使用了fork函数和execve函数。一般使用fork函数创建一个新进程,然后在这个进程的上下文中使用execve函数加载并运行一个新程序。
execve函数的原型如下:
int execve(const char *filename, const char *argv[], const char *envp[])
其中,filename 指示要运行的可执行文件,argv为参数列表(argv[0]为可执行目标文件的名字), envp为环境信息
一个使用execve函数代替ls命令查看当前目录的典型用法如下:
#include<stdio.h>
#include<unistd.h>
int main(int arg, char **args)
{
char *argv[]={"ls","-al", NULL};
char *envp[]={,NULL};
execve("/bin/ls",argv,envp);
}
Linux下的进程与线程(一)—— 进程概览的更多相关文章
- Linux下c开发 之 线程通信(转)
Linux下c开发 之 线程通信(转) 1.Linux“线程” 进程与线程之间是有区别的,不过Linux内核只提供了轻量进程的支持,未实现线程模型.Linux是一种“多进程单线程”的操作系统.Linu ...
- Linux下c开发 之 线程通信
Linux下c开发 之 线程通信 1.Linux“线程” 进程与线程之间是有区别的,不过Linux内核只提供了轻量进程的支持,未实现线程模型.Linux是一种“多进程单线程”的操作系统.Linux本身 ...
- linux下多进程的文件拷贝与进程相关的一些基础知识
之前实现了用文件IO的方式能够实现文件的拷贝,那么对于进程而言,我们是否也能够实现呢? 答案是肯定的. 进程资源: 首先我们先回想一下,进程的执行须要哪些资源呢?其资源包含CPU资源,内存资源,当然还 ...
- Linux下使用两个线程协作完成一个任务的简易实现
刚解决了之前的那个Linux下Pthread库的问题,这次就来使用两个线程来协作,共同完成一个求和的任务. 打一下基础吧 本次需要使用到的知识点有: lpthread,编译的时候用到,相当于一个声明的 ...
- python---基础知识回顾(十)进程和线程(进程)
前戏:进程和线程的概念 若是学过linux下的进程,线程,信号...会有更加深刻的了解.所以推荐去学习下,包括网络编程都可以去了解,尤其是对select,poll,epoll都会有更多的认识. 进程就 ...
- linux下pthread_cancel无法取消线程的原因【转】
转自:http://blog.csdn.net/huangshanchun/article/details/47420961 版权声明:欢迎转载,如有不足之处,恳请斧正. 一个线程可以调用pthrea ...
- linux下pthread_cancel无法取消线程的原因
一个线程能够调用pthread_cancel终止同一进程中的还有一个线程,可是值得强调的是:同一进程的线程间,pthread_cancel向还有一线程发终止信号.系统并不会立即关闭被取消线程,仅仅有在 ...
- linux下svn使用及查看杀掉进程
ps –aux ubuntu下安装subversion客户端: sudo apt-get install subversion svn正在checkout时候无法退出操作,shift+ctrl+t新建 ...
- 浅析linux 下shell命令执行和守护进程
执行shell脚本有以下几种方式 1.相对路径方式,需先cd到脚本路径下 [root@banking tmp]# cd /tmp [root@banking tmp]# ./ceshi.sh 脚本执行 ...
- 学习笔记:Linux下共享内存的方式实现进程间的相互通信
一.常用函数 函数系列头文件 #include <sys/types.h> #include <sys/ipc.h> #include <sys/shm.h> ft ...
随机推荐
- vxWorks6.6 N270 D525 cpu的bsp配置总结
对硬盘的操作 使用SATA硬盘,分区,引导区(VxC:)必须格式化为FAT(FAT16)格式,所以该分区大小有限制,不能超过4G(4G大小带测试),设置C:为"活动的": 主机上安 ...
- freemarker报错之十三
1.错误描述 freemarker.core.ParseException: Token manager error: freemarker.core.TokenMgrError: Unknown d ...
- 网络协议笔记-网络层-路由器的作用、IP地址
1-[路由器在网际互连中的作用] 1.1-[直接交付和间接交付] 直接交付:当主机A要向另一个主机B发送数据报时,要先检查目的主机B是否与源主机连接在同一个网络上.如果是,就将数据报直接交付给目的主机 ...
- 升级adb注意事项
最近使用adb devices老提示设备offline,百度试了好多方法都不行,后面才发现是因为没有把adb文件的名称中含有adb的所有文件复制到 c:/windows/system目录,复制完后只记 ...
- JavaScript之中级教程关键
Date() setTime()getTime()toUpperCase() toLowerCase() charAt() 返回指定的字符,返回的字符长度为1的字符串. indexOf('需要检索的字 ...
- 【BZOJ4554】游戏(二分图匹配,网络流)
[BZOJ4554]游戏(二分图匹配,网络流) 题解 Description 在2016年,佳缘姐姐喜欢上了一款游戏,叫做泡泡堂.简单的说,这个游戏就是在一张地图上放上若干个炸弹,看 是否能炸到对手, ...
- 关于hibernate中hql语句 case when的写法
java hql case when的用法 if(null == sorter){ hql.append(" order by m.mDate desc,case when m.mealTi ...
- WPF-悬浮窗(类似于360)
boss要求开发一个类似于360的悬浮窗,如下图所示: 目前采用的是wpf做的客户端,之前有个winform的项目,我参考了下,完成了wpf版的悬浮窗. Height=" WindowSta ...
- windows7下django项目搭建
参考视频教程 http://study.163.com/course/ http://www.bilibili.com/video/av8915600/ http://www.bilibil ...
- 设计模式——外观模式(C++实现)
#include <string> #include <iostream> using namespace std; class STSystemA { public: voi ...