/*
1、用户输入任意目录名称,显示该目录下的文件列表信息,包括文件类型,文件权限,文件大小,文件名称
2、拷贝用户输入的文件到当前目录下
3、第二点功能,使用4种方式完成,并比较说明效率
*/

/*

struct stat {
dev_t st_dev; //文件的设备编号
ino_t st_ino; //节点
mode_t st_mode; //文件的类型和存取的权限
nlink_t st_nlink; //连到该文件的硬连接数目,刚建立的文件值为1
uid_t st_uid; //用户ID
gid_t st_gid; //组ID
dev_t st_rdev; //(设备类型)若此文件为设备文件,则为其设备编号
off_t st_size; //文件字节数(文件大小)
unsigned long st_blksize; //块大小(文件系统的I/O 缓冲区大小)
unsigned long st_blocks; //块数
time_t st_atime; //最后一次访问时间
time_t st_mtime; //最后一次修改时间
time_t st_ctime; //最后一次改变时间(指属性)
};

先前所描述的st_mode 则定义了下列数种情况:
S_IFMT 0170000 文件类型的位遮罩
S_IFSOCK 0140000 scoket
S_IFLNK 0120000 符号连接
S_IFREG 0100000 一般文件
S_IFBLK 0060000 区块装置
S_IFDIR 0040000 目录
S_IFCHR 0020000 字符装置
S_IFIFO 0010000 先进先出

S_ISUID 04000 文件的(set user-id on execution)位
S_ISGID 02000 文件的(set group-id on execution)位
S_ISVTX 01000 文件的sticky位

S_IRUSR(S_IREAD) 00400 文件所有者具可读取权限
S_IWUSR(S_IWRITE)00200 文件所有者具可写入权限
S_IXUSR(S_IEXEC) 00100 文件所有者具可执行权限

S_IRGRP 00040 用户组具可读取权限
S_IWGRP 00020 用户组具可写入权限
S_IXGRP 00010 用户组具可执行权限

S_IROTH 00004 其他用户具可读取权限
S_IWOTH 00002 其他用户具可写入权限
S_IXOTH 00001 其他用户具可执行权限

上述的文件类型在POSIX中定义了检查这些类型的宏定义:
S_ISLNK (st_mode) 判断是否为符号连接
S_ISREG (st_mode) 是否为一般文件
S_ISDIR (st_mode) 是否为目录
S_ISCHR (st_mode) 是否为字符装置文件
S_ISBLK (s3e) 是否为先进先出
S_ISSOCK (st_mode) 是否为socket
*/

#include<stdio.h>
#include <dirent.h>
#include <unistd.h>
#include <sys/stat.h>
#include <string.h>
#include<sys/time.h>
#include<fcntl.h>

int mode_to_letters(int mode,char *str)
{

strcpy(str,"----------");

if(S_ISDIR(mode))str[0] = 'd';

if(S_ISCHR(mode))str[0] = 'c';

if(S_ISBLK(mode))str[0] = 'b';

if(mode&S_IRUSR)str[1] = 'r';

if(mode&S_IWUSR)str[2] = 'w';

if(mode&S_IXUSR)str[3] = 'x';

if(mode&S_IRGRP)str[4] = 'r';

if(mode&S_IWGRP)str[5] = 'w';

if(mode&S_IXGRP)str[6] = 'x';

if(mode&S_IROTH)str[7] = 'r';

if(mode&S_IWOTH)str[8] = 'w';

if(mode&S_IXOTH)str[9] = 'x';

return 0;

}
int dostat(const char *path)
{
struct stat info;
char modestr[16];
if(stat(path, &info)==-1)
{
printf("%s stat error\n",path);
return -1;

}
printf(" %s %ld ", path,info.st_size);
mode_to_letters(info.st_mode,modestr);

printf("%s\n",modestr);
return 0;
}

int cpchar(char *src, char *des)
{
FILE *fpsrc,*fpdes;
char ch;

fpsrc = fopen(src, "r");
if(fpsrc==NULL)
{
printf("open src fail\n");
return -1;
}

fpdes = fopen(des, "w");
if(fpdes==NULL)
{
printf("open des fail\n");
return -1;
}

while(1)
{
if((ch=fgetc(fpsrc))!=EOF)
{
fputc(ch,fpdes);
//printf("%c",ch);
}
else
{
break;
}
}

fclose(fpsrc);
fclose(fpdes);

return 0;
}

/*fgets fputs 一行*/
int cpline(char *src, char *des)
{
FILE *fpsrc,*fpdes;
char buf[1024];

fpsrc = fopen(src, "r");
if(fpsrc==NULL)
{
printf("open src fail\n");
return -1;
}

fpdes = fopen(des, "w");
if(fpdes==NULL)
{
printf("open des fail\n");
return -1;
}

while(1)
{
if(fgets(buf,1024,fpsrc)!=NULL)
{
fputs(buf,fpdes);
//printf("%s",buf);
}
else
{
break;
}
}

fclose(fpsrc);
fclose(fpdes);

return 0;
}

/*fread fwrite 一块*/
int cpblk(char *src, char *des)
{
FILE *fpsrc,*fpdes;
char buf[1024];
int num;

fpsrc = fopen(src, "r");
if(fpsrc==NULL)
{
printf("open src %s fail\n",src);
return -1;
}

fpdes = fopen(des, "w");
if(fpdes==NULL)
{
printf("open des %s fail\n",des);
return -1;
}

while(1)
{
if((num=fread(buf,sizeof(char),1024,fpsrc))>0)
{
fwrite(buf,sizeof(char),num,fpdes);
//printf("%d ",num);
}
else
{
break;
}
}

fclose(fpsrc);
fclose(fpdes);

return 0;
}

/*系统read write*/
int cp(char *src, char *des)
{
int fd1,fd2;
char buf[1024];
int nbyte;

if((fd1 = open(src, O_RDONLY)) < 0)
{
printf("open src fail!\n");
return -1;
}

if((fd2 = open(des, O_WRONLY)) < 0)
{
printf("open des fail!\n");
return -1;
}

while((nbyte = read(fd1, buf, sizeof(buf))) > 0)
{
write(fd2, buf, nbyte);
}

close(fd1);
close(fd2);

return 0;
}

int mydir(const char *dirname){
DIR *dp;
struct dirent *dir;
dp=opendir(dirname);
char path[256];
char inputfilename[256];
char pathbuf[256];
char path_getcwd[256];
int ret;
if(dp==NULL)
{

printf("open dir fail");
return -1;
}
strncpy(path,dirname,strlen(dirname)+1);
while(1)
{
dir=readdir(dp);
if(dir!=NULL)
{
//printf("%ld %s\n",dir->d_ino,dir->d_name);

strncpy(pathbuf,path,strlen(path)+1);
dostat(strcat(strcat(pathbuf,"/"),dir->d_name));

}
else
{
break;

}
}
//拷贝用户输入的文件到当前目录下
printf("please input copy file name to current dir\n");
scanf("%s",inputfilename);
strncpy(pathbuf,path,strlen(path)+1);
printf("%s\n",pathbuf);
getcwd(path_getcwd,256);

strcat(strcat(pathbuf,"/"),inputfilename);
strcat(strcat(path_getcwd,"/"),inputfilename);
struct timeval tv;
long start_time,stop_time,use_time;

gettimeofday(&tv,NULL);
//printf("tv_usec:%d\n",tv.tv_usec);
start_time=tv.tv_sec*1000+tv.tv_usec/1000;

ret=cp(pathbuf,path_getcwd);

gettimeofday(&tv,NULL);
//printf("tv_usec:%d\n",tv.tv_usec);
stop_time=tv.tv_sec*1000+tv.tv_usec/1000;
use_time=stop_time-start_time;
if(ret==0)
{

printf("cp test success! use time= %ld msec\n",use_time);
}

gettimeofday(&tv,NULL);
//printf("tv_usec:%d\n",tv.tv_usec);
start_time=tv.tv_sec*1000+tv.tv_usec/1000;

ret=cpchar(pathbuf,path_getcwd);

gettimeofday(&tv,NULL);
//printf("tv_usec:%d\n",tv.tv_usec);
stop_time=tv.tv_sec*1000+tv.tv_usec/1000;
use_time=stop_time-start_time;
if(ret==0)
{

printf("cpchar test success! use time= %ld msec\n",use_time);
}

gettimeofday(&tv,NULL);
//printf("tv_usec:%d\n",tv.tv_usec);
start_time=tv.tv_sec*1000+tv.tv_usec/1000;

ret=cpline(pathbuf,path_getcwd);

gettimeofday(&tv,NULL);
//printf("tv_usec:%d\n",tv.tv_usec);
stop_time=tv.tv_sec*1000+tv.tv_usec/1000;
use_time=stop_time-start_time;
if(ret==0)
{

printf("cpline test success! use time= %ld msec\n",use_time);
}

gettimeofday(&tv,NULL);
//printf("tv_usec:%d\n",tv.tv_usec);
start_time=tv.tv_sec*1000+tv.tv_usec/1000;

ret=cpblk(pathbuf,path_getcwd);

gettimeofday(&tv,NULL);
//printf("tv_usec:%d\n",tv.tv_usec);
stop_time=tv.tv_sec*1000+tv.tv_usec/1000;
use_time=stop_time-start_time;
if(ret==0)
{

printf("cpblk test success! use time= %ld msec\n",use_time);
}

closedir(dp);

return 0;
}

int main(int argc, char * argv[])
{
if(argc != 2)
{
printf("Input dir error\n");
return -1;
}

mydir(argv[1]);
return 0;
}

运行结果如下,read write 最快, fread fwrite次之, 之后是fputs 和fputc.

另外fputs和fputc用于非字符串文件时会有问题,深层原因还待分析。

Linux 目录操作和4中文件拷贝效率测试的更多相关文章

  1. Java学习-045-目录中文件拷贝

    挺晚的了,直接上码.敬请各位小主参阅,若有不足之处,敬请指正,非常感谢! 目录文件拷贝源码: /** * <strong>目录拷贝</strong><br> * & ...

  2. 【技术博客】 关于laravel5.1中文件上传测试的若干尝试

    关于laravel5.1中文件上传测试的若干尝试 作者:ZGJ 版本:v1.0 PM注:本人这两天也正在尝试解决这一问题,如有进展将及时更新这一博客 在我们的软工第二阶段中,我开始着手进行后端控制器的 ...

  3. windows下操作linux虚拟机映射网络驱动器中文件提示chmod权限不足解决方案

    为了方便操作,linux虚拟机会通过windows下连接网络驱动器的方式共享自己的文件,对于前端来说,我想把gulp放在windows磁盘,操作虚拟机中的php文件,一来节省虚拟机磁盘大小,二来解决虚 ...

  4. 3、Linux目录操作

    1.目录操作概述 2.ls显示目录内容 命令名称:ls 命令英文原意:list 命令所在路径:/bin/ls 执行权限:所有用户 功能描述:显示目录文件 ls  -a    显示目录下的所有文件(包括 ...

  5. 【Linux】【一】linux 目录切换、创建目录和文件、编辑目录以及文件(txt)

    以下 是在指定目录下创建文件夹目录,以及在该目录下创建txt文件进行编辑,保存. 然后删除相关文件以及目录的命令操作记录. 本操作记录中的命令简单解释: pwd 显示当前路径 ls 显示当前目录下的文 ...

  6. 总结java中文件拷贝剪切的5种方式-JAVA IO基础总结第五篇

    本文是Java IO总结系列篇的第5篇,前篇的访问地址如下: 总结java中创建并写文件的5种方式-JAVA IO基础总结第一篇 总结java从文件中读取数据的6种方法-JAVA IO基础总结第二篇 ...

  7. Linux下不同机器之间的文件拷贝

    通过 scp 命令实现不同机器之间的文件拷贝. (1)本机考到目标机器:scp 本机文件 目的地: 如:scp /home/odp-web.war   root@192.168.6.137:/usr/ ...

  8. Ubuntu 14.04 + Linux 3.14.34 系统调用实现文件拷贝

    采用 64位系统, ubuntu 14.04 + 新内核linux-3.14.34 下载地址https://www.kernel.org/pub/linux/kernel/v3.x/linux-3.1 ...

  9. 在 Linux 平台及 IPv4 环境中构建 IPv6局域网 测试环境

    在 Linux 平台及 IPv4 环境中构建 IPv6 测试环境 1 IPv6简介 IPv6(Internet Protocol Version 6)作为 IPv4 的升级版本,它是作为一共软件升级安 ...

随机推荐

  1. Android(java)学习笔记81:java异常处理机制

    1.try....catch/try...catch...finally package cn.itcast_02; /* * 我们自己如何处理异常呢? * A:try...catch...final ...

  2. Firefox便携版

    安装firefox后默认配置文件在C:\Users\Administrator\AppData\Roaming\Mozilla\Firefox 可以在快捷方式里设置不同的配置文件,但是要注意参数的含义 ...

  3. phpnow升级php版本 php-5.2.14-Win32升级至5.3.5

    PHPNow自带的PHP版本为5.2.14,而最后一次更新在于2010-9-22.下面来升级PHP5.3.5: 1.下载安装文件: 先下载PHP5.3.5,下载地址:php-5.3.5-Win32-V ...

  4. js实现刮刮卡效果

    <!DOCTYPE html> <html> <body> <canvas/> <script> (function(bodyStyle) ...

  5. 虚拟机 VirtualBox 自制帮助文档

    初学 VirtualBox ,网络上教程很多,图片一张一张的费流量,讲得又比较散,于是花了一下午制作了此 CHM 帮助文档. 下载:(图片另存为--重命名为 RhinoC.rar --解压缩)

  6. Sqlserver 关于游标

    对于sql来说查询的思维方式的面向集合对于游标来说:思维方式是面向行的 性能上:游标会吃更多内存,减少可见的并发,锁定资源等 当穷尽了while循环,临时表,表变量,自建函数,或其他方式仍然无法实现某 ...

  7. sqlserver 公有表达式

    了解通用表达式: 为了让代码简洁:在一个查询中引用另外的结果集都是通过视图而不是子查询来进行分解,但是视图是系统级对象,如果数据集仅仅需要在存储过程或是自定义函数中使用一次的话,使用view有些奢侈哈 ...

  8. sql查询统计,根据新闻类别ID统计,没有数据显示0

    有两张表,新闻信息表MessageInfo和新闻类别表MessageType.表结构如下: 然后需要实现下面这种查询结果: 这个是我面试时遇到的,上面的新闻类型是乱写的.当时没有做出来,然后回来又研究 ...

  9. Agile.Net 组件式开发平台 - 组件开发示例

    所谓组件式开发平台,它所有的功能模块都是以组件的形式扩展的,下面我来演示一个简单的组件开发例程. Agile.Net开发管理平台项目,已经托管在开源中国码云平台(http://git.oschina. ...

  10. Excel数据生成Sql语句的方法

    选中想要生成的列,套用表格格式,选中表包含标题的选项确定,然后在最右边的一列第二行处,点击函数功能,选择CONCATENATE,在文本里输入想要的结构即可  代码如下 复制代码 ,=CONCATENA ...