我知道这很简单,但我不知何故错过了它。
szTemp[1024] = "";
sprintf((char*)szTemp, "%c%c", 0x7e, 0x00);
仅通过UART输出~
。任何超过1个字节都不起作用。但这确实有效:
sprintf((char*)szTemp, "some test string");
给予:some test string
更新:我正在与之通信的XBEE模块采用API命令帧。其中之一是数据传输帧。在不进入帧结构的情况下,要发送的字节是:
7E 00 17 10 01 00 13 A2 00 41 66 0F 42 FF FE 00 00 74 65 73 74 20 64 61 74 61 CA
我可以通过设置发送寄存器的值并等待它完成来写入uart:
COMTX = 0X7E;
while ((COMSTA0 & 0x40) == 0x00){}
答案 0 :(得分:2)
听起来你正试图在szTemp
中构建一个字节序列。
听起来这些字节可能都不是可打印的字符。
听起来像将szTemp
的内容传输到您的UART的代码工作正常。
如果你只想构造一个任意字节的字符串,你甚至不需要sprintf
。 (它可能会使用sprintf
工作,但它会更麻烦并且不会给你买任何东西。)试试这个:
szTemp[0] = 0x7e;
szTemp[1] = 0x17;
szTemp[2] = 0x10;
szTemp[3] = 0x01;
szTemp[4] = 0x00;
/* now your existing code for transmitting szTemp` to UART */
根据您发布的示例,听起来您的现有发送字符串到UART代码在到达0字节时停止,如果字符串是以空字符结尾的C字符串,这是有意义的。但很明显,如果要发送的字节是任意二进制字节,可能包含0x00
,那么您不希望在第0位停止。因此该代码可能需要重新处理。
我现在推测,但你可能想要这样的事情:
char szTemp[] = { 0x7E, 0x00, 0x17, 0x10, 0x01, 0x00, 0x13, 0xA2, 0x00,
0x41, 0x66, 0x0F, 0x42, 0xFF, 0xFE, 0x00, 0x00, 0x74,
0x65, 0x73, 0x74, 0x20, 0x64, 0x61, 0x74, 0x61, 0xCA };
int nch = 27;
int main()
{
int i;
for(i = 0; i < nch; i++) put_one_character(szTemp[i]);
}
void put_one_character(char c)
{
COMTX = c;
while((COMSTA0 & 0x40) == 0x00) {}
}