Форум программистов, компьютерный форум CyberForum.ru

Размер и поиск файлов _findfirst описание - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.92
Leningradeс
 Аватар для Leningradeс
10 / 10 / 1
Регистрация: 03.03.2011
Сообщений: 331
16.01.2013, 14:10     Размер и поиск файлов _findfirst описание #1
Всем привет!
В общем наткнулся на такой код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
#include <stdio.h>
#include <stdlib.h>
#include <io.h>
#include <iostream>
using namespace std;
 
int main (void)
{
    setlocale (LC_ALL, "RUSSIAN");
    //Размер директории
    long int sizedir = 0;
    //Вспомогательные структуры и дескрипторы
    struct _finddata_t file;
    intptr_t hFile;
 
    //Открываем текущую директорию
    if ((hFile = _findfirst ( "*.*", &file )) == -1L)
    {
        cerr << "Не удалось открыть директорию" << endl;
    }
    else
    {
        //В цикле обходим файлы директории
        do
        {
            cout << file.name << " = " << file.size << " bytes " << endl;
            sizedir += file.size;
        }
        while ( _findnext (hFile, &file) == 0 );
        //Закрываем директорию
        _findclose (hFile);
        cout << "Общий размер директории = " << sizedir << " bytes " << endl;
    }
    //Остановка перед закрытием окна
    system ("PAUSE");
    return 0;
}
И очень хотелось бы изучить и понять многие моменты, например:
C++
1
struct _finddata_t file;
C++
1
intptr_t hFile;
C++
1
if ((hFile = _findfirst ( "*.*", &file )) == -1L)
C++
1
while ( _findnext (hFile, &file) == 0 );
Так код рабочий и подсчитывает кол-во файлов, их размер и выводит эти данные на экран. Хотелось бы его понять что там за структура такая, и что за не структура, в общем про весь _findxxxxxxx узнать.
Нашел вот такое:

OgreSearchOps.h
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/*
-----------------------------------------------------------------------------
This source file is part of OGRE
(Object-oriented Graphics Rendering Engine)
For the latest info, see [url]http://www.ogre3d.org/[/url]
 
Copyright (c) 2000-2012 Torus Knot Software Ltd
 
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
 
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
 
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
-----------------------------------------------------------------------------
*/
#ifndef __SearchOps_H_
#define __SearchOps_H_
 
// Emulate _findfirst, _findnext on non-Windows platforms
 
 
 
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <stdlib.h>
 
#include "OgrePlatform.h"
 
 
#if OGRE_PLATFORM != OGRE_PLATFORM_WIN32
 
#include <dirent.h>
#include <unistd.h>
#if OGRE_PLATFORM != OGRE_PLATFORM_SYMBIAN
#include <fnmatch.h>
#endif
 
/* Our simplified data entry structure */
struct _finddata_t
{
    char *name;
    int attrib;
    unsigned long size;
};
 
#if OGRE_PLATFORM != OGRE_PLATFORM_SYMBIAN
#define _A_NORMAL 0x00  /* Normalfile-Noread/writerestrictions */
#define _A_RDONLY 0x01  /* Read only file */
#define _A_HIDDEN 0x02  /* Hidden file */
#define _A_SYSTEM 0x04  /* System file */
#define _A_ARCH   0x20  /* Archive file */
#endif
#define _A_SUBDIR 0x10  /* Subdirectory */
 
long _findfirst(const char *pattern, struct _finddata_t *data);
int _findnext(long id, struct _finddata_t *data);
int _findclose(long id);
#endif
 
#endif
Но все же бы человеческие комментарии хотелось услышать)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.01.2013, 14:10     Размер и поиск файлов _findfirst описание
Посмотрите здесь:

C++ Файлы, функции. Определить размер трех файлов с данными именами.
C++ Странное поведение функций _findfirst() и _findnext()
Классы с наследованием. Описать класс fruit, содержащий поля сорт, размер, описание C++
C++ Где пишется описание для выходного файла .exe (например описание процесса)
Вычислить размер файлов через консоль C++
C++ Получить размер больших файлов
C++ Размер файлов в каталоге
NTFS, вывести суммарный размер файлов в заданном каталоге C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Геон
0 / 0 / 0
Регистрация: 07.02.2016
Сообщений: 1
09.07.2016, 22:47     Размер и поиск файлов _findfirst описание #2
Leningradeс
1.
C++
1
struct _finddata_t file;
Это объявление переменной file, структурного типа _finddata_t. (что такое структура см. Инициализация структуры в си ( c struct ))
Определение _finddata_t находится в подключаемой библиотеке io.h

C
1
2
3
4
5
6
7
8
9
struct _finddata_t
{
    unsigned    attrib;     /* Attributes, see constants above. */
    time_t      time_create;
    time_t      time_access;    /* always midnight local time */
    time_t      time_write;
    _fsize_t    size;
    char        name[FILENAME_MAX]; /* may include spaces. */
};
См. информация по этой структуре: https://msdn.microsoft.com/ru-ru/library/kda16keh.aspx

2.
C++
1
intptr_t hFile;     /* Это объявление знаковой целочисленной переменной hFile */
intptr_t является знаковым целочисленным memsize-типом и способен безопасно хранить в себе указатель в независимости от разрядности платформы.
См. http://rsdn.ru/article/cpp/XXtraps64bit.xml, http://www.viva64.com/ru/t/0023/

3.
C++
1
if ((hFile = _findfirst ( "*.*", &file )) == -1L)
Происходит вызов функции _findfirst, определение которой находится в подключаемой библиотеке io.h. Функция ищет в текущей директории файл, соответствующий маске "*.*" (т.е с любым именем и любым типом). Характеристики первого найденного файла помещаются в структурную переменную file, откуда их потом можно прочитать.
См: https://msdn.microsoft.com/ru-ru/library/kda16keh.aspx
Если функция вернула -1, значит поиск закончился неудачей. Иначе, в hFile помещается дескриптор (это что-то вроде указателя на первый встреченный файл, но подробней не знаю) для последующего использования в функциях _findnext и _findclose

4.
C++
1
while ( _findnext (hFile, &file) == 0 );
Функция findnext() продолжает поиск, начатый функцией findfirst(). Находя при каждом срабатывании очередной файл, по маске, заданной в _findfirst. Пока функция возвращает нулевое значение - цикл продолжается.

P.S.
Спасибо за шаблон кода. Я его взял за основу при выполнении д.з. в рамках учебного курса по языку Си. Вот моя адаптация:
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#include <stdio.h>
#include <stdlib.h>
#include <io.h>
 
int main(void)
{
    //Вспомогательные структуры и дескрипторы
    struct _finddata_t f;
    long hFile;
    
    //Открываем текущую директорию
    if ((hFile = _findfirst ( "*.*", &f )) == -1L)
    {
       printf("Cannot open dir");
    }
    else
    {
         //В цикле обходим файлы директории
         do
         {
             printf ("%s %ld\n", f.name, f.size);
         }
         while ( _findnext (hFile, &f) == 0 );
         //Закрываем директорию
        _findclose (hFile);
    }
    //Остановка перед закрытием окна
    system("PAUSE");
    return 0;
}
Также я читал: http://www.c-cpp.ru/content/findfirst-findnext - там, по сравнению с сайтом MSDN, объяснение мне показалось понятнее. Но там, будто, для другой редакции Си.

P.P.S. http://www.specialist.ru/course/si
Yandex
Объявления
09.07.2016, 22:47     Размер и поиск файлов _findfirst описание
Ответ Создать тему
Опции темы

Текущее время: 03:00. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru