
Я изучаю неожиданное поведение на выходе терминала относительно получения нулевого символа '\0'. Я отправляю строку, которая, как я ожидаю, будет содержать 2 \0, но это не отображается в PuTTY.
В соответствии сэтот вопросподразумевается, что PuTTY не отправляет null при нормальных обстоятельствах. Однако этому вопросу уже около 10 лет, и я предполагаю, что PuTTY получил обновления за этот период.
Я посмотрел вРуководство пользователя PuTTYи в основном нашел документацию по панелям PuTTY и много информации по сообщениям об ошибках и подключению.Глава 3.3обсуждает «Изменение конфигурации набора символов», но в основном касается нелатинских алфавитов и ссылается наГлава 4.10, которая является панелью перевода.
Мой вопрос прост:что обычно делает PuTTY, когда ему нужно получить символ \0? Он его не получает? Он получает символ, но не отображается в терминале?
Если Вам потребуется дополнительная информация, сообщите мне, пожалуйста.
Код, используемый для отправки данных в PuTTY, написан на языке C на плате STM32:
static int8_t CDC_Receive_FS(uint8_t* Buf, uint32_t *Len)
{
/* USER CODE BEGIN 6 */
USBD_CDC_SetRxBuffer(&hUsbDeviceFS, &Buf[0]);
USBD_CDC_ReceivePacket(&hUsbDeviceFS);
memset (buffer, '\0', 64); // clear the buffer
uint8_t len = (uint8_t)*Len; //Converts Len as uint32_t to len as uint8_t
memcpy(buffer, Buf, len); // copy the data to the buffer
memset(Buf, '\0', len); // clear the Buf also
//Code used to send message back
/*In the full version, there will be another function outside of this file.
* The buffer will be processed and a proper message will be sent.
* Check that other file to see how it gets processed when we eventually implement it.
*/
uint8_t transmit_message[64] = "TOWST_FIRMV_REEEEEEE_27\r\n"; //Do we have \r\n?
//CDC_Transmit_FS(transmit_message, sizeof(transmit_message));
//HAL_GPIO_TogglePin(GPIOF, GPIO_PIN_10);
//message_Received(buffer, len);
process_Message(buffer, len);
return (USBD_OK);
/* USER CODE END 6 */
}
void process_Message(uint8_t* message, uint16_t Len){
HAL_GPIO_TogglePin(GPIOF, GPIO_PIN_10);
uint8_t* inputCmd[5];
uint8_t* inputMessage[8];
uint8_t outputCmd[5];
uint8_t outputData[8];
// strcpy((char*) inputCmd, (const char*)message + COMMAND_CHAR);
// strcpy((char*) inputMessage, (const char*)message + DATA_CHAR);
if (strcmp(inputCmd, "FIRMV") == 0){
memcpy(outputCmd, "FIRMV", COMMAND_LENGTH);
memcpy(outputData, "01050A00", DATA_LENGTH);
}
else{
memcpy(outputCmd, "REEEE", COMMAND_LENGTH);
memcpy(outputData, "99999999", DATA_LENGTH);
}
// message_Received(message, Len);
send_Message(outputCmd, outputData);
}
void send_Message(uint8_t* cmd, uint8_t* data){
uint8_t outputMessage[25] = "TOWST_"; //Size of array is for future uses.
strncpy((char*) outputMessage + 8, "FIRMV", 5);
CDC_Transmit_FS(outputMessage, sizeof(outputMessage));
}
//Expected output: 'TOWST_\0\0FIRMV' based on this post, which per my understanding suggests that strncpy will fill in unfilled memory with null chars. https://aticleworld.com/how-to-use-strncpy-and-how-to-write-your-own-strncpy