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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Проверить, можно ли из данных букв составить заданное слово S http://www.cyberforum.ru/cpp-beginners/thread763333.html
Люди, помогите решить задачу: Двумерный массив М N содержит некоторые буквы русского алфавита, расположенные в произвольном порядке. Написать программу, проверяющую можно ли из этих букв составить данное слово S.
C++ Преобразовать int в char * Есть какое-то целое число. Допустим 12451243. Его необходимо преобразовать в строку. У меня есть поле TenString (десят. строка), внутри поле Data. Выклыдываю прототип функции toString и ее описание: void toString(int); void TenString::toString(int _number) { int m = _number; int k = 0; while(m!=0) { http://www.cyberforum.ru/cpp-beginners/thread763304.html
C++ Как перегрузить оператор ввода?
Как перегрузить оператор ввода? rational.h #define _Rational_h_ #include <iostream> using namespace std; int nod(int p, int q) { if (p < 0) p = -p;
C++ Циклический сдвиг(маленький косяк)
#include <iostream> using namespace std; #include <math.h> #include <conio.h> #include <windows.h> int main() { SetConsoleCP(1251); SetConsoleOutputCP(1251); const int n=3,m=4;
C++ Определить, имеется ли в строке три цифры подряд http://www.cyberforum.ru/cpp-beginners/thread763272.html
Определить, имеется ли в строке три цифры подряд.
C++ Напечатать все слова отличные от последнего слова, предварительно перенести последнюю букву в начало слова Дано текст, содержащий от 2 до 30 слов, в каждом из которых от 2 до 10 латинских букв, между соседними словами - не менее одного пробела. Напечатать все слова отличные от последнего слова, предварительно превратив каждое из них по следующему правилу: перенести последнюю букву в начало слова. подробнее

Показать сообщение отдельно
Leningradeс
10 / 10 / 1
Регистрация: 03.03.2011
Сообщений: 331

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

16.01.2013, 14:10. Просмотров 1926. Ответов 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
Но все же бы человеческие комментарии хотелось услышать)
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru