如题,我用CreateFile和ReadFile来读数据的。一般情况下都能正常通信。但是如果是系统刚启动完,第一次读串口时,怎么也读不到数据,就是ReadFile根本不返回。如果这时候我用WINDOWS带的超级终端来发送,接受一次数据后,程序就一切正常,可读数据了。不知道为什么。我是用串口线连自己的机器,一头连COM1,一头是USB转串口,模拟COM3。有谁遇到过这种问题?

解决方案 »

  1.   

    打开串口:
    m_ComportHandle = CreateFile( m_ComName,
    GENERIC_READ | GENERIC_WRITE,
    FILE_SHARE_READ | FILE_SHARE_WRITE,
    NULL,
    OPEN_EXISTING,
    FILE_ATTRIBUTE_NORMAL,
    NULL);
    if (m_ComportHandle == INVALID_HANDLE_VALUE)
    throw CComException(E_UNEXPECTED, GetLastErrorDesc(GetLastError()),
    __FILE__, __LINE__);
    设置状态: GetCommState( m_ComportHandle, &m_dcb );
    m_dcb.BaudRate = STRTOINT(m_BAUDRATE);
    m_dcb.ByteSize = STRTOINT(m_BYTESIZE);
    m_dcb.fParity = STRTOINT(m_PARITY);
    m_dcb.StopBits = STRTOINT(m_STOPBITS);
    if( !SetCommState( m_ComportHandle, &m_dcb ))
    {
    DWORD errcode = GetLastError();
    CloseHandle(m_ComportHandle);
    throw CComException(errcode, GetLastErrorDesc(errcode), __FILE__, __LINE__);
    }
    读数据: if (!ReadFile(m_ComportHandle, (void*)buf, m_ComBuffer, &readed, NULL))
    {
                ....
             }
      

  2.   

    那你要判断一下CreateFile是否成功了,不成功的话,读肯定是不行的
      

  3.   

    http://www.gznet.com/gzcity/2005/2005-2-2/505937.html
      

  4.   

    USB转串口?有可能是驱动还在加载过程中。
    试试两个串口直接通信呢?如果还有问题,说明是你代码的问题。
    试试Overlap I/O.
      

  5.   

    >>串口参数没有初始化那要如何正确初始化? 各位看我的代码,每个函数都判断了是否成功,不成功就THROW 一个异常的. 但是所有的都返回了成功啊.
      

  6.   

    USB 轉串口, 似乎有點不平常, 你可以掉轉測試的兩個串口試下
      

  7.   

    usb转串口有的时候就是不正常
      

  8.   

    但是如果是系统刚启动完,第一次读串口时,怎么也读不到数据,就是ReadFile根本不返回。如果这时候我用WINDOWS带的超级终端来发送,接受一次数据后,程序就一切正常,可读数据了。
    不明白,难道WINDOWS带的超级终端 有信号补偿功能?
    估计,是你程序的问题.可能再你用串口之前 还需要一个步骤...而这个步骤  WINDOWS带的超级终端替你实现了以后 你的程序才能正常工作..
    这个 我没试过..机器太老.:____(  没   USB 55555555555555
      

  9.   

    可能缺少这几句
    ...
    if(!SetupComm(CommHandle, 4096, 4096))
     {
     ...
     }
    ...
    if(!SetCommTimeouts( CommHandle, &commtimeouts )) 
     {
     ...
     }
    PurgeComm(CommHandle, PURGE_TXABORT | PURGE_RXABORT |PURGE_TXCLEAR | PURGE_RXCLEAR) ;
      

  10.   

    GetCommState( m_ComportHandle, &m_dcb );
    m_dcb.BaudRate = STRTOINT(m_BAUDRATE);
    m_dcb.ByteSize = STRTOINT(m_BYTESIZE);
    m_dcb.fParity = STRTOINT(m_PARITY);
    m_dcb.StopBits = STRTOINT(m_STOPBITS);
    --------------------------------------------------------------------
    这里,对dcb的每个成员附值,肯定是有部分没有初始化,所以你在GetCommState时,其中的一些成员没有初始化,或者初始化的内容和你的不一样,但你却只对其中的4个成员初始化了
      

  11.   

    http://www.blindpoint.net/bbs/ShowForum.asp?forumid=7
      

  12.   

    绝对是没有设置超时结构:
    COMMTIMEOUTS commTimeouts; // 串口超时 memset( &commTimeouts, 0, sizeof(COMMTIMEOUTS) );
    commTimeouts.ReadIntervalTimeout = MAXDWORD; // 读立即返回
    ::SetCommTimeouts( m_hComm, &commTimeouts );
      

  13.   

    我的一段成功代码供参考BOOL CComiotestDlg::OpenConnect()
    {
    m_hTermWnd=GetSafeHwnd();
    if(m_bConnect)
    return FALSE;
    hCom=CreateFile("COM1",//文件名
    GENERIC_READ|GENERIC_WRITE, // 允许读和写 
    0, // 独占方式
    NULL, 
    OPEN_EXISTING, //打开而不是创建
    FILE_ATTRIBUTE_NORMAL|FILE_FLAG_OVERLAPPED, // 重叠方式
    NULL
    );
    if(hCom == INVALID_HANDLE_VALUE)
    {
    dwError=GetLastError( );
    return FALSE;
     // 处理错误
    }
    SetupComm(hCom,1024,1024 ); //缓冲区的大小为1024
    //清除缓冲区
    PurgeComm(hCom,PURGE_TXABORT|PURGE_RXABORT|PURGE_TXCLEAR|PURGE_RXCLEAR);
    //超时的建立
    TimeOuts. ReadIntervalTimeout=1000; 
    TimeOuts.ReadTotalTimeoutMultiplier=500; 
    TimeOuts.ReadTotalTimeoutConstant=5000; 
    TimeOuts.WriteTotalTimeoutMultiplier=500; 
    TimeOuts.WriteTotalTimeoutConstant=5000;
    SetCommTimeouts(hCom, &TimeOuts); // 设置超时
    //设置事件触发方式
    SetCommMask(hCom,EV_RXCHAR);
    if(ConfigConnect())
    {
    m_pThread=AfxBeginThread(CommProc, this, THREAD_PRIORITY_NORMAL, 
    0, CREATE_SUSPENDED, NULL); // 创建并挂起线程
    if(m_pThread==NULL)
    {
    CloseHandle(hCom);
    return FALSE;
    }
    else
    {
    m_bConnect=TRUE;
    m_pThread->ResumeThread(); // 恢复线程运行
    }
    }
    else
    {
    CloseHandle(hCom);
    return FALSE;
    }
    }BOOL CComiotestDlg::ConfigConnect()
    {

    DCB m_dcb;
    if(!GetCommState(hCom, &m_dcb))
    return FALSE;
    m_dcb.fBinary=TRUE;
    m_dcb.BaudRate=m_nBaud; // 波特率
    m_dcb.ByteSize=m_nDataBits; // 每字节位数
    m_dcb.fParity=TRUE;
    switch(m_nParity) // 校验设置
    {
    case 0: 
    m_dcb.Parity=NOPARITY;
    break;
    case 1: 
    m_dcb.Parity=EVENPARITY;
    break;
    case 2: 
    m_dcb.Parity=ODDPARITY;
    break;
    default:;
    }
    switch(m_nStopBit) // 停止位
    {
    case 0: 
    m_dcb.StopBits=ONESTOPBIT;
    break;
    case 1: 
    m_dcb.StopBits=ONE5STOPBITS;
    break;
    case 2: 
    m_dcb.StopBits=TWOSTOPBITS;
    break;
    default:;
    }
    // 硬件流控制设置
    //m_dcb.fOutxCtsFlow=m_nFlowCtrl==1;
    //m_dcb.fRtsControl=m_nFlowCtrl==1?
    //RTS_CONTROL_HANDSHAKE:RTS_CONTROL_ENABLE;
    // XON/XOFF流控制设置
    //m_dcb.fInX=dcb.fOutX=m_nFlowCtrl==2;
    //m_dcb.XonChar=XON;
    //m_dcb.XoffChar=XOFF;
    //m_dcb.XonLim=50;
    //m_dcb.XoffLim=50;
    m_dcb.fBinary=TRUE;
    return SetCommState(hCom, &m_dcb);
    }
      

  14.   

    连接串口2,3针脚试试先,看看是不是由于USB引起