Поведение PuTTY по умолчанию при получении нулевого символа '\0'

Поведение PuTTY по умолчанию при получении нулевого символа '\0'

Я изучаю неожиданное поведение на выходе терминала относительно получения нулевого символа '\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 


Связанный контент