Linux C++获取文件夹大小1(通过lstat实现)

项目中要计算指定文件夹的大小。
百度查到这篇文章,https://my.oschina.net/Tsybius2014/blog/330628
方法可行,运行正确。

拿到我们的项目中,却遇到一些问题:程序中一些读文件的代码,开始报异常,读不到文件。这些问题是以前没有遇到过的。
到底是什么情况呢?排查了好久,终于发现该文章提供的计算文件夹大小的函数(暂且叫做GetDirectorySize),其中有改变当前目录的代码:

chdir(dir);

我们的项目是多线程的,一个线程调用GetDirectorySize,调用的过程中改变了当前目录,而此时另一个线程使用相对路径去读文件,原来能读到的,现在就读不到了。特别提示chdir改变的是,当前进程(当然包括其下所有线程)的工作目录!!!(具体可以查看线程共享进程的那些资源?
为了去掉GetDirectorySize的副作用,我重新实现了该函数:

#include <stdio.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <unistd.h>
#include <stdlib.h>
#include <dirent.h>
#include <string.h>

//计算某目录所占空间大小(包含本身的4096Byte)
long long int GetDirectorySize(char *dir)
{
	DIR *dp;
	struct dirent *entry;
	struct stat statbuf;
	long long int totalSize=0;

	if ((dp = opendir(dir)) == NULL)
	{
		fprintf(stderr, "Cannot open dir: %s\n", dir);
		return -1; //可能是个文件,或者目录不存在
	}
	
	//先加上自身目录的大小
	lstat(dir, &statbuf);
	totalSize+=statbuf.st_size;

	while ((entry = readdir(dp)) != NULL)
	{
		char subdir[256];
		sprintf(subdir, "%s/%s", dir, entry->d_name);
		lstat(subdir, &statbuf);
		
		if (S_ISDIR(statbuf.st_mode))
		{
			if (strcmp(".", entry->d_name) == 0 ||
				strcmp("..", entry->d_name) == 0)
			{
				continue;
			}

			long long int subDirSize = GetDirectorySize(subdir);
			totalSize+=subDirSize;
		}
		else
		{
			totalSize+=statbuf.st_size;
		}
	}

	closedir(dp);	
	return totalSize;
}

int main(int argc, char* argv[])
{
	char* dir = argv[1];
	long long int  totalSize = GetDirectorySize(dir);	
	printf("totalSize: %lld\n", totalSize);

	return 0;
}

 

转载于:https://my.oschina.net/zidanzzg/blog/812420

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: c语言遍历文件夹的方法如下: 1. 使用opendir函数打开文件夹, 并使用readdir函数读取文件夹中的文件名。 2. 使用循环遍历文件夹中的所有文件。 3. 对于每一个文件, 使用stat函数获取文件的信息, 包括文件类型(是否是文件夹)。 4. 如果是文件夹, 递归调用此函数, 进入新的文件夹继续遍历。 5. 当文件夹遍历完毕后, 使用closedir函数关闭文件夹。 下面是一个示例代码: ``` #include <stdio.h> #include <dirent.h> #include <sys/stat.h> void listdir(const char *name) { DIR *dir; struct dirent *entry; if (!(dir = opendir(name))) return; while ((entry = readdir(dir)) != NULL) { struct stat st; char path[1024]; snprintf(path, sizeof(path), "%s/%s", name, entry->d_name); if (lstat(path, &st) == -1) continue; if (S_ISDIR(st.st_mode)) { if (strcmp(entry->d_name, ".") == 0 || strcmp(entry->d_name, "..") == 0) continue; printf("%*s[%s]\n", indent, "", entry->d_name); listdir(path); } else printf("%*s- %s\n", indent, "", entry->d_name); } closedir(dir); } int main() { listdir("."); return 0; } ``` 希望这个示例代码能够帮助你理解文件夹遍历的方法。 ### 回答2: 遍历文件夹指的是以某种方式遍历文件夹中的所有文件和子文件夹。在计算机编程中,常用的遍历文件夹的方法包括递归和迭代。 递归遍历文件夹是一种深度优先的方式。这种方法会从根文件夹开始,首先获取当前文件夹中的所有文件和子文件夹。然后,对于每个子文件夹,再递归调用遍历文件夹方法,重复上述步骤,直到遍历到最底层的文件夹。这种方式可以确保遍历到文件夹中的每个文件和子文件夹,但可能会消耗较多的内存。 迭代遍历文件夹是一种广度优先的方式。这种方法会使用一个队列来存储待遍历的文件夹。开始时,将根文件夹入队。然后,从队列中取出一个文件夹获取其中的所有文件和子文件夹,并将它们入队。重复上述步骤,直到队列为空。这种方式可以逐层遍历文件夹,较递归方式占用较少的内存。 在实际编程中,可以根据具体需求选择适合的遍历文件夹的方法。递归方式相对简单,但可能导致栈溢出或死循环等问题。迭代方式相对复杂,但可以灵活控制遍历的深度和顺序。无论选择哪种方式,遍历文件夹都是访问文件系统中重要内容的基本操作之一。 ### 回答3: 遍历文件夹是指对指定的文件夹进行逐个查找和检索其中的文件和子文件夹的过程。 在计算机编程中,实现文件夹遍历通常需要使用递归算法。具体步骤如下: 1. 首先,我们需要指定一个顶层文件夹作为起始点。可以是任意一个已存在的文件夹。 2. 然后,我们通过读取起始文件夹的内容(包括文件和子文件夹),获取这些内容的相关信息,例如文件名、文件类型、文件大小等。 3. 对于每一个子文件夹,我们将重复步骤2,进一步查找其中的文件和子文件夹。这就是递归的过程,直到遍历到最底层的文件夹。 4. 遍历文件夹的过程中,可以根据需要进行文件的筛选,例如只处理某些特定类型的文件。 5. 最后,我们可以对遍历到的每一个文件进行自定义的操作,例如打印文件路径、复制文件、修改文件等。 通过遍历文件夹,我们可以方便地获取指定文件夹下的所有文件,对其进行批量处理,例如备份、删除、搜索等。这在文件管理、数据处理和程序开发中都是常见的应用场景。 需要注意的是,对于大型文件夹或者文件夹层级很深的情况下,可能会遇到性能问题,因此在实际开发时需要进行优化,例如通过并行处理来提高遍历速度,避免资源浪费和耗时过长。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值