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

相关文章

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

Python异步编程之await与asyncio基本用法详解

《Python异步编程之await与asyncio基本用法详解》在Python中,await和asyncio是异步编程的核心工具,用于高效处理I/O密集型任务(如网络请求、文件读写、数据库操作等),接... 目录一、核心概念二、使用场景三、基本用法1. 定义协程2. 运行协程3. 并发执行多个任务四、关键

AOP编程的基本概念与idea编辑器的配合体验过程

《AOP编程的基本概念与idea编辑器的配合体验过程》文章简要介绍了AOP基础概念,包括Before/Around通知、PointCut切入点、Advice通知体、JoinPoint连接点等,说明它们... 目录BeforeAroundAdvise — 通知PointCut — 切入点Acpect — 切面

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

C#异步编程ConfigureAwait的使用小结

《C#异步编程ConfigureAwait的使用小结》本文介绍了异步编程在GUI和服务器端应用的优势,详细的介绍了async和await的关键作用,通过实例解析了在UI线程正确使用await.Conf... 异步编程是并发的一种形式,它有两大好处:对于面向终端用户的GUI程序,提高了响应能力对于服务器端应

Go语言网络故障诊断与调试技巧

《Go语言网络故障诊断与调试技巧》在分布式系统和微服务架构的浪潮中,网络编程成为系统性能和可靠性的核心支柱,从高并发的API服务到实时通信应用,网络的稳定性直接影响用户体验,本文面向熟悉Go基本语法和... 目录1. 引言2. Go 语言网络编程的优势与特色2.1 简洁高效的标准库2.2 强大的并发模型2.

C# async await 异步编程实现机制详解

《C#asyncawait异步编程实现机制详解》async/await是C#5.0引入的语法糖,它基于**状态机(StateMachine)**模式实现,将异步方法转换为编译器生成的状态机类,本... 目录一、async/await 异步编程实现机制1.1 核心概念1.2 编译器转换过程1.3 关键组件解析

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

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

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

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