嵌入式操作系统网络编程(5)

2024-02-17 17:18

本文主要是介绍嵌入式操作系统网络编程(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)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/718471

相关文章

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同