嵌入式操作系统网络编程(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

相关文章

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

Linux网络配置之网桥和虚拟网络的配置指南

《Linux网络配置之网桥和虚拟网络的配置指南》这篇文章主要为大家详细介绍了Linux中配置网桥和虚拟网络的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、网桥的配置在linux系统中配置一个新的网桥主要涉及以下几个步骤:1.为yum仓库做准备,安装组件epel-re

python如何下载网络文件到本地指定文件夹

《python如何下载网络文件到本地指定文件夹》这篇文章主要为大家详细介绍了python如何实现下载网络文件到本地指定文件夹,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下...  在python中下载文件到本地指定文件夹可以通过以下步骤实现,使用requests库处理HTTP请求,并结合o

Linux高并发场景下的网络参数调优实战指南

《Linux高并发场景下的网络参数调优实战指南》在高并发网络服务场景中,Linux内核的默认网络参数往往无法满足需求,导致性能瓶颈、连接超时甚至服务崩溃,本文基于真实案例分析,从参数解读、问题诊断到优... 目录一、问题背景:当并发连接遇上性能瓶颈1.1 案例环境1.2 初始参数分析二、深度诊断:连接状态与

Python 异步编程 asyncio简介及基本用法

《Python异步编程asyncio简介及基本用法》asyncio是Python的一个库,用于编写并发代码,使用协程、任务和Futures来处理I/O密集型和高延迟操作,本文给大家介绍Python... 目录1、asyncio是什么IO密集型任务特征2、怎么用1、基本用法2、关键字 async1、async

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

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

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

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

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