所以我使用mbed编译器进行编程,这是我目前的代码。
pc.baud(9600);
dev1.baud(19200);
char command[5];
//pc.puts("Initialized1X\n");
//while(1) {
if (1) {
dev1.gets(command, 6); //this is causing my error...just waiting for command, must fix
if (command[0] != 0x68){
for (int x=0; x<4; x++){
command[x] = command[x+1];
}
command[4] = 0x16;
}
for (int i=0; i<5; i++) {
pc.printf("%x ", command[i]);
}
pc.printf("\n");
sampleRates = command[2];
if (command[1] == 0x01){
switch (sampleRates){
case 0x01: pc.printf("44.1k\n");
return;
case 0x02: pc.printf("48k\n");
return;
case 0x03: pc.printf("88.2k\n");
return;
case 0x04: pc.printf("96k\n");
return;
case 0x05: pc.printf("176.4k\n");
return;
case 0x06: pc.printf("192k\n");
return;
case 0x07: pc.printf("352k\n");
return;
case 0x08: pc.printf("384k\n");
return;
case 0x09: pc.printf("705.6k\n");
return;
case 0x10: pc.printf("768k\n");
return;
}
}
}
//}
使用dev1.gets(命令,6);我从另一台设备获得输入。代码工作正常,除非我需要在程序中添加其他函数。其他函数不会运行,因为它最终等待dev.1gets()命令的输入。有什么方法可以让它快速检查,接受输入并继续前进?我使用了dev1.readable()的if语句;但是直到我再次执行它才将命令带入数组,因为它只进入循环。也许是否有办法同时检查和保存?
答案 0 :(得分:0)
通过中断将数据输入缓冲区。
使用双缓冲可能是一个好主意,并保留一个标志,指示特定缓冲区是否包含一个新的&#39; &#39;完成&#39;命令 等待处理。
中断处理程序维护循环缓冲区并处理实际的I / O.
让中断处理程序足够智能,以便识别完整的命令&#39;已进入。
当一个完整的命令&#39;已进入,中断为特定缓冲区设置一个标志,主程序可以查看/重置以确定是否有一个&#39;命令&#39;可以处理。
上述标志需要受到保护,因此在读取/重置标志时,请使用互斥锁或使用主功能禁用中断。