---- 文章目录 1. inode节点与硬链接 2. stat函数与 struct stat 结构体 3. stat函数实例分析及stat命令 4....实现 ls -l filename命令 我们可以通过stat函数来实现 ls -l 命令的功能,下面我们实现查看指定文件的 ls -l 命令,即 ls -l filename 实现代码如下 /*****...(非系统调用) *原型:struct tm *localtime(const time_t *timep); *参数:time_t类型,struct stat中time_t st_atime,这里应该是文件访问时间...(非系统调用) struct passwd *getpwuid(uid_t uid); 根据uid获取用户信息 struct passwd { char *pw_name; username char...那么我们自己如何实现获取符号链接的实际大小呢,这就用到了非穿透函数lstat,只要把上面代码实现中的函数调用stat替换为lstat就可以了,下面测试一下。
比如最简单的hello world程序是将信息打印到终端,终端对系统来说是硬件资源,如果没有系统调用,用户程序需要自己编写终端设备的驱动,以及控制终端如何显示的代码。 隐藏背后的技术细节。...所有 C 函数库是相同的,而各个操作系统的系统调用是不同的。 函数库调用是调用函数库中的一个程序,而系统调用是调用系统内核的服务。...当一个进程正在运行,遇到读写文件操作,会发生一个中断,中断后系统会把当前用户进程的一些寄存器信息保存在内核堆栈中,接着去处理中断服务程序,这里是要去执行系统调用,Linux 中通过执行 int $0x80...为了更清楚的说明系统调用的过程,我们这里参考网上的一段代码来实现系统调用: int main() { time_t tt; struct tm *t; asm volatile (...其实代码中的汇编部分就是实现 time() 系统调用的功能,汇编代码不懂没关系(我也不太懂),这里主要是为了说清楚系统调用的整个过程。
在Linux系统中,fork()是一个非常重要的系统调用,它的作用是创建一个新的进程。...具体来说,fork()函数会在当前进程的地址空间中复制一份子进程,并且这个子进程几乎完全与父进程相同,包括进程代码、数据、堆栈以及打开的文件描述符等。...fork()函数的语法如下: #include pid_t fork(void); 其中,参数pid_t代表进程id,而fork()函数返回值则有以下两种情况: 如果返回0,表示当前进程是子进程...需要注意的是,fork()函数并不保证父进程和子进程的执行顺序。在fork()之后,操作系统可能会先执行父进程,也可能会先执行子进程,这完全取决于系统的调度算法。...一般情况下,父进程和子进程之间是相互独立的,它们各自运行各自的代码,共享的只有一部分内存空间,而其他资源则是分别使用的。
Linux系统调用– recv/recvfrom函数详解 功能描述: 从套接字上接收一个消息。对于recvfrom,可同时应用于面向连接的和无连接的套接字。...假如套接字上没有消息可以读取,除了套接字已被设置为非阻塞模式,否则接收调用会等待消息的到来。
name"); return -1; } int fd = open(argv[1], O_RDWR | O_CREAT); write(fd, "hello linux...STDIN_FILENO STDERR_FILENO*/ } close(fd); return 0; } 我们知道,在C语言中,字符串都是以 '\0' 结尾的,比如 "hello linux...write(fd, "hello linux...", 15); 我们来测试下程序,首先明确一点,字符串会写入相应文件,但是不会打印在屏幕中,这个后面分析。...这时候,就可以使用lseek()函数来移动读写位置,我们只需在上面代码中加一句话即可。...name"); return -1; } int fd = open(argv[1], O_RDWR | O_CREAT); write(fd, "hello linux
1.文件重命名 在linux的shell解释器中输入mv 原文件名 新文件名即可进行重命名,实际上C库函数提供了具有相同功能的系统调用函数rename。...所需头文件:#include 函数原型: int rename(const char *oldpath,const char *newpath) 参数: oldpath原文件名...该函数用法比较简单,不做实例验证,大家可以自行验证。 2.修改当前进行(应用程序)的路径 cd。...所需头文件: #include 函数原型: int chdir(const char *path) 参数: path即为要切换的路径。...5.删除一个空目录 rmdir 所需头文件: #include 函数原型:int rmdir(const char* pathname) 参数:空目录的名字。
1. link函数 包含头文件 #include 函数原型 int link(const char *oldpath, const char *newpath); 函数功能 link...函数参数 oldpath:源文件名(路径) newpath:硬链接文件名(路径) 函数返回值 成功返回0。On success, zero is returned....2. symlink函数 包含头文件 #include 函数原型 int symlink(const char *oldpath, const char *newpath); 函数功能...读取软链接,这个函数只能读取软链接,不能读取硬链接。 函数参数 path:连接名(路径) buf:缓冲区(缓存读出的数据) bufsiz:缓冲区大小 函数返回值 成功返回缓冲区被填充的大小。...(注意同名命令unlink,查询函数man手册时要加章节2) 函数参数 pathname:链接名,也可以是文件名 函数返回值 成功返回0。
操作系统内核——操作系统的内核,负责管理系统的进程、内存、设备驱动程序、文件和网络系统。一个内核不是一套完整的操作系统。例如Linux。 Linux操作系统——基于Linux内核的操作系统。...Linux的运行空间: Linux的运行空间:内核空间+用户空间 ---- 内核空间——存放的是整个内核代码和所有内核模块,以及内核所维护的数据。 用户空间——用户程序的代码和数据。...系统调用表: 内核维护系统调用表,保存系统调用函数的起始位置,系统调用号对应该系统调用在调用表中的偏移量。 ---- 执行系统调用的方法 还有系统中断。...---- GLIBC库函数 Glibc实现操作系统提供的系统服务,即为系统调用的封装。 每个特定的系统调用对应了至少一个glibc封装的库函数。 多个API也可能只对应同一个系统调用。...返回值:该函数返回值为特定系统调用的返回值,在系统调用成功之后你可以将返回值转化为特定的类型,如果系统调用失败则返回-1,错误代码存放在errno中。
而有趣的是,Linux 提供的系统调用却比大部分操作系统都少得多。 要访问系统调用(在 Linux 中常称作 syscall),通常通过C库中定义的函数调用来进行。...系统调用在出现错误的时候C库会把错误码写人errno全局变量。通过调用perror()库函数,可以把该变量翻译成用户可以理解的错误字符串。 在 Linux 中,每个系统调用被赋予一个系统调用号。...系统调用说明 asmlinkage 限定词,这是一个编译指令,通知编译器仅从栈中提取该函数的参数。...函数返回 long,为了保证 32 位和 64 位系统的兼容,系统调用在用户空间和内核空间有不同的返回值类型,在用户空间为 int,在内核空间为 long。...假设系统调用在内核空间定义为 sys_ioctl,那么该系统调用的用户空间接口为 ioctl Linux kernel-5.18.8 有 440 个系统调用,这些系统调用讲究通用性,一旦固定,很少修改,
函数参数 buf:缓冲区,用于存放目录。...2. chdir函数 包含头文件 #include 函数原型 int chdir(const char *path); int fchdir(int fd); 函数功能 chdir...4. rmdir函数 包含头文件 #include 函数原型 int rmdir(const char *pathname); 函数功能 rmdir() deletes a directory...函数参数 name:目录名字。...> #include 函数原型 int closedir(DIR *dirp); 函数功能 关闭目录。
一、系统API与C库函数的调用关系 当我们在C语言程序中调用一个库函数的时候,比如调用printf()函数,实际上它是通过文件指针来指向要打印的位置的。...并且,printf()函数会调用Linux的系统函数write()函数(它是一个系统接口,也可以人工调用),write()函数再继续调用sys_write()函数(这个函数只能是操作系统去调用),sys_write...我们所作的只有在C程序中调用printf()等库函数,其余操作都是操作系统帮我们做的。请看下面这张图。 printf()函数在打印的时候通过一个文件指针来实现打印到某个文件的某个位置。...这些函数都属于系统调用,可以通过命令 man 2 functionname 查看。...表示查看第二章,也就是系统调用API。
not fount file name"); return -1; } int fd = open(argv[1], O_RDWR | O_CREAT); write(fd, "hello linux...read_size); /*STDIN_FILENO STDERR_FILENO*/ } close(fd); return 0; } 我们知道,在C语言中,字符串都是以 ‘\0’ 结尾的,比如 “hello linux...write(fd, "hello linux...", 15); 我们来测试下程序,首先明确一点,字符串会写入相应文件,但是不会打印在屏幕中,这个后面分析。...这时候,就可以使用lseek()函数来移动读写位置,我们只需在上面代码中加一句话即可。...not fount file name"); return -1; } int fd = open(argv[1], O_RDWR | O_CREAT); write(fd, "hello linux
1. access函数 包含头文件 #include 函数原型 int access(const char *pathname, int mode); 函数功能 判断文件权限以及文件是否存在...} else { printf("can not execution %s\n", argv[1]); } return 0; } 下面测试一下代码...,来说明access函数的作用,首先我们在普通用户下测试该函数 现在我们切换到root用户,或者在普通用户下使用sudo命令,再运行一下该函数 对比上面两次测试结果,这时候我们发现一个奇怪的现象,同一个文件...查看,或使用stat函数获取st_gid 函数返回值 成功返回0。...所以,如果你查看man手册如果发现没有函数原型,说明该函数有同名命令,需要加上章节才能查看函数的帮助手册 man 2 chown,系统调用都在第2章节。
所需头文件: #include 函数原型: int access(const char *pathname,int mode) 参数: pathname代表文件名,绝对路径或相对路径都可以...功能:测试当前用户指定文件是否具有某种属性,注意当前用户,使用哪个用户调用这个函数,这个用户就是当前用户。...下面举例应用access函数: #include #include #include int main(int argc,char *argv...\n",argv[1]); } return 0; } 当前目录下的文件: 运行上述代码,结果如下:
所需头文件: #include #include #include 函数功能:用来获取linux操作系统下文件的属性。...注意,在linux操作系统下,一切皆文件。文件共有七种类型,分别是普通文件、目录文件、管道文件、可执行文件、压缩文件、设备文件(字符、管道和块)和其他文件。...大家可能注意到,在代码中并为涉及输出st_mode属性相关的信息。 重点:下面着重深入的研究一下st_mode这属性,可以通过它来获取文件的文件类型以及权限。...那么如何取出对应的位置的位获取相关的信息呢,Linux系统调用给我们提供了一系列的宏,可以查看man文档 man 2 stat。...st.st_mode & S_IFMT) == S_IFREG) { printf("regular file\n"); } return 0; } 相信完全理解了系统调用函数
1.chmod 修改文件权限 所需头文件: #include 函数原型: int chmod(const char *filename,int mode) 参数: filename...应用实例: 当前目录文件下: 我们在应用chmod函数修改其a.txt的权限。...所需头文件: #include 函数原型: int chown(const char *path,uid_t owner,gid_t group) 参数: path为文件路径...所需头文件: #include #include 函数原型: int truncate(const char *path,off_t length) 参数...现在我们在代码中分别进行扩大和缩小文件大小,观察结果进行对比: //1.扩大a.txt文件 #include #include #include
一、什么是系统调用 系统调用 跟用户自定义函数一样也是一个函数,不同的是 系统调用 运行在内核态,而用户自定义函数运行在用户态。...系统调用 是 Linux 内核提供的一段代码(函数),其实现了一些特定的功能,用户可以通过 int 0x80 中断(x86 CPU)或者 syscall 指令(x64 CPU)来调用 系统调用。...二、进入系统调用 本文主要介绍的是 x86 CPU 进入系统调用的方式 Linux 提供了 int 0x80 中断来让用户程序进入 系统调用,我们来看看 Linux 对 int 0x80 中断的处理初始化过程...三、系统调用实现 当用户要调用 系统调用 时,需要通过向 eax 寄存器写入要调用的 系统调用 编号。...而 Linux 进入中断处理程序时,会把这些寄存器的值保存到内核栈中,这样 系统调用 就能通过内核栈来获取到参数。
文章目录 一、munmap 系统调用函数执行流程 二、munmap 系统调用函数源码 三、vm_munmap 函数源码 一、munmap 系统调用函数执行流程 ---- munmap 系统调用函数 的作用是...munmap 系统调用函数 调用了 vm_munmap 函数 , 在 vm_munmap 函数 中 , 又调用了 do_munmap 函数 , do_munmap 函数 是 删除 内存映射 的 核心函数...; 二、munmap 系统调用函数源码 ---- munmap 系统调用函数 , 定义在 Linux 内核源码 linux-4.12\mm\mmap.c#2729 位置 ; munmap 系统调用函数源码如下...-4.12\mm\mmap.c#2729 三、vm_munmap 函数源码 ---- vm_munmap 函数 , 定义在 Linux 内核源码 linux-4.12\mm\mmap.c#2713 位置...; 在 vm_munmap 函数 中 , 调用了 do_munmap 函数 , do_munmap 函数 是 删除 内存映射 的 核心函数 ; vm_munmap 函数源码如下 : int vm_munmap
二、 函数调用约定 函数调用约定约定了caller如何传参即将实参放到何处,应该按照何种顺序保存,以及callee如何返回返回值即将返回值放到何处。...x86的32位机器之上C语言一般是通过栈来传递参数,且一般都是倒序push,即先push最后一个参数再push倒数第二个参数,并通过ax寄存器返回结果,这称为cdecl调用约定(C有三种调用约定,linux...在x64系统默认有System V AMD64和Microsoft x64两种C语言函数调用约定,System V AMD64实际是System V AMD64 ABI文档的一部分,类UNIX系统多采用...本文主要讨论x64架构下Linux系统的函数调用约定即System V AMD64调用约定。...三、 x64架构下Linux系统函数调用 3.1 如何传递参数 System V AMD64调用约定规定了caller将第1-6个整型参数分别保存到rdi、rsi、rdx、rcx、r8、r9寄存器中,第
下面我们通过实例来说明这个函数的用法,接上一节的话题,我们可以不在open()打开文件的时候设置非阻塞,而是在程序中使用fcntl()函数来设置非阻塞参数,具体代码如下。...实现 ls -l filename命令 我们可以通过stat函数来实现 ls -l 命令的功能,下面我们实现查看指定文件的 ls -l 命令,即 ls -l filename 实现代码如下 /*****...(非系统调用) *原型:struct tm *localtime(const time_t *timep); *参数:time_t类型,struct stat中time_t st_atime...(非系统调用) struct passwd *getpwuid(uid_t uid); 根据uid获取用户信息 struct passwd { char...那么我们自己如何实现获取符号链接的实际大小呢,这就用到了非穿透函数lstat,只要把上面代码实现中的函数调用stat替换为lstat就可以了,下面测试一下。
领取专属 10元无门槛券
手把手带您无忧上云