Linux系统调用八、link系列API函数详解

简介: Linux系统调用八、link系列API函数详解

🚀1. link函数

  • 包含头文件
#include <unistd.h>
  • 函数原型
int link(const char *oldpath, const char *newpath);
  • 函数功能
    link() creates a new link (also known as a hard link) to an existing file. 为现有的文件建立一个硬链接
  • 函数参数
  • oldpath:源文件名(路径)
  • newpath:硬链接文件名(路径)
  • 函数返回值
  • 成功返回0。On success, zero is returned.
  • 失败返回-1并设置errno。On error, -1 is returned, and errno is set appropriately.

示例:传入现有的文件名并为该文件建立硬链接

/************************************************************
  >File Name  : link_test.c
  >Author     : QQ
  >Company    : QQ
  >Create Time: 2022年05月16日 星期一 15时03分15秒
************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc, char* argv[])
{
  if(argc < 2)
  {
    printf("not found filename\n");
    return -1;  
  }
  link(argv[1], "./linkdir/link_test.c.hard");
  return 0;
}

在执行程序时,参数oldpath和newpath不仅可以是文件名,也可以是带有路径的文件名。

🚀2. symlink函数

  • 包含头文件
#include <unistd.h>
  • 函数原型
int symlink(const char *oldpath, const char *newpath);
  • 函数功能
    symlink() creates a symbolic link named newpath which contains the string oldpath. 创建一个符号链接,也就是软链接
  • 函数参数
  • oldpath:源文件名(路径)
  • newpath:符号链接文件名(路径)
  • 函数返回值
  • 成功返回0。On success, zero is returned.
  • 失败返回-1,并设置errno。On error, -1 is returned, and errno is set appropriately.

示例:传入现有的文件名并为该文件建立符号链接

/************************************************************
  >File Name  : symlink_test.c
  >Author     : QQ
  >Company    : QQ
  >Create Time: 2022年05月16日 星期一 15时25分50秒
************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc, char* argv[])
{
  if(argc < 2)
  {
    printf("not found filename\n");
    return -1;  
  }
  symlink(argv[1], "symlink_test.c.soft");
  return 0;
}

🚀3. readlink函数

  • 包含头文件
#include <unistd.h>
  • 函数原型
ssize_t readlink(const char *path, char *buf, size_t bufsiz);
  • 函数功能
    readlink() places the contents of the symbolic link path in the buffer buf, which has size bufsiz. readlink() does not append a null byte to buf. It will truncate the contents (to a length of bufsiz characters), in case the buffer is too small to hold all of the contents. 读取软链接,这个函数只能读取软链接,不能读取硬链接。
  • 函数参数
  • path:连接名(路径)
  • buf:缓冲区(缓存读出的数据)
  • bufsiz:缓冲区大小
  • 函数返回值
  • 成功返回缓冲区被填充的大小。On success, readlink() returns the number of bytes placed in buf.
  • 失败返回-1且设置errno。On error, -1 is returned and errno is set to indicate the error.
/************************************************************
  >File Name  : readlink_test.c
  >Author     : QQ
  >Company    : QQ
  >Create Time: 2022年05月16日 星期一 16时01分26秒
************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc, char* argv[])
{
  if(argc < 2)
  {
    printf("not found filename\n");
    return -1;  
  }
  char buf[10] = {0};
  ssize_t ret = readlink(argv[1], buf, sizeof(buf));
  printf("buf = %s, buflen = %ld, read size = %ld\n", buf, sizeof(buf), ret);
  return 0;
}

🚀4. unlink函数

  • 包含头文件
#include <unistd.h>
  • 函数原型
int unlink(const char *pathname);
  • 函数功能
    unlink() deletes a name from the file system. 删除软链接、硬链接、文件。(注意同名命令unlink,查询函数man手册时要加章节2)
  • 函数参数
  • pathname:链接名,也可以是文件名
  • 函数返回值
  • 成功返回0。On success, zero is returned.
  • 失败返回-1且设置errno。On error, -1 is returned, and errno is set appropriately.

示例1:unlink()删除文件、软链接、硬链接

/************************************************************
  >File Name  : unlink_test.c
  >Author     : QQ
  >Company    : QQ
  >Create Time: 2022年05月16日 星期一 16时57分59秒
************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc, char* argv[])
{
  if(argc < 2)
  {
    printf("not found filename\n");
    return -1;  
  }
  unlink(argv[1]);
  return 0;
}

示例2:write()写入unlink()删除的文件

/************************************************************
  >File Name  : unlink_test2.c
  >Author     : QQ
  >Company    : QQ
  >Create Time: 2022年05月16日 星期一 17时13分37秒
************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
int main()
{
  int fd = open("hello.txt", O_WRONLY | O_CREAT, 0664);
  unlink("hello.txt");
  int ret = write(fd, "hello", sizeof("hello"));
  if(ret < 0)
  {
    perror("write err");  
  }
  else if(ret == 0)
  {
    printf("not write\n");  
  }
  else
  {
    printf("write %d byte\n", ret); 
  }
  return 0;
}

在这个实验中看到,虽然并没有hello.txt这个文件,但是write()函数返回了成功,也就是写入成功了,那么内容写到哪去了呢。实际上,unlink函数删除硬链接计数时,如果有进程在引用这个文件,那么将暂时先不删除文件,等进程退出后,再删除文件。实际上这个文件已经写入成功了,只不过在后面又被删除了,这有点像我们在网上听音乐或看视频时的缓存,也就是一个比实际进度更快的一个进度条,它会先把要看的内容缓存在一个临时文件(以便于看的时候更流畅),在看完后自动删除。

相关文章
|
8天前
|
Linux
【Linux】System V信号量详解以及semget()、semctl()和semop()函数讲解
System V信号量的概念及其在Linux中的使用,包括 `semget()`、`semctl()`和 `semop()`函数的具体使用方法。通过实际代码示例,演示了如何创建、初始化和使用信号量进行进程间同步。掌握这些知识,可以有效解决多进程编程中的同步问题,提高程序的可靠性和稳定性。
47 19
|
10天前
|
Linux Android开发 开发者
linux m、mm、mmm函数和make的区别
通过理解和合理使用这些命令,可以更高效地进行项目构建和管理,特别是在复杂的 Android 开发环境中。
40 18
|
18天前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
83 13
|
3月前
|
网络协议 Linux 调度
深入探索Linux操作系统的心脏:内核与系统调用####
本文旨在揭开Linux操作系统中最为核心的部分——内核与系统调用的神秘面纱,通过生动形象的语言和比喻,让读者仿佛踏上了一段奇妙的旅程,从宏观到微观,逐步深入了解这两个关键组件如何协同工作,支撑起整个操作系统的运行。不同于传统的技术解析,本文将以故事化的方式,带领读者领略Linux内核的精妙设计与系统调用的魅力所在,即便是对技术细节不甚了解的读者也能轻松享受这次知识之旅。 ####
|
3月前
|
缓存 算法 安全
深入理解Linux操作系统的心脏:内核与系统调用####
【10月更文挑战第20天】 本文将带你探索Linux操作系统的核心——其强大的内核和高效的系统调用机制。通过深入浅出的解释,我们将揭示这些技术是如何协同工作以支撑起整个系统的运行,同时也会触及一些常见的误解和背后的哲学思想。无论你是开发者、系统管理员还是普通用户,了解这些基础知识都将有助于你更好地利用Linux的强大功能。 ####
52 1
|
4月前
|
网络协议 API Windows
MASM32编程调用 API函数RtlIpv6AddressToString,windows 10 容易,Windows 7 折腾
MASM32编程调用 API函数RtlIpv6AddressToString,windows 10 容易,Windows 7 折腾
|
4月前
|
Linux Shell
Linux系统编程:掌握popen函数的使用
记得在使用完 `popen`打开的流后,总是使用 `pclose`来正确关闭它,并回收资源。这种做法符合良好的编程习惯,有助于保持程序的健壮性和稳定性。
176 6
|
4月前
|
Linux Shell
Linux系统编程:掌握popen函数的使用
记得在使用完 `popen`打开的流后,总是使用 `pclose`来正确关闭它,并回收资源。这种做法符合良好的编程习惯,有助于保持程序的健壮性和稳定性。
188 3
|
4月前
|
存储 程序员 API
【收藏】非API函数检测操作系统类型
【收藏】非API函数检测操作系统类型
|
SQL 缓存 中间件
Linux必知词汇:应用程序接口(Application Program Interface,API)
Linux必知词汇:应用程序接口(Application Program Interface,API)
752 0