当前位置: 首页 > 面试题库 >

有效地列出目录中包含很多条目的文件

沈实
2023-03-14
问题内容

我需要递归地读取目录结构,但是一旦我读完每个目录的所有条目,还需要执行其他步骤。因此,我需要编写自己的递归逻辑(并且不能使用简单的filepath.Walk例程)。但是,ioutil.ReadDirfilepath.Glob例程仅返回切片。如果我要限制
ext4xfs 的限制,并建立一个目录,文件的数量达到数十亿怎么办?我希望 golang
具有os.FileInfo在通道而不是排序的切片上返回未排序的一系列(甚至更好的是原始字符串)的函数。在这种情况下,我们如何有效地读取文件条目?

上面引用的所有函数似乎都依赖readdirnamesos / dir_unix.go ,并且由于某种原因,它仅在看起来很容易产生
gothread
并将值推入通道的情况下才创建数组。。这样做可能有合理的逻辑,但目前尚不清楚。我是Go的新手,所以我也很容易错过其他人显而易见的一些原则。

这是源代码,为方便起见:

func (f *File) readdirnames(n int) (names []string, err error) {
    // If this file has no dirinfo, create one.
    if f.dirinfo == nil {
        f.dirinfo = new(dirInfo)
        // The buffer must be at least a block long.
        f.dirinfo.buf = make([]byte, blockSize)
    }
    d := f.dirinfo

    size := n
    if size <= 0 {
        size = 100
        n = -1
    }

    names = make([]string, 0, size) // Empty with room to grow.
    for n != 0 {
        // Refill the buffer if necessary
        if d.bufp >= d.nbuf {
            d.bufp = 0
            var errno error
            d.nbuf, errno = fixCount(syscall.ReadDirent(f.fd, d.buf))
            if errno != nil {
                return names, NewSyscallError("readdirent", errno)
            }
            if d.nbuf <= 0 {
                break // EOF
            }
        }

        // Drain the buffer
        var nb, nc int
        nb, nc, names = syscall.ParseDirent(d.buf[d.bufp:d.nbuf], n, names)
        d.bufp += nb
        n -= nc
    }
    if n >= 0 && len(names) == 0 {
        return names, io.EOF
    }
    return names, nil
}

问题答案:

ioutil.ReadDirfilepath.Glob周围阅读目录条目只是方便的功能。

如果提供的参数> 0 ,则可以直接使用Readdiror
Readdirnames方法批量读取目录条目n

对于像读取目录条目这样的基本操作,无需增加goroutine和通道的开销,也无需提供返回错误的替代方法。如果愿意,您始终可以使用自己的goroutine和通道模式包装批处理的调用



 类似资料:
  • 问题内容: 假设我有一个目录中,其中有3个符号连接其他目录 ,和。我想列出中的所有文件,包括在那些,和。 为了更通用,我想列出所有文件,包括目录中的符号链接文件。,等停止在符号链接上,而无需导航到它们以进一步列出。 问题答案: 该选项将完成您想要的。它取消引用符号链接。 因此,您的命令将是: 您也可以使用 该选项指示find跟随符号链接到目录。 在Mac OS X上使用 如已弃用。

  • 问题内容: 列出1000多个目录和子目录中文件名的最快方法是什么? 编辑; 我使用的当前代码是: 问题答案: 看起来不错(递归遍历目录)瓶颈将是您需要执行的所有文件I / O操作,优化Java不会显示任何实际改进。

  • 问题内容: 在PHP中可以包含脚本目录吗? 即代替: 是否有类似的东西: 似乎找不到找到针对特定类的大约10个子类的集合的好方法。 问题答案:

  • 问题内容: 我已经看到了 列出目录中所有文件的 函数,但是我又如何也可以列出 子目录 中的所有文件,因此它会 返回一个数组 ? 所以 类似于 问题答案: foreach (new RecursiveIteratorIterator(new RecursiveDirectoryIterator(‘.’)) as $filename) { // filter out “.” and “..” if (

  • 我有一个简单的问题:我使用迭代一个大的、深嵌套的目录结构,如下所示: 我的目标是添加特定目录下的所有文件,我知道该目录最多是下的级别。 语言级别为Java8。

  • 问题内容: 我正在尝试检索目录中的所有图像,包括所有子目录。我目前正在使用 这可行,但是结果是: 我希望它一次执行整个目录分支,因此结果是: 非常感谢您的帮助,欢呼! 附注:如果我只需将所有子目录都包含在投资组合下,而不必用通配符具体说明每个目录,那也很好。 问题答案: 从示例