通过串行端口

时间:2017-10-14 15:07:58

标签: c++ serial-port putty

我遇到的问题是发送消息L"第二行"在我的应用程序中读取我正在接收的串行端口" S e c o n d L e n e",但在putty我收到"第二行"我认为这是因为wchar_t以16位编码,所以每个字母之间都有一个00。但是我仍然不知道如何解决这个问题,我对所有这些事情都很陌生,所以这有点令人困惑。

我不确定是否需要在我的应用程序中将字节大小设置为16?

我想发送LPCWSTR LogpszMessage,因为我正在从应用程序发送一些日志消息。这是另一个代码,在这里工作必须在那里工作。

putty配置为8位,这就是我发送的内容;

#include "stdafx.h"

#include <windows.h>
#include <stdio.h>

typedef _Null_terminated_ CONST WCHAR *LPCWSTR, *PCWSTR;

int main()
{

    LPCWSTR LogpszMessage = L"Second line";
    char bytes_to_send[] = "test1 y test2";

    // Declare variables and structures
    HANDLE hSerial;
    DCB dcbSerialParams = { 0 };
    COMMTIMEOUTS timeouts = { 0 };

    // Open the highest available serial port number
    fprintf(stderr, "Opening serial port...");
    hSerial = CreateFile(
        L"\\\\.\\COM24", GENERIC_READ | GENERIC_WRITE, 0, NULL,
        OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
    if (hSerial == INVALID_HANDLE_VALUE)
    {
        fprintf(stderr, "Error\n");
        return 1;
    }
    else fprintf(stderr, "OK\n");

    dcbSerialParams.DCBlength = sizeof(dcbSerialParams);
    if (GetCommState(hSerial, &dcbSerialParams) == 0)
    {
        fprintf(stderr, "Error getting device state\n");
        CloseHandle(hSerial);
        return 1;
    }

    dcbSerialParams.BaudRate = CBR_115200;
    dcbSerialParams.ByteSize = 8;
    dcbSerialParams.StopBits = ONESTOPBIT;
    dcbSerialParams.Parity = NOPARITY;
    if (SetCommState(hSerial, &dcbSerialParams) == 0)
    {
        fprintf(stderr, "Error setting device parameters\n");
        CloseHandle(hSerial);
        return 1;
    }

    // Set COM port timeout settings
    timeouts.ReadIntervalTimeout = 50;
    timeouts.ReadTotalTimeoutConstant = 50;
    timeouts.ReadTotalTimeoutMultiplier = 10;
    timeouts.WriteTotalTimeoutConstant = 50;
    timeouts.WriteTotalTimeoutMultiplier = 10;
    if (SetCommTimeouts(hSerial, &timeouts) == 0)
    {
        fprintf(stderr, "Error setting timeouts\n");
        CloseHandle(hSerial);
        return 1;
    }

    // Send specified text (remaining command line arguments)
    DWORD bytes_written, total_bytes_written = 0;
    fprintf(stderr, "Sending bytes...");
    /*if (!WriteFile(hSerial, bytes_to_send, sizeof(bytes_to_send), &bytes_written, NULL))
    {
        fprintf(stderr, "Error\n");
        CloseHandle(hSerial);
        return 1;
    }*/

    if (!WriteFile(hSerial, LogpszMessage, wcslen(LogpszMessage) * sizeof(wchar_t), &bytes_written, NULL))
    {
        fprintf(stderr, "Error\n");
        CloseHandle(hSerial);
        return 1;
    }
    fprintf(stderr, "%d bytes written\n", bytes_written);

    // Close serial port
    fprintf(stderr, "Closing serial port...");
    if (CloseHandle(hSerial) == 0)
    {
        fprintf(stderr, "Error\n");
        return 1;
    }
    fprintf(stderr, "OK\n");
    getchar();

    // exit normally
    return 0;
}

提前致谢。

1 个答案:

答案 0 :(得分:0)

我无法使用WideCharToMultiByte(),在尝试使用LPCWSTR LogpszMessage时产生错误,所以我使用wcstombs_s完成微软文档之后的工作并且它工作正常,现在当读取COM端口时没有由16位字符组成的空格。

谢谢Hans Passant