Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
Другие темы раздела
C++ Как положительной переменной присвоить отрицательное значение? https://www.cyberforum.ru/ cpp-beginners/ thread1026129.html
Надо изменить знак числа на противоположный. Условие: нельзя использовать клавишу "-" Как это можно сделать? #include <iostream> using namespace std; int main() { int a;
Упорядочить элементы структуры C++
Необходимо составить структуру, сделать сортировку по признаку, по убыванию или возрастанию... Вот код: #include "stdafx.h" #include <iostream> #include <Windows.h> #include <conio.h> #include <string.h> #include <stdlib.h> #include <stdio.h> #include <string>
C++ пытаюсь написать браузер Добрый день.Работаю в Visual C++. Сделал браузер на WebBrowser.Движок IE.Работает.Браузерная строка и 4 кнопки-перейти,обновить,вперед,назад. Но не пойму. 1)все время вылезает -произошла ошибка сценария.Продолжить?Нажимаю и да и нет-работает одинаково. Как это окно убрать или отключить. 2)Это я сделал на движке IE.А как на других движках.Это надо переходить с Visual C++ на другие... https://www.cyberforum.ru/ cpp-beginners/ thread1026122.html C++ вычислить и вывести на экран значение функции https://www.cyberforum.ru/ cpp-beginners/ thread1026119.html
вычислить и вывести на экран значение функции F(x) на отрезке с шагом h=0.1 и точностью e. Результат работы программы представить в виде след.таблицы: №, Значение х, значение функции F(x), Кол-во просуммированных слагаемых n. F(x)=-x/2!+x^3/4!-x^5/6!+x^7/8!-..., x принадлежит
Алгоритм std::set_union C++
Добрый вечер, попалась задача на данный алгоритм,библиотека <algorithm> подключена. Метод класса вызывается вот таким образом, pe.plansUnion(pe2);,где pe, pe2-объекты класса PlanEducation, в каждом из них есть поле vector<subject> discipls, но тут, видимо, это не важно. Важно вот, что: void PlanEducation::plansUnion(const PlanEducation& otherPlan){ vector<subject> disciplsUnion; ...
C++ Сформировать и распечатать квадратную матрицу Сформировать и распечатать квадратную матрицу А(10,10) следующего вида: 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 2 0 0 0 0 0 0 0 0 3 0 0 0 0 0 0 0 0 4 0 0 0 0 0 0 0 0 5 0 0 0 0 0 0 0 0 6 0 0 0 0 0 0 0 0 7 0 0 0 0 0 0 0 0 8 0 0 0 0 0 0 0 https://www.cyberforum.ru/ cpp-beginners/ thread1026116.html
C++ Код на С++ не корректно работает Задача: В одномерном массиве A=(a1, а2, ..., аn) все положительные элементы, имеющие четный порядковый номер, переписать в начало массива. #include"stdafx.h" #include"iostream" #include"conio.h" #include<time.h> using namespace std; void main() { https://www.cyberforum.ru/ cpp-beginners/ thread1026104.html Написать программу, которая считывает линейный массив натуральных чисел из файла C++
Пожалуйста помогите написать программу: 1.Написать программу, которая считывает линейный массив натуральных чисел из файла, имя которого вводится с клавиатуры, и выводит на экран те элементы, которые являются простыми числами. Заранее благодарен!!!
C++ Сдвоенные числа #include <cstdlib> #include <iostream> #include <Math.h> using namespace std; int main(int argc, char *argv) { int n, pred, tek, i, j, t = 0; cout<<"Vvedite granicu diapazona : "; cin>>n; for (i = 2; i <= n; i++){ https://www.cyberforum.ru/ cpp-beginners/ thread1026096.html C++ Умножение матриц,которые считываются с файлов https://www.cyberforum.ru/ cpp-beginners/ thread1026083.html
Допустим у нас в двух файлах а и б даны две одинаковые матрицы,нужно их считать и перемножить.Я напимал программу для этого,но она работает некорректно,выводит просто "1".Что не так? #include "stdafx.h" #include<iostream> #include"stdio.h" using namespace std; const int mn=100; void main()
C++ Задача на классы
Составить описание класса одномерных массивов строк, каждая строка задается длиной и указателем на выделенную для нее память. Предусмотреть возможность обращения к отдельным строкам массива по индексам, контроль выхода за пределы массивов, выполнения операций поэлементного сцепления двух массивов с образованием нового массива, слияния двух массивов с исключением повторяющихся элементов,...
C++ В чем ошибка ? ? https://www.cyberforum.ru/ cpp-beginners/ thread1026077.html
Вычислить с точностью e=0.0001 #include "stdafx.h" #include <iostream> #include <math.h> using namespace std; void main() { const float e = 0.0001;
1 / 1 / 0
Регистрация: 27.02.2013
Сообщений: 13
0

поиск файлов по маске в каталоге c++ - C++ - Ответ 5424306

02.12.2013, 20:32. Показов 2874. Ответов 0
Метки (Все метки)

Author24 — интернет-сервис помощи студентам
Программа выполняет поиск файлов в каталоге по заданной маске.
Количество потоков равно количеству каталогов. Найденные файлы сохраняются в файл, после завершения поиска всеми потоками, считывает данные из файла и выводит на экран. Синхронизация через семафор.

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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#include "stdafx.h"
#include "Windows.h" 
#include <iostream>
#include <string> 
#include <fstream>
 
#define MAXTHREAD 10
#define LogName "log.txt"
 
HANDLE hSemaphore; 
 
//чтение
void readFile()
{
    FILE *file;
    char arr[20];
    file = fopen(LogName, "r");
    while (fgets (arr, 20, file) != NULL)
    printf("%s", arr);
    printf("\n");
    fclose(file);
}
 
//запись
void appendLog(const char* filename)
{
     FILE* log = fopen(LogName,"a"); 
     fputs(filename,log);
     fputs("\r\n",log);
     fclose(log);
}
 
DWORD WINAPI FolderSearch( LPVOID param)
{
    WIN32_FIND_DATAA fd;
    //ищем первый файл
    HANDLE hf = FindFirstFileA(
                        (LPCSTR) param, // имя файла
                        &fd             // буфер данных
                              );
    if (hf != INVALID_HANDLE_VALUE)
    {         
            //захватываем и/или ожидаем семафор
            WaitForSingleObject(hSemaphore, INFINITE);  
            //записываем в лог
            appendLog(fd.cFileName);
            //отпускаем семафор +1      
            ReleaseSemaphore(hSemaphore,1,NULL);
        
            while ( FindNextFileA(hf, &fd) ) 
            { 
                //захватываем и/или ожидаем семафор
                WaitForSingleObject(hSemaphore, INFINITE);  
                //записываем в лог                
                appendLog(fd.cFileName);
                //отпускаем семафор +1
                ReleaseSemaphore(hSemaphore,1,NULL);
            } 
            //освобождаем ресурсы поиска файлов
            FindClose(hf); 
    }
    return 0;
}
 
int main(int argc, _TCHAR* argv[])
{
    
    printf("Input file mask for search:  ");
    std::string mask;
    //ввод маски
    std::cin >> mask;
    printf("Input folders count: ");
    int foldersCount;
    //ввод количества папок
    std::cin >> foldersCount;
    std::string folders[MAXTHREAD];
    //запрос папок
    for (int i=0; i<foldersCount; i++){
        printf("Input folder %d with \\:",i+1);
        //ввод папки
        std::cin >> folders[i];
    }
    //массив хэндлов потоков
    HANDLE aThread[MAXTHREAD];
    
    //содаём семафор с счётчиком 1, максимальное кол-во обращений - 1
    hSemaphore = CreateSemaphore(NULL,1,1,NULL);  
 
    //делаем пустой файл
     FILE* log = fopen(LogName,"w"); 
     fclose(log);
 
    //запускаем потоки с поиском
    DWORD ThreadID;
    for (int i=0; i<foldersCount; i++){
        folders[i].append(mask);
        aThread[i] = CreateThread( 
                        NULL,                                   // дескриптор защиты
                        0,                                      // начальный размер стека
                        (LPTHREAD_START_ROUTINE) FolderSearch,  // функция потока 
                        (LPVOID)folders[i].c_str(),             // параметр потока
                        0,                                      // опции создания
                        &ThreadID                               // идентификатор потокка
                                 );
    }
 
    //ждём пока все потоки завершатся
    WaitForMultipleObjects(foldersCount, aThread, TRUE, INFINITE);
 
    //освобождаем ресурсы потоков
    for(int i=0; i < foldersCount; i++ ) CloseHandle(aThread[i]);
 
    //освобождаем ресурсы семафора
    CloseHandle(hSemaphore);
    printf("Found files:\n");
    readFile();
    system("Pause");
    return 0;
}
Вопрос: Моя программа выполняет поиск только в текущем каталоге, без проверки подкаталогов.
Как сделать, чтобы поиск происходил так же и в подкаталогах текущего каталога?

Вернуться к обсуждению:
поиск файлов по маске в каталоге c++ C++
0
Заказать работу у эксперта
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.12.2013, 20:32
Готовые ответы и решения:

Поиск файлов по маске в каталоге
Программа выполняет поиск файлов в каталоге по заданной маске. Количество потоков равно количеству...

Поиск файлов по маске в каталоге и подкаталогах
Надо найти файы по маске в каталоге и подкаталогах. но у меня либо только в каталоге ищет ls...

Парсинг файлов в каталоге по маске
В документе Excel макросом необходимо реализовать такую фитчу: В каталоге, прописаном в переменной...

Чтение файлов, запись и дозапись в файл, поиск файлов в каталоге и поиск данных в файле
2. Создать файлы, в которых будут вмещаться строки с именами студентов и их средними балами. Каждый...

0
02.12.2013, 20:32
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.12.2013, 20:32
Помогаю со студенческими работами здесь

Поиск файлов по маске
Пытаюсь сделать поиск файлов в текущей директории, но вылазит 2 ошибки и не могу понять что с ней...

Поиск файлов по маске
Возможно ли сделать так ,чтобы программа сканировала диски и нашла файлы в формате .jpg ?

Поиск файлов по маске
Имеется имя файла, например : файл.txt Как определить нет ли в папке таких же файлов, только с...

Поиск файлов по маске
Нужно найти файлы по маске. Маска и каталог передаётся через параметры. Файлы ищутся также в...

0
Новые блоги и статьи
Что такое хорошо и что такое плохо, вид сбоку. Индивид и общество - грань не нарушения.
Hrethgir 18.01.2025
В моей личной жизни и времени, я рассуждаю категорией "хуже-лучше", в том плане, когда меня спросили например - "а зачем ты делаешь свой процессор?", то я ответил - "чтобы сделать свою жизнь лучше". . .
Передача по ссылке или по значению в Java?
InfoMaster 18.01.2025
В мире программирования на Java одним из ключевых аспектов, требующих глубокого понимания, является механизм передачи параметров в методы. Этот фундаментальный концепт часто становится источником. . .
Тернарный условный оператор в Python
InfoMaster 18.01.2025
В мире программирования существует множество инструментов и конструкций, позволяющих создавать эффективный и лаконичный код. Одним из таких инструментов является тернарный условный оператор, который. . .
Как удалить неотслеживаемые файлы из рабочего дерева Git
InfoMaster 18.01.2025
В процессе разработки программного обеспечения с использованием системы контроля версий Git часто возникает необходимость в управлении неотслеживаемыми файлами. Неотслеживаемые файлы (untracked. . .
Что делает код if __name__ == "__main__": в Python
InfoMaster 18.01.2025
В мире программирования на Python существует множество важных концепций, и одной из наиболее интересных является конструкция if __name__ == "__main__". Эта специальная конструкция играет ключевую. . .
Как заставить Git забыть об отслеживаемом файле, добавленном в .gitignore
InfoMaster 18.01.2025
В мире разработки программного обеспечения система контроля версий Git стала неотъемлемой частью рабочего процесса, позволяя эффективно отслеживать изменения в коде и управлять ими. Однако. . .
Что означает use strict в JavaScript и для чего используется
InfoMaster 18.01.2025
В мире современной веб-разработки JavaScript играет ключевую роль как один из основных языков программирования. По мере его эволюции возникла необходимость в механизмах, которые помогли бы. . .
Как работать со скрытыми (hidden) элементами в jQuery
InfoMaster 18.01.2025
В современной веб-разработке управление видимостью элементов на странице является одним из ключевых аспектов создания интерактивных пользовательских интерфейсов. jQuery предоставляет мощный набор. . .
Как переключаться между ветками (Branch) с помощью checkout в Git
InfoMaster 18.01.2025
Ветки в Git являются одной из ключевых концепций для управления версионностью кода, позволяя разработчикам эффективно работать в команде и параллельно развивать программные проекты. Каждый новый. . .
Что такое стек и куча, чем они отличаются и где находятся
InfoMaster 18.01.2025
Понимание основных концепций памяти в программировании В мире современного программирования эффективное управление памятью играет ключевую роль в создании производительных и надежных приложений. . . .
Как использовать комментарии в JSON
InfoMaster 18.01.2025
JSON (JavaScript Object Notation) представляет собой легкий и широко используемый формат обмена данными, который стал стандартом де-факто для веб-приложений и программных интерфейсов. При работе с. . .
Как заставить git pull перезаписать локальные файлы в Git
InfoMaster 18.01.2025
Проблема перезаписи локальных файлов в Git При работе с системой контроля версий Git разработчики часто сталкиваются с ситуацией, когда необходимо синхронизировать локальный репозиторий с. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru