Linux系统函数API----基本概念

简介: Linux系统函数API----基本概念

C++程序员必会的知识


文件IO

如何理解输入输出流?

  • 站在文件的角度:输入流—>从内存向文件中写入I,输出流从文件中向内存中写东西O
  • 站在内存的角度:输入流—>从文件向内存中写入I,输出流从内存中向文件中写东西O

C库函数如何操作文件

FILE:是一个结构体类型,其中包括三个重要的属性,文件描述符、文件读写指针、I/O缓冲区的地址。通过这三个属性,我们就可以定位到磁盘中的每一个文件的某一个位置,并且能找到内存中对应的区域。如此以来,我们就能将数据在内存和文件中进行交互了。

磁盘刷新时机: 刷新缓冲区 flush、缓冲区满了、程序正常退出(exit、return)

C库函数与系统函数的关系

过程描述:我们在程序中调用库函数,库函数会调用LINUX提供的系统函数,LINUX接着调用了系统调用,由系统调用进入内核层,调用相应的设备驱动程序,调用硬件层的相应设备。

虚拟地址空间

       对于每一个运行着的程序(进程),操作系统都会为其分配一个虚拟地址空间(0~4G)。这个虚拟地址空间通过MMU与实际的内存对应。

MMU的规定分页的大小为 4K

                                 

我们平时分析程序时通常用内存四区图就行。

文件描述符表

       在内核区的PCB称为进程描述符,记录了很多关于进程相关的信息,对于我们开发人员来说,这个一个很关键、也必须掌握的内容。

       在PCB中存在维护了一个进行描述符表(其实就是一个int的类型的数组),这个数组的大小为1024,其下标从0~1023。每一个下标对应着一个文件描述符,是的,就是我们前面所说的文件描述符。其实每一个文件描述符并不是直接指向磁盘中对应的文件位置。文件描述符先指向一个文件表,文件表里维护了文件的很多信息,如更新时间,权限等等,其中最重要的是有一个指针指向了磁盘中对应的文件位置(通常我们不考虑文件表的存在)。

       文件描述表中的前三个分别对应的标准输入、标准输出、标准错误,这个操作系统提前帮我们设定好的。它们都指向同一个设备驱动文件-->终端 /dev/tty

当我们申请一个文件描述符的时候,默认是打开一个目前状况下最小的问价描述符。

文件描述符表的大小是有限制的,我们使用的时候,应考虑进去,记得关闭不使用的文件描述符。

             

 

 

相关文章
|
2月前
|
Ubuntu Linux Anolis
Linux系统禁用swap
本文介绍了在新版本Linux系统(如Ubuntu 20.04+、CentOS Stream、openEuler等)中禁用swap的两种方法。传统通过注释/etc/fstab中swap行的方式已失效,现需使用systemd管理swap.target服务或在/etc/fstab中添加noauto参数实现禁用。方法1通过屏蔽swap.target适用于新版系统,方法2通过修改fstab挂载选项更通用,兼容所有系统。
207 3
Linux系统禁用swap
|
2月前
|
Linux
Linux系统修改网卡名为eth0、eth1
在Linux系统中,可通过修改GRUB配置和创建Udev规则或使用systemd链接文件,将网卡名改为`eth0`、`eth1`等传统命名方式,适用于多种发行版并支持多网卡配置。
287 3
|
3月前
|
Ubuntu Linux
计算机基础知识:linux系统怎么安装?
在虚拟机软件中创建一个新的虚拟机,并选择相应操作系统类型和硬盘空间大小等参数。将下载的 ISO 镜像文件加载到虚拟机中。启动虚拟机,进入安装界面,并按照步骤进行安装。安装完成后,可以在虚拟机中使用 Linux 系统。
|
3月前
|
存储 Ubuntu Linux
「正点原子Linux连载」第二章Ubuntu系统入门
在图2.8.2.4中,我们使用命令umount卸载了U盘,卸载以后当我们再去访问文件夹/mnt/tmp的时候发现里面没有任何文件了,说明我们卸载成功了。
|
Ubuntu Linux 网络安全
Linux系统初始化脚本
一款支持Rocky、CentOS、Ubuntu、Debian、openEuler等主流Linux发行版的系统初始化Shell脚本,涵盖网络配置、主机名设置、镜像源更换、安全加固等多项功能,适配单/双网卡环境,支持UEFI引导,提供多版本下载与持续更新。
273 0
Linux系统初始化脚本
|
3月前
|
运维 Linux 开发者
Linux系统中使用Python的ping3库进行网络连通性测试
以上步骤展示了如何利用 Python 的 `ping3` 库来检测网络连通性,并且提供了基本错误处理方法以确保程序能够优雅地处理各种意外情形。通过简洁明快、易读易懂、实操性强等特点使得该方法非常适合开发者或系统管理员快速集成至自动化工具链之内进行日常运维任务之需求满足。
219 18
|
2月前
|
安全 Linux Shell
Linux系统提权方式全面总结:从基础到高级攻防技术
本文全面总结Linux系统提权技术,涵盖权限体系、配置错误、漏洞利用、密码攻击等方法,帮助安全研究人员掌握攻防技术,提升系统防护能力。
261 1
|
2月前
|
监控 安全 Linux
Linux系统提权之计划任务(Cron Jobs)提权
在Linux系统中,计划任务(Cron Jobs)常用于定时执行脚本或命令。若配置不当,攻击者可利用其提权至root权限。常见漏洞包括可写的Cron脚本、目录、通配符注入及PATH变量劫持。攻击者通过修改脚本、创建恶意任务或注入命令实现提权。系统管理员应遵循最小权限原则、使用绝对路径、避免通配符、设置安全PATH并定期审计,以防范此类攻击。
958 1
|
2月前
|
算法 API 数据库
生鲜电商技术实践:基于保质期API的自动下架系统保障食品安全
基于保质期提醒API与自动化工作流,实现生鲜商品临期智能预警与自动下架。通过设定差异化预警阈值(如蔬菜2天、冷冻品7天),每日扫描数据库并触发下架指令,确保食品安全合规,降低损耗与客诉,提升运营效率。
234 0
|
3月前
|
缓存 监控 Linux
Linux系统清理缓存(buff/cache)的有效方法。
总结而言,在大多数情形下你不必担心Linux中buffer与cache占用过多内存在影响到其他程序运行;因为当程序请求更多内存在没有足够可用资源时,Linux会自行调整其占有量。只有当你明确知道当前环境与需求并希望立即回收这部分资源给即将运行重负载任务之前才考虑上述方法去主动干预。
1499 10