Разработка, производство и продажа радиоэлектронной аппаратуры
|
Карта сайта
|
Пишите нам
|
В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:
jobsmp@pochta.ru
Телесистемы
|
Электроника
|
Конференция «Микроконтроллеры и их применение»
ок, вот реализация без goto и вложенных if/else
Отправлено
koyodza
11 февраля 2008 г. 10:56
В ответ на:
goto можно убить только в if (tx_byte & (1UL<<(N_bit-2))), в if (N_bit==34) и if (N_bit==1) нельзя, иначе не отдаются стартовый и стоповый биты
отправлено Aleksey75 11 февраля 2008 г. 10:37
я не вникал, что именно оно должно делать, а тупо перевёл. Но чувствую, что это всё можно сделать ещё проще и лучше
N_bit=34;
while (N_bit>0)
{
bit_stat_1 = st_bit;
do
{
if (N_bit==34)
{
bit_stat_1 = start_1;
bit_stat_2 = start_2;
if (repit==1)
N_bit=1;
break;
}
if (N_bit==1)
{
bit_stat_2 = pause ;
break;
}
if (tx_byte & (1UL<<(N_bit-2)))
bit_stat_2 = one;
else
bit_stat_2 = zero;
}
while (FALSE);
//==== Transmit BIT ===
...
...
...
}
Составить ответ
|
Вернуться на конференцию
Ответы
Да уж лучше бы с goto :)
—
Oldring
(11.02.2008 11:43:36
91.76.17.197
,
пустое
)
:=P
—
koyodza
(11.02.2008 12:29:24
195.214.197.203
,
пустое
)
Отправка ответа
Имя*:
Пароль:
E-mail:
Тема*:
Сообщение:
Ссылка на URL:
URL изображения:
если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
введите число 38:
Перейти к списку ответов
|
Конференция
|
Раздел "Электроника"
|
Главная страница
|
Карта сайта
Web
telesys.ru