实现输出当前目录下的文件名

ls功能:

方法一:

#include <iostream>
#include <algorithm>
#include <stdio.h>
#include <stdlib.h>
#include <dirent.h>
#include <sys/types.h>
#include <string.h>
#include <string>
using namespace std; bool cmp( string s1,string s2){
return s1<s2;
} int main()
{
DIR *dir;
char s[];
string data[];
int tot=;
struct dirent *rent;
dir =opendir(".");
while(rent=readdir(dir))
{
strcpy(s,rent->d_name);
if(s[]!='.'){
data[tot]=s;
tot++;
}
}
sort(data,data+tot,cmp);
for(int i=;i<tot;i++)
cout<<data[i]<<" ";
puts("");
closedir(dir);
return ;
}

方法二:

#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>
#include <pwd.h>
#include <grp.h>
#include <time.h>
#include <dirent.h>
int do_ls(char *dir,char *filename,int lflag)
{
int n;
struct stat buf;
char out[];
struct passwd *pw;
struct group *gr;
struct tm *t;
if(lflag == ) //如果不带l参数,直接显示文件/目录名
{
printf("%s\t",filename);
return ;
}
if(lstat(dir,&buf)<)
{
fprintf(stderr,"stat error:%s\n",strerror(errno));
return -;
}
switch(buf.st_mode & S_IFMT) //获取字符串的属性:普通文件-、目录d、字符设备c、块设备b、管道文件p、连接文件l、套接字文件s
{
case S_IFREG:
printf("-");
break;
case S_IFDIR:
printf("d");
break;
case S_IFCHR:
printf("c");
break;
case S_IFBLK:
printf("b");
break;
case S_IFIFO:
printf("p");
break;
case S_IFLNK:
printf("l");
break;
case S_IFSOCK:
printf("s");
break;
}
for(n=; n>=; n--) //打印文件的读写属性:读r、写w、执行x、无权限-
{
if(buf.st_mode&(<<n))
{
switch(n%)
{
case :
printf("r");
break;
case :
printf("w");
break;
case :
printf("x");
break;
default:
break;
}
}
else
{
printf("-");
}
}
printf(" %d",buf.st_nlink); //硬链接数,此链接非彼链接,指(包含)目录的个数,文件为1,目录起始为2,再加上目录里包含的目录个数(不递归,只一层)
pw = getpwuid(buf.st_uid); //所属用户名
printf(" %s",pw->pw_name);
gr = getgrgid(buf.st_gid); //所属组名
printf(" %s",gr->gr_name);
printf(" %ld",buf.st_size); //字节计总大小
t = localtime(&buf.st_atime); //最后一次访问时间
printf(" %d-%d-%d %d:%d"
,t->tm_year+
,t->tm_mon+
,t->tm_mday
,t->tm_hour
,t->tm_min);
printf(" %s ",filename);
if(S_ISLNK(buf.st_mode)) //判断是否为链接,是返回真
{
printf(" -> ");
if(readlink(filename,out,)==-)
{
//printf("readlink error\n");
}
printf("%s",out);
}
printf("\n");
return ;
}
int ls_prepare(char *w,int aflag,int lflag) //ls的准备工作
{
struct stat buf; //man lstat可以看到此结构
char name[];
DIR *dir; //类似打开文件的fd描述符
struct dirent *pdr; //man readdir可以看到此结构
if(lstat(w,&buf)<) //获取文件/目录属性并赋值给buf,该函数和lstat一样,只是当w为链接时,指代他本身,并不存在文件
{
fprintf(stderr,"stat error:%s\n",strerror(errno));
return -;
}
if(S_ISDIR(buf.st_mode)) //判断是否为目录,是返回真
{
dir = opendir(w); //打开目录
while ((pdr = readdir(dir))!=NULL) //读/遍历目录
{
if(aflag==) //如果不带a参数,越过以.开头的所有文件/目录
{
if(pdr->d_name[]=='.')
continue;
memset(name,,);
strcpy(name,w); //拷贝
strcat(name,"/"); //追加
strcat(name,pdr->d_name);
do_ls(name,pdr->d_name,lflag);
}
else //有a参数显示所有
{
memset(name,,);
strcpy(name,w);
strcat(name,"/");
strcat(name,pdr->d_name);
do_ls(name,pdr->d_name,lflag);
}
}
closedir(dir);
}
else //为文件则直接显示
{
do_ls(w,w,lflag);
}
return ;
}
int main(int argc,char **argv)
{
int aflag =;
int lflag =;
char c;
int i;
while((c = getopt(argc,argv,"al"))!=-) //解析命令行参数,即-/--后面的字符串和给定的字符串匹配,有未解析字母返回字母或问号(取决于第3个参数),否则返回-1
{
switch(c) //此处仅匹配a(所有)和l(列表),即只支持参数a、l
{
case 'a':
aflag =;
break;
case 'l':
lflag =;
break;
default:
break;
}
}
if(argc == optind )
{
ls_prepare("./",aflag,lflag);
}
else
{
for(i=optind; i<argc; i++) //所有目录都传进去
ls_prepare(argv[i],aflag,lflag);
}
printf("\n");
return ;
}

ls -l功能:

#include <stdio.h>
#include <sys/types.h>
#include <dirent.h>
#include <sys/stat.h>
#include <pwd.h>
#include <grp.h> void show_file_info(char* filename, struct stat* info_p) {
char* uid_to_name(), *ctime(), *gid_to_name(), *filemode();
void mode_to_letters();
char modestr[11]; mode_to_letters(info_p->st_mode, modestr); printf("%s", modestr);
printf(" %4d", (int) info_p->st_nlink);
printf(" %-8s", uid_to_name(info_p->st_uid));
printf(" %-8s", gid_to_name(info_p->st_gid));
printf(" %8ld", (long) info_p->st_size);
printf(" %.12s", 4 + ctime(&info_p->st_mtime));
printf(" %s\n", filename); } void 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';
}
} char* uid_to_name(uid_t uid){
struct passwd* getpwuid(),* pw_ptr;
static char numstr[10]; if((pw_ptr = getpwuid(uid)) == NULL){
sprintf(numstr,"%d",uid); return numstr;
}else{
return pw_ptr->pw_name;
}
} char* gid_to_name(gid_t gid){
struct group* getgrgid(),* grp_ptr;
static char numstr[10]; if(( grp_ptr = getgrgid(gid)) == NULL){
sprintf(numstr,"%d",gid);
return numstr;
}else{
return grp_ptr->gr_name;
}
}
void do_ls(char dirname[]) {
DIR* dir_ptr;
struct dirent* direntp; if ((dir_ptr = opendir(dirname)) == NULL) {
fprintf(stderr, "ls2: cannot open %s \n", dirname);
} else {
while ((direntp = readdir(dir_ptr)) != NULL) {
dostat(direntp->d_name);
} close(dir_ptr);
}
} void dostat(char* filename) {
struct stat info; if (stat(filename, &info) == -1) {
perror(filename);
} else {
show_file_info(filename, &info);
}
} int main(int ac,char* av[]){
if(ac == 1){
do_ls(".");
}else{
while(--ac){
printf("%s: \n",*++av);
do_ls(*av);
}
}
}

  

用C++实现Linux中shell的ls功能的更多相关文章

  1. Linux中Shell

    Linux中Shell Shell是什么 ​ Shell是一个命令行解释器,为用户提供了一个向Linux内核发送请求以便运行程序的界面系统级程序,可以用Shell来启动.挂起.停止.编写一些程序. S ...

  2. linux中shell变量$#,$@,$0,$1,$2的含义解释

    linux中shell变量$#,$@,$0,$1,$2的含义解释: 变量说明: $$ Shell本身的PID(ProcessID) $! Shell最后运行的后台Process的PID $? 最后运行 ...

  3. linux中shell变量$#,$@,$0,$1,$2的含义解释

    linux中shell变量$#,$@,$0,$1,$2的含义解释 linux中shell变量$#,$@,$0,$1,$2的含义解释:  变量说明:  $$  Shell本身的PID(ProcessID ...

  4. Linux中shell变量$0,$?等含义

    linux中shell变量$#,$@,$0,$1,$2的基本含义: 变量说明: $$ Shell本身的PID(ProcessID) $! Shell最后运行的后台Process的PID $? 最后运行 ...

  5. 【转】linux中shell变量$#,$@,$0,$1,$2的含义解释

    原文网址:http://www.cnblogs.com/fhefh/archive/2011/04/15/2017613.html linux中shell变量$#,$@,$0,$1,$2的含义解释: ...

  6. 【Shell】linux中shell变量$#,$@,$0,$1,$2的含义解释 && set 关键字使用

    linux中shell变量$#,$@,$0,$1,$2的含义解释   摘抄自:ABS_GUIDE 下载地址:http://www.tldp.org/LDP/abs/abs-guide.pdf linu ...

  7. linux中shell变量$#,$@,$0,$1,$2的含义

    linux中shell变量$#,$@,$0,$1,$2的含义解释: 变量说明: $$ Shell本身的PID(ProcessID) $! Shell最后运行的后台Process的PID $? 最后运行 ...

  8. linux中shell变量$#,$@,$0,$1,$2

    linux中shell变量$#,$@,$0,$1,$2的含义解释: 变量说明: $$ Shell本身的PID(ProcessID) $! Shell最后运行的后台Process的PID $? 最后运行 ...

  9. 浅谈linux中shell变量$#,$@,$0,$1,$2,$?的含义解释

    浅谈linux中shell变量$#,$@,$0,$1,$2,$?的含义解释 下面小编就为大家带来一篇浅谈linux中shell变量$#,$@,$0,$1,$2的含义解释.小编觉得挺不错的,现在就分享给 ...

随机推荐

  1. Hyper-V无法文件拖拽解决方案~~~这次用一个取巧的方法架设一个FTP来访问某个磁盘,并方便的读写文件

    异常处理汇总-服 务 器 http://www.cnblogs.com/dunitian/p/4522983.html 服务器相关的知识点:http://www.cnblogs.com/dunitia ...

  2. ExtJS 4.2 组件介绍

    目录 1. 介绍 1.1 说明 1.2 组件分类 1.3 组件名称 1.4 组件结构 2. 组件的创建方式 2.1 Ext.create()创建 2.2 xtype创建 1. 介绍 1.1 说明 Ex ...

  3. 利用XAG在RAC环境下实现GoldenGate自动Failover

    概述 在RAC环境下配置OGG,要想实现RAC节点故障时,OGG能自动的failover到正常节点,要保证两点: 1. OGG的checkpoint,trail,BR文件放置在共享的集群文件系统上,R ...

  4. C#多线程之线程同步篇3

    在上一篇C#多线程之线程同步篇2中,我们主要学习了AutoResetEvent构造.ManualResetEventSlim构造和CountdownEvent构造,在这一篇中,我们将学习Barrier ...

  5. angular2系列教程(十一)路由嵌套、路由生命周期、matrix URL notation

    今天我们要讲的是ng2的路由的第二部分,包括路由嵌套.路由生命周期等知识点. 例子 例子仍然是上节课的例子:

  6. js面向对象学习 - 对象概念及创建对象

    原文地址:js面向对象学习笔记 一.对象概念 对象是什么?对象是“无序属性的集合,其属性可以包括基本值,对象或者函数”.也就是一组名值对的无序集合. 对象的特性(不可直接访问),也就是属性包含两种,数 ...

  7. [转载]C#中MessageBox.Show用法以及VB.NET中MsgBox用法

    一.C#中MessageBox.Show用法 MessageBox.Show (String) 显示具有指定文本的消息框. 由 .NET Compact Framework 支持. MessageBo ...

  8. .NET Core 2016 回顾

    都在回顾自己的2016,今天我们来看看.NET Core的2016. 每一年的脚步的确是快,转眼间马上就2017.新的一年,带着理想和抱负继续出发. 1 月 ASP.NET 5 改名 ASP.NET ...

  9. QT内省机制、自定义Model、数据库

    本文将介绍自定义Model过程中数据库数据源的获取方法,我使用过以下三种方式获取数据库数据源: 创建 存储对应数据库所有字段的 结构体,将结构体置于容器中返回,然后根据索引值(QModelIndex) ...

  10. 总结iOS开发中的断点续传那些事儿

    前言 断点续传概述 断点续传就是从文件赏赐中断的地方重新开始下载或者上传数据,而不是从头文件开始.当下载大文件的时候,如果没有实现断点续传功能,那么每次出现异常或者用户主动的暂停,都会从头下载,这样很 ...