目录
目录文件
目录文件的操作
(1)mkdir
mkdir
int mkdir(const char *pathname, mode_t mode);
功能:
创建目录
参数:
pathname:目录文件的路径
mode:目录文件的权限
返回值:
成功返回0
失败返回-1注意:
1.r 决定是否目录下可以查看其余文件信息
2.w 决定在目录下是否能够新建文件
3.x 决定是否能够进入该目录文件
(2) rmdir
rmdir
int rmdir(const char *pathname);
功能:
删除空目录文件
参数:
pathname:
目录文件的路径
返回值:
成功返回0
失败返回-1
(3)getcwd
getcwd
char *getcwd(char *buf, size_t size);
功能:
获得当前工作目录的绝对路径
参数:
buf:存放路径空间首地址
size:最大存放字符的长度
返回值:
成功返回存放路径字符串空间首地址
失败返回NULL
(4)chdir
chdir
int chdir(const char *path);
功能:
切换程序当前目录的工作路径
参数:
path:目的路径
返回值:
成功返回0
失败返回-1
本文所有代码的头文件
#ifndef __HEAD_H_
#define __HEAD_H_
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<unistd.h>
#include<fcntl.h>
#include<dirent.h>
#include<time.h>
#include<sys/time.h>
#endif
#include"../head.h"
int main()
{
char str[200]={0};
//新建目录文件
mkdir("diretory",0777);
//获取当前工作目录绝对路径
getcwd(str,sizeof(str));
printf("%s\n",str);
//切换当前目录工作路径
chdir("/home/linux/Desktop");
//打印改变后的文件路径
getcwd(str,sizeof(str));
printf("%s\n",str);
/* rmdir("diretory"); 删除此文件*/
return 0;
}
(5)chmod
chmod
int chmod(const char *pathname, mode_t mode);
chmod命令使用
chmod 0777 filename
chmod 0664 filename
chmod +/-r/w/x filename
功能:
修改文件权限
参数:
pathname:文件路径
mode:权限值 0777 0664
返回值:
成功返回0
失败返回-1
目录文件的读取
操作方法: 打开目录
读取目录项
关闭目录
(1)opendir
opendir
DIR *opendir(const char *name);
功能:
打开目录
参数:
name:目录文件路径
返回值:
成功返回目录流指针
失败返回NULL
(2)closedir
closedir
int closedir(DIR *dirp);
功能:
关闭目录流指针
参数:
dirp:目录流指针
返回值:
成功返回0
失败返回-1
(3)readdir
readdir
struct dirent *readdir(DIR *dirp);
功能:
读取目录项
参数:
dirp:目录流指针
返回值:
成功返回目录项指针
失败返回NULL
读到末尾返回NULL返回值类型
struct dirent {
ino_t d_ino; /* 节点编号 */
off_t d_off; /* 早期文件系统中,telldir返回文件在目录内的偏移 */
unsigned short d_reclen; /* 记录的实际长度 */
unsigned char d_type; /* 文件类型 */
char d_name[256]; /* 文件名 */
};
#include"../head.h"
/*显示输入目录路径下的文件,不包括隐藏文件*/
int List(char *dirname)
{
DIR *dp=NULL;
struct dirent *pp=NULL;
dp=opendir(dirname);//打开目录
if(dp==NULL)
{
return -1;
}
while(1)
{
pp=readdir(dp);//读取目录项
if(pp==NULL)
{
break;
}
if('.'==*pp->d_name)//跳过隐藏文件
{
continue;
}
printf("pp->d_name=%s/%s\n",dirname,pp->d_name);//打印目录项的文件名
}
closedir(dp);
return 0;
}
int main()
{
char dirname[256]={0};
printf("请输入目录路径\n");
scanf("%s",dirname);
List(dirname);
return 0;
}
#include"../head.h"
/*查找输入目录路径下所有的文件,不包括隐藏文件,并显示查找耗费的时间*/
int Listdir(char *dirname)
{
char filepath[1024]={0};
DIR *dp=NULL;
struct dirent *pp=NULL;
dp=opendir(dirname);
if(dp==NULL)
{
return -1;
}
while(1)
{
pp=readdir(dp);//接收目录项
if(pp==NULL)
{
return -1;
}
if('.'==*pp->d_name)//跳过隐藏文件
{
continue;
}
sprintf(filepath,"%s/%s",dirname,pp->d_name);//dirname是路径,pp->d_name是文件名,将绝对路径存入filepath
printf("%s\n",filepath);
if(DT_DIR==pp->d_type)//如果文件是目录文件则递归查找里面的文件(标红是虚拟机的问题)
{
Listdir(filepath);//递归调用List(filepath)
}
}
closedir(dp);
return 0;
}
int main()
{
char dirname[600]={0};
struct timeval start;
struct timeval end;
long ts=0;
struct tm *ptm=NULL;
printf("请输入目录路径:\n");
scanf("%s",dirname);
gettimeofday(&start,NULL);//获得从1970.1.1到查找前的秒数,精确到微秒
Listdir(dirname);
gettimeofday(&end,NULL);//获得从1970.1.1到查找后的秒数,精确到微秒
ts = (end.tv_sec * 1000000 + end.tv_usec) - (start.tv_sec * 1000000 + start.tv_usec);
printf("耗时 %ld.%ld s\n", ts / 1000000, ts % 1000000);
return 0;
}
链接文件
1.软链接(符号链接)
创建软链接文件的命令
ln -s 被链接的文件名 软链接文件名
ln -s b.txt a.txt
a.txt 链接b.txt通过文件名进行链接,(a.txt)软链接文件中保存的是被它连接文件(b.txt)的文件名,当删除b.txt,a.txt不能再打开,若是重新创建 b.txt 则 a.txt 又可以重新打开
文件打开方式
普通文件:
文件名 -> inode -> 数据块
软链接:
软连接文件名 -> inode -> 数据块 -> 链接向的文件名 -> inode -> 数据块
(1)symlink
int symlink(const char *target, const char *linkpath);
功能:
创建一个linkpath的软连接文件,里面存放target字符串
参数:
target:链接向的文件名
linkpath:软链接文件名
返回值:
成功返回0
失败返回-1
(2)readlink
ssize_t readlink(const char *restrict path, char *restrict buf, size_t bufsize);
功能:
读取软链接文件本身内容
参数:
path:软链接文件名
buf:存放软链接文件内容的缓冲区
bufsize:缓冲区的大小
返回值:
成功返回读取的字节数
失败返回-1
#include"../head.h"
int main()
{
FILE *fp=NULL;
char tmpbuf[32]={0};
symlink("file.txt","a.txt");//建立一个链接向file.txt的链接文件a.txt
fp=fopen("a.txt","r");
if(fp==NULL)
{
perror("failed to open");
return -1;
}
fgets(tmpbuf,sizeof(tmpbuf),fp);//获得a.txt链接向的文件的内容
printf("%s\n",tmpbuf);
memset(tmpbuf,0,sizeof(tmpbuf));//将tmpbuf中的内容重置
readlink("a.txt",tmpbuf,sizeof(tmpbuf));//获得a.txt中保存的内容(链接向的文件名即file.txt)
printf("%s\n",tmpbuf);
fclose(fp);
return 0;
}
2.硬链接
ln 被链接的文件名 硬链接文件名
ln b.txt a.txt
通过在磁盘中存放的inode节点进行链接,使用同一个inode节点,不同链接文件名类似于不同名字,删除文件链接关系断开a.txt和b.txt内容一致,当删除b.txt后,硬链接断开,a.txt还可以打开且内容保持不变,再重新创建b.txt后,b.txt不再使用之前的inode节点,即两文件没有关系
(1) link
link
int link(const char *oldpath, const char *newpath);
功能:
创建一个newpath的硬链接文件
参数:
oldpath:要链接的文件名
newpath:硬链接文件名
返回值:
成功返回0
失败返回-1
(2)unlink
unlink
int unlink(const char *pathname);
功能:
删除链接文件名,并让硬链接个数-1 ,如果一个磁盘空间硬链接个数为0,需要回收磁盘空间
参数:
pathname:链接文件名
返回值:
成功返回0
失败返回-1
include"../head.h"
int main()
{
link("file.txt","a.txt");//创建硬链接
unlink("file.txt"); //删除硬链接
return 0;
}