无法在C ++中读取串行端口上的写入

时间:2015-03-09 04:47:09

标签: c++ visual-studio-2010 serial-port serial-communication

我正在Visual Studio 2010上用c ++编写串行通信代码。对于这个try this示例,它运行正常。现在,我尝试发送一个字符串,并通过缩短硬件的Rx和Tx引脚来读取它。这是我发送字符串的代码: -

char *buffer ="hello";
   DWORD bytesSend;
   DWORD errors;
   COMSTAT status;
   DWORD numWritten;
   WriteFile(hCom, buffer, strlen(buffer), &numWritten, NULL); 
   printf("send succesfully\n");

这是我的接收代码: -

DWORD numRead;

  BOOL ret = ReadFile(hCom, buffer, 5, &numRead, NULL);

    if(!ret)
    {
        printf("Read Fail\n");
    }
    else
    {
        printf("%s\n",buffer);
    }

在运行我的代码时,接收失败。那么,请告诉我问题出在哪里。这是我的完整代码。

#include "stdafx.h"

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

void PrintCommState(DCB dcb)
{
    //  Print some of the DCB structure values
    _tprintf( TEXT("\nBaudRate = %d, ByteSize = %d, Parity = %d, StopBits = %d\n"), 
              dcb.BaudRate, 
              dcb.ByteSize, 
              dcb.Parity,
              dcb.StopBits );
}


int _tmain( )
{
   DCB dcb;
   HANDLE hCom;
   BOOL fSuccess;
   TCHAR *pcCommPort = TEXT("COM1"); //  Most systems have a COM1 port

   //  Open a handle to the specified com port.
   hCom = CreateFile( pcCommPort,
                      GENERIC_READ | GENERIC_WRITE,
                      0,      //  must be opened with exclusive-access
                      NULL,   //  default security attributes
                      OPEN_EXISTING, //  must use OPEN_EXISTING
                      0,      //  not overlapped I/O
                      NULL ); //  hTemplate must be NULL for comm devices

   if (hCom == INVALID_HANDLE_VALUE) 
   {
       //  Handle the error.
       printf ("CreateFile failed with error %d.\n", GetLastError());
       return (1);
   }

   //  Initialize the DCB structure.
   SecureZeroMemory(&dcb, sizeof(DCB));
   dcb.DCBlength = sizeof(DCB);

   //  Build on the current configuration by first retrieving all current
   //  settings.
   fSuccess = GetCommState(hCom, &dcb);

   if (!fSuccess) 
   {
      //  Handle the error.
      printf ("GetCommState failed with error %d.\n", GetLastError());
      return (2);
   }

   PrintCommState(dcb);       //  Output to console

   //  Fill in some DCB values and set the com state: 
   //  57,600 bps, 8 data bits, no parity, and 1 stop bit.
   dcb.BaudRate = CBR_57600;     //  baud rate
   dcb.ByteSize = 8;             //  data size, xmit and rcv
   dcb.Parity   = NOPARITY;      //  parity bit
   dcb.StopBits = ONESTOPBIT;    //  stop bit

   fSuccess = SetCommState(hCom, &dcb);

   if (!fSuccess) 
   {
      //  Handle the error.
      printf ("SetCommState failed with error %d.\n", GetLastError());
      return (3);
   }

   //  Get the comm config again.
   fSuccess = GetCommState(hCom, &dcb);

   if (!fSuccess) 
   {
      //  Handle the error.
      printf ("GetCommState failed with error %d.\n", GetLastError());
      return (2);
   }

   PrintCommState(dcb);       //  Output to console

   _tprintf (TEXT("Serial port %s successfully reconfigured.\n"), pcCommPort);

   char *buffer ="hello";
   DWORD bytesSend;
   DWORD errors;
   COMSTAT status;
   DWORD numWritten;
    WriteFile(hCom, buffer, strlen(buffer), &numWritten, NULL); 
    printf("send succesfully\n");

  DWORD numRead;
  BOOL ret = ReadFile(hCom, buffer, 5, &numRead, NULL);

    if(!ret)
    {
        printf("Read Fail\n");
    }
    else
    {
        printf("%s",buffer);
    }



   return (0);
}

这是我的输出: - enter image description here

1 个答案:

答案 0 :(得分:0)