реклама на сайте
подробности

 
 
> Рекурсивный алгоритм, для перебора файлов на диске
Ivan Kuznetzov
сообщение Feb 25 2011, 20:29
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 307
Регистрация: 6-02-08
Из: Россия, Екатеринбург
Пользователь №: 34 798



Делаю плеер на АВРке, файловая система fatfs. Подскажите пожалуйста, как грамотно реализовать рекурсивный алгоритм поиска файлов с функцией перемещения по текущему воспроизводимому файлу "вперед-назад", с возможностью работы с подпапками.


--------------------
Разработчик
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 5)
ar__systems
сообщение Feb 26 2011, 19:40
Сообщение #2


self made
****

Группа: Свой
Сообщений: 855
Регистрация: 7-03-09
Из: Toronto, Canada
Пользователь №: 45 795



зачем рекурсивный?
Go to the top of the page
 
+Quote Post
Ivan Kuznetzov
сообщение Feb 27 2011, 17:02
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 307
Регистрация: 6-02-08
Из: Россия, Екатеринбург
Пользователь №: 34 798



Цитата(ar__systems @ Feb 27 2011, 00:40) *
зачем рекурсивный?

Хочется перемещаться вперед-назад по файлам.


--------------------
Разработчик
Go to the top of the page
 
+Quote Post
rezident
сообщение Feb 27 2011, 18:26
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 10 920
Регистрация: 5-04-05
Пользователь №: 3 882



Я слабо знаком с предметом обсуждения, но у меня возник встречный вопрос:разве fatfs файловая система с последовательным доступом к файлам? Из беглого чтения описания - вроде нет. Тогда причем тут вообще рекурсия и рекурсивный алгоритм? Вы хотите создать список воспроизведения наподобие playlist? Ну так что вам мешает его создать? Может вам нужен не "рекурсивный алгоритм", а алгоритм случайного выбора из имеющегося списка файлов? Уточните исходный вопрос.
Go to the top of the page
 
+Quote Post
KRS
сообщение Feb 27 2011, 23:06
Сообщение #5


Профессионал
*****

Группа: Модераторы
Сообщений: 1 951
Регистрация: 27-08-04
Из: Санкт-Петербург
Пользователь №: 555



Насколько я понял рекурсивный - потому что с обходом дерева каталогов. Т.е. нужно просто перейти к следующему файлу - если это подкаталог - то к первому файлу подкаталога...
Если бы просто надо было получить список всех файлов - то это была бы рекурсивная функция!

А т.к. надо получить следующий файл, надо запоминать данные в виде массива с текущими позициями в каждом каталоге. В самом тупом виде будет примерно следующее
Код
unsigned level;
DIR last;
unsigned dir_pos[MAX_LEVEL];
char* get_next_file(void)
{
    while(1) {
        f_readdir(&last,...);
        если подкаталог {
            ++level;
            f_opendir(&last,...)
            continue;
        }
        если конец {
            dir_pos[level]=0;
            --level;
            открыть каталог верхнего уровня
            пропустить dir_pos[level] файлов
            continue;
        }
        ++dir_pos[level];
        return имя файла
    }
}
Go to the top of the page
 
+Quote Post
sergeeff Jr.
сообщение Mar 1 2011, 19:08
Сообщение #6


Знающий
****

Группа: Свой
Сообщений: 568
Регистрация: 8-07-07
Из: Занзибар
Пользователь №: 28 964



И тут немного инфы...
http://base.vingrad.ru/view/1971-Kak-nayti-fayl-na-diske


--------------------
"Познание бесконечности требует бесконечного времени, а потому работай не работай - все едино". А. и Б. Стругацкие
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 23rd July 2025 - 05:24
Рейтинг@Mail.ru


Страница сгенерированна за 0.02519 секунд с 7
ELECTRONIX ©2004-2016