Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: scanf + колцевой буфер (WinAVR)
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > Cредства разработки для МК > GNU/OpenSource средства разработки
ARV
вот, решил задействовать функции ввода высокого уровня, а именно scanf.
сделал кольцевой буфер, в который складываются принимаемые по прерываниям из UART байты. создал стандартный поток ввода, как и нужно для реализации WinAVR, функция чтения символа возвращает _FDEV_EOF, если в кольцевом буфере "голова" совпадает с "хвостом", т.е. нет новых данных.

и вот что получается: буфер заполняется довольно медленно, а scanf пытается вычитывать данные быстро, в итоге после вычитывания первого же символа она получает EOF и, естественно, заканчивает ввод... то есть как ни крути, вводится 1 или (редко) два байта, и точка.

почему лыжи не едут?

что-то у меня не очень укладывается в голове, как организовать ввод данных так, чтобы использовать scanf и при этом не попадать в долгие ожидания поступления очередного символа...
neiver
Можно завести флаг наличия в буффере достаточного количества байт, чтоб их читать с помощью scanf.
Устанавливать его при получении символа разделителя (речь идёт о текстовом вводе/выводе).
Сбрасывать при чтении (если нет других разделителей в буффере).
Функция чтения символа возвращает _FDEV_EOF если этот флаг не установлен - читай в буффере нет разделителей.
ReAl
Цитата(ARV @ Jul 20 2010, 09:23) *
что-то у меня не очень укладывается в голове, как организовать ввод данных так, чтобы использовать scanf и при этом не попадать в долгие ожидания поступления очередного символа...
Почти никак.
EOF для scanf означает, что файл закончился, приплыли. Соответственно, он прекращает сканировать и вываливается.
Так что или в getchar ждать до посинения, или в нём же пользоваться сервисом вытесняющей ОС по ожиданию события поступления символа.

Ну или в шаге кооперативки набирать посимвольно в буфер до упомянутого выше разделителя (т.е. "по месту" реализованный gets() с отдачей управления) а потом вызывать sscanf.
ARV
да понятно, что с кооперативкой было бы проще... да перейти на нее трудов стоит. и все извращения в конечном итоге погасят весь выигрыш от scanf... подсчет разделителей, в принципе, немного снизит остроту проблемы, но ведь поиск разделителей - как раз и задача scanf, для этого ее и применять решил... получается, проще входной поток символов разбирать на лету без всяких io-функций...
klen
а мож ненада..... scanf использовать - вещ то жутковатя
ARV
Цитата(klen @ Jul 20 2010, 20:47) *
а мож ненада..... scanf использовать - вещ то жутковатя
а в чем жуть? поведение у нее весьма специфическое, это очевидно... но есть еще что-то, скрытое от глаз?
sergeeff
Я бы так выразился. scanf, как всякая функция "на все случаи жизни", страдает монстроподобностью. Совершенно не очевидно, что именно она вам нужна. Если вы подумаете, выяснится, что нужна реально 1/10 ее функциональности. Посему может проще самому чего написать?
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.