利用POSIX文件函数部分实现linux中的cp功能

本文介绍了如何利用POSIX文件函数来部分实现Linux中的`cp`功能,重点在于复制普通文件及其属性。首先确定目标是实现一对一的文件拷贝,然后讲解了Linux文件系统的基本知识,包括文件定义、文件系统结构、文件类型和权限。接着,阐述了如何使用stat和fstat函数获取文件属性,并介绍了不带缓存的文件I/O操作。最后,给出了C语言实现的代码示例,并提到该编程经验与进程间通信中的管道(pipe)的潜在联系。
摘要由CSDN通过智能技术生成

利用POSIX文件函数部分实现linux中的cp功能

一、确定目标

在开始之前,我们先确定这次编程的主要目的——

  1. 实现一对一的普通文件的拷贝
  2. 类似cp程序可以在bash上直接传送参数
  3. 尽量各方面还原cp程序

二、基本知识

确定了主要目的之后,先看文件在linux系统中的有关概念

**- Linux系统中,文件的准确定义是不包含有任何其他结构的字符流。
- Linux系统提供的文件系统,是树形层次结构系统。
- Linux支持多种文件系统,最常用的文件系统是ext2系统。
- Linux系统的文件属性主要包括文件类型和文件权限两个方面**

那么我们若要实现拷贝功能,不仅要拷贝文件内容,而且要拷贝文件属性。

以下是linux系统中文件的主要类型,在此我们只实现基础的普通文件的拷贝。
这里写图片描述

以下是linux系统中文件权限的说明

*对于Linux系统中的文件来说,它的权限可以分为4种:可读取(Readable)、可写入(Writable)、可执行(eXecute)和无权限,分别用r、w、x和-表示。
Linux系统按文件所有者、文件所有者同组用户和其它用户三类规定不同的文件访问权限。
显示的作为权限的10个字符,可分为四部分:
第一位:一般表示文件类型。
第二位到第四位(第一组rwx):表示文件所有者的访问权限。
第五位到第七位(第二组rwx):表示文件所有者同组用户的访问权限。
第八位到第十位(第三组rwx):表示其他用户的访问权限。*

linux文件的其他属性如下

struct stat {
        mode_t     st_mode;       //文件对应的模
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值