本文主要是介绍嵌入式操作系统网络编程(5),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
D0317
嵌入式Linux文件操作
1、Linux系统空间的组成:用户空间、内核空间(提供核心的服务和数据)
注:用户空间到内核空间是有开销的(时间、cpu、内存)
2、系统调用:用户访问内核空间的方式;(注:用户不能直接发起系统调用;系统调用的接口不能跨平台使用)
用户编程接口API:发生系统调用—访问内核空间的服务和数据
(注:访问内核空间的方式:系统调用、硬件中断、软件中断)
3、Linux一点哲学:一切皆为文件;文件的分类;文件描述符的作用
4、读写文件(除去普通文件)发生阻塞;(读空文件会阻塞、写满文件会阻塞);
(注:标准输入设备:STDIN_FILENO,标准输出设备:STDOUT_FILEN,标准出错设备:STDERR_FILENO)
5、如何改变输入设备的阻塞状态?(open打开文件时,选择O_NONBLOCK选项;对已打开的文件,使用fcntl函数进行标志位设置)fcntl(fd、F_SETL,O_NONBLOCK);
6、文件的重定向(改变文件的输出输入方向):dup、dup2
7、文件的属性获取:stat、fstat(文件的大小)
1、文件的普通操作:create\open\read\write\close\lseek
2、C库函数:fcreate\fopen\fread\fwrite\fclose\flseek\fgets\fprint\fputs\fscanf\ftell\feof
10、自学:ioctl
多任务—进程
1、什么是多任务?
错误理解:同时执行多个任务
平台:单个CPU(一个核):一个CPU核同一时刻只能处理一条语句
任务:10个任务
单任务:一个任务执行结束之后,另一个任务才能执行!
多任务(并发处理 :抢占式(中断;实时性)、非抢占式(时间片轮转;非实时性);):一个任务执行过程中,可以暂停运行(被其他任务打断运行),然后cpu执行其他任务
并发执行&并行执行
进程的概念:
多任务编程—多进程或者多线程编程
进程VS程序
进程:一个程序执行的一次过程
进程是操作系统执行的最小单元
一个程序运行可能会产生多个进程
Linux进程的特点:每个进程都有独立的运行空间(Linux进程虚拟地址空间)
换句话:每个进程都有自己独立的虚拟地址空间,所有的数据都保存在自己独立的空间内;
Hello.c àa.out-à加载内存中
在所有计算机系统中,内存都是稀缺资源
保护稀缺资源方法:抽象虚拟物体进行代替
操作虚拟的物体实际上是在操作稀缺资源
D3.18
单任务VS 多任务
并发(单个cpu)VS并行(多个cpu)
进程:
特点:每个进程都有自己独立的虚拟地址空间,大小为4G(互不干扰、相互独立);进程虚拟地址空格的构成
栈空间:先进后出,系统管理,生命周期是由所在函数决定(局部)
堆空间:先进先出,空户管理(malloc、free),用户决定(局部或者全局)
数据段:系统管理,生命周期,全局
进程id
所有进程创建都是由父进程创建的,父进程创建的进程称之为子进程
Linux系统下所有进程的父进程 init()
进程id 定义 pid_t pid
fork函数的作用:创建进程
1、给子进程分配空间;
2、拷贝父进程的代码段、数据段到子进程空间;
3、给父子进程的pid赋值;
fork创建的进程:父子进程的执行顺序是随机的
父子进程的调度是由系统决定的
作业:waitpid的作用
这篇关于嵌入式操作系统网络编程(5)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!