Nano Hash - криптовалюты, майнинг, программирование

Как получить общее доступное дисковое пространство в системах Posix?

Я пишу кроссплатформенное приложение, и мне нужно все доступное дисковое пространство. Для систем posix (Linux и Macos) я использую statvfs. Я создал этот метод С++:

long OSSpecificPosix::getFreeDiskSpace(const char* absoluteFilePath) {
   struct statvfs buf;

   if (!statvfs(absoluteFilePath, &buf)) {
      unsigned long blksize, blocks, freeblks, disk_size, used, free;
      blksize = buf.f_bsize;
      blocks = buf.f_blocks;
      freeblks = buf.f_bfree;

      disk_size = blocks*blksize;
      free = freeblks*blksize;
      used = disk_size - free;

      return free;
   }
   else {
      return -1;
   }
}

К сожалению, я получаю довольно странные значения, которые не могу понять. Например: f_blocks = 73242188 f_bsize = 1048576 f_bfree = 50393643 ...

Являются ли эти значения битами, байтами или чем-то еще? Я прочитал здесь в stackoverflow, что это должны быть байты, но тогда я бы получил общее количество свободных байтов: f_bsize*f_bfree = 1048576*50393643, но это означает 49212,542 ГБ... слишком много...

Я делаю что-то не так с кодом или что-то еще? Спасибо!

10.10.2010

  • Какую файловую систему вы используете с размером блока 1048576? 10.10.2010
  • Это расширенная версия Mac OS (с учетом регистра, в журнале). Сейчас я работаю на Mac, но, насколько я понимаю, это должно работать. 10.10.2010
  • Помимо странности с вашим размером блока и вашим предполагаемым диском на 70 ТБ, имейте в виду, что long в 32-разрядной OSX составляет всего 32 бита. Даже если у вас есть правильные числа, этого, вероятно, достаточно для вашего количества блоков, но недостаточно для вашего количества байтов. Диски размером до 4 ГБ легко доступны у специализированных поставщиков ;-) 10.10.2010
  • Помимо ошибки в возвращаемом типе, нет причин, по которым я получаю странные значения в структуре? Есть ли другой способ получить эти значения? Спасибо! 10.10.2010
  • А, теперь, когда я присмотрюсь к этому поближе, проверьте, равны ли f_bsize и f_frsize. Бьюсь об заклад, это не так. Номера блоков и свободных блоков относятся к f_frsize, а не f_bsize. 10.10.2010

Ответы:


1

Я не знаю OSX достаточно хорошо, чтобы предсказать, что это определенно ответ, но f_blocks и f_bfree на самом деле относятся к «фундаментальным блокам» или «фрагментам» (которые имеют размер buf.f_frsize байт), а не к «размеру блока файловой системы» (который составляет buf.f_bsize байт):

http://www.opengroup.org/onlinepubs/009695399/basedefs/sys/statvfs.h.html

f_bsize — это просто подсказка о предпочтительном размере для операций ввода-вывода, это не обязательно связано с тем, как разделена файловая система.

10.10.2010

2

Следующие строки:

disk_size = blocks*blksize;
free = freeblks*blksize;

Вызывает переполнение при наличии ОГРОМНЫХ HD.

У меня тоже были странные результаты, пока я не выяснил, что мой HD составляет 455 ГБ, пожалуйста, рассмотрите возможность приведения блоков, blksize и freeblks vars к unsigned long задолго до выполнения умножения.

Что-то вроде этого:

unsigned long long disk_size = (unsigned long long) (blocks) * (unsigned long long) (blksize)

Я видел много подобных вопросов, но никто не заметил этого в ответах.

26.04.2012
  • Хороший улов! Я тоже видел странные числа (беззнаковые длинные длинные) 17.04.2015

  • 3

    Я полагаю, что последние два ответа верны и полезны. Однако я решил, просто заменив функцию statvfs на функцию statfs. Размер блока тогда 4096, как и ожидалось, и все кажется правильным. Спасибо!

    10.10.2010
  • Я не вижу, где statfs устарело в OS X. Также statfs выдает правильные значения. 12.09.2012
  • Я также не вижу этого: developer.apple.com/library/mac/#documentation/Darwin/Reference/. 12.09.2012
  • Документация Apple говорит об этом в конце документа statvfs: Функции statvfs() и fstatvfs() соответствуют стандарту IEEE Std 1003.1-2001 (``POSIX.1''). Стандартизированные переносимые приложения не могут зависеть от этих функций, возвращающих какую-либо достоверную информацию. Эта реализация пытается предоставить столько полезной информации, сколько предоставляет базовая файловая система, с учетом ограничений указанных типов данных. 25.06.2015
  • Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..