linux C之getchar()非阻塞方式

参考链接: http://blog.csdn.net/zydlyq/article/details/50963360

#include "../include/CommUart.h"
#include "ComCommon.h"
#include <stdio.h>
#include <unistd.h>
#include <iostream>
#include <stdlib.h>

#include <string.h>
#include <sys/time.h>
#include <sys/types.h>
#include <termios.h>

using namespace std;

#define USR_DEBUG

static struct termios ori_attr, cur_attr;

static __inline  int tty_reset(void)
{
   if (tcsetattr(STDIN_FILENO, TCSANOW, &ori_attr) != 0)
      return -1;

   return 0;
}

static __inline  int tty_set(void)
{

   if ( tcgetattr(STDIN_FILENO, &ori_attr) )
      return -1;

   memcpy(&cur_attr, &ori_attr, sizeof(cur_attr) );
   cur_attr.c_lflag &= ~ICANON;
//        cur_attr.c_lflag |= ECHO;
   cur_attr.c_lflag &= ~ECHO;
   cur_attr.c_cc[VMIN] = 1;
   cur_attr.c_cc[VTIME] = 0;

   if (tcsetattr(STDIN_FILENO, TCSANOW, &cur_attr) != 0)
      return -1;

   return 0;
}

static __inline  int kbhit(void)
{

   fd_set rfds;
   struct timeval tv;
   int retval;

   /* Watch stdin (fd 0) to see when it has input. */
   FD_ZERO(&rfds);
   FD_SET(0, &rfds);
   /* Wait up to five seconds. */
   tv.tv_sec  = 0;
   tv.tv_usec = 0;

   retval = select(1, &rfds, NULL, NULL, &tv);
   /* Don‘t rely on the value of tv now! */

   if (retval == -1) {
      perror("select()");
      return 0;
   } else if (retval)
      return 1;
   /* FD_ISSET(0, &rfds) will be true. */
   else
      return 0;
   return 0;
}

int main(int argc, char*argv[]) {

//非阻塞getChar初始化
   int tty_set_flag;
   tty_set_flag = tty_set();

   char com_num[3] = {0};
   if (argc < 2) {
      printf("please enter com num:\n");
      scanf("%c", &com_num);
   } else {
      // com_num = *argv[1];
      strcpy(com_num, argv[1]);
   }

#ifdef USR_DEBUG
   printf("main entry\n");
#endif // USR_DEBUG
   CComCommon *m_pComUart = new CCommUart;
#ifdef USR_DEBUG
   printf("create CCommUart\n");
#endif // USR_DEBUG

   char sendStr[256] = {0};
   strcpy(sendStr, "/dev/ttyS100");
   strcat(sendStr, com_num);
   strcat(sendStr, ",115200,8,1,n");
   // m_pComUart->InitComComm("/dev/ttyS1001,115200,8,1,n");
   m_pComUart->InitComComm(sendStr);

   // strcat(sendStr,"kkkkkkkkkkkkkkkkkk");

//  写入文件

   FILE * pFile;
   char fileName[124] = {0};
   sprintf(fileName,"readData_dir/%s.txt",com_num);
   pFile = fopen (fileName, "w");

   char Rbuff[256] = {0};
   int nsize = 0;
   int i = 0;
   int nCnt = 0;
   while (1) {

      /*********************发送测试*******************************/
      // m_pComUart->SendBuff(buff,sizeof(buff));
      // m_pComUart->SendStr("1234567887654321abcdefgh");
      // m_pComUart->SendStr("kkkkkkkkkkkkkkkkkk");

      if (kbhit()) {
         const int key = getchar();
         // printf("%c pressed\n", key);
         if (key == ‘q‘)
            break;
      } /*else {
         fprintf(stderr, "<no key detected>\n");
      }*/

      /*********************接收的测试案例*************************/
      memset(Rbuff, 0, 256);
      nsize = m_pComUart->GetData(Rbuff, 256, 1000);
      if (nsize > 0)
      {
         printf("nsize:%d\n", nsize);

// if(nCnt==10){
         for (i = 0; i < nsize; i++)
         {

            // printf("%02x ", (unsigned char)Rbuff[i]);

            fprintf(pFile, "%02x", (unsigned char)Rbuff[i]);
            if (nCnt == 7) {
               fprintf(pFile, "\n");
               nCnt = 0;
            } else {
               nCnt++;
            }

         }

         // 二进制输入
         // fwrite (Rbuff , sizeof(char), sizeof(Rbuff), pFile);

//    nCnt = 0;
// }else{
//    nCnt++;
// }
         printf("\n");

         // printf("%s\n", Rbuff);

      }

      // printf("rec buff data:%s\n", Rbuff);
      // printf("get char:  %d\n", m_pComUart->GetChar(10));

      // sleep(1);
      // usleep(1000);
   }
   delete m_pComUart;

   fclose (pFile);

// 线程的操作
   if (tty_set_flag == 0)
      tty_reset();

}
时间: 2024-11-05 07:58:46

linux C之getchar()非阻塞方式的相关文章

socket编程 ------ 客户端(非阻塞方式)

connect完成(三次握手)需要花一段时间,从几毫秒的局域网到几百毫秒或几秒的广域网,使用非阻塞connect可以利用这段时间干其他事情 目前connect非阻塞编程的普遍思路是: 在一个TCP套接口设置为非阻塞后,调用connect,connect会在系统提供的errno变量中返回一个EINRPOCESS错误,此时TCP的三路握手继续进行.之后可以用select函数检查这个连接是否建立成功

linux centos 安装Jenkins(非docker方式)

写在前面 我之前写过Asp.net Core 使用Jenkins + Dockor 实现持续集成.自动化部署(一):Jenkins安装这jenkisn的安装过程,但这篇使用的是docker的方式安装的,在实际的使用过程后:我不推荐新手使用docker的方式安装jenkins 新手使用docker的方式安装jenkins使用过程中可能会遇到较多问题,耗费不必要的时间精力: 运行环境 centos:7.2 cpu:1核 2G内存 1M带宽 安装java 因为jenkins是用java开发的,需先安装

Linux设备驱动中的阻塞和非阻塞I/O

[基本概念] 1.阻塞 阻塞操作是指在执行设备操作时,托不能获得资源,则挂起进程直到满足操作所需的条件后再进行操作.被挂起的进程进入休眠状态(不占用cpu资源),从调度器的运行队列转移到等待队列,直到条件满足. 2.非阻塞 非阻塞操作是指在进行设备操作是,若操作条件不满足并不会挂起,而是直接返回或重新查询(一直占用CPU资源)直到操作条件满足为止. 当用户空间的应用程序调用read(),write()等方法时,若设备的资源不能被获取,而用户又希望以阻塞的方式来访问设备,驱动程序应当在设备驱动层的

深入浅出~Linux设备驱动中的阻塞和非阻塞I/O

今天意外收到一个消息,真是惊呆我了,博客轩给我发了信息,说是俺的博客文章有特色可以出本书,,这简直让我受宠若惊,俺只是个大三的技术宅,写的博客也是自己所学的一些见解和在网上看到我一些博文以及帖子里综合起来写的,,总之这又给了额外的动力,让自己继续前进,,希望和大家能够分享一些自己的经验,,在最需要奋斗的年级以及在技术的领域踽踽独行的过程中有共同的伙伴继续前进~ 今天写的是Linux设备驱动中的阻塞和非阻塞I/0,何谓阻塞与非阻塞I/O?简单来说就是对I/O操作的两种不同的方式,驱动程序可以灵活的

(转)同步异步/阻塞非阻塞 和 5种linux网络通信模型

会阻塞的函数:connect, accept,send/recv/sendto/recvfrom等读写函数. 不会阻塞的函数:bind, listen,socket, closesocket. linux网络通信模型有: 阻塞IO模型(同步),非阻塞IO模型(拷贝同步),IO复用模型(多线程同步),信号驱动IO模型((拷贝同步),异步IO模型(异步). node.js对同步/异步,阻塞非阻塞的解释: 线程在执行中如果遇到磁盘读写或网络通信(统称为I/O 操作),通常要耗费较长的时间,这时 操作系

Linux 设备驱动--- 阻塞型字符设备驱动 --- O_NONBLOCK --- 非阻塞标志【转】

转自:http://blog.csdn.net/yikai2009/article/details/8653697 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[-] 阻塞 阻塞操作 非阻塞操作 阻塞方式-read- 实现 阻塞方式-write- 实现 非阻塞方式的读写操作 实例 --- 读阻塞的实现 实例 --- 按键驱动阻塞实现 1在 open 函数 查看看是 阻塞方式 还是 非阻塞方式 2在 read 函数中同样查看 3应用程序中 1以阻塞方式运行 2以非阻塞方式运行

Hasen的linux设备驱动开发学习之旅--阻塞与非阻塞I/O

/** * Author:hasen * 参考 :<linux设备驱动开发详解> * 简介:android小菜鸟的linux * 设备驱动开发学习之旅 * 主题:阻塞与非阻塞I/O * Date:2014-11-05 */ 阻塞操作是指在执行设备操作时,若不能获得资源,则挂起进程直到满足可操作的条件后再进行操作.被 挂起的进程进入休眠状态,被从调度器的运行队列移走,直到等待的条件被满足.而非阻塞操作的进程在不能 进行设备操作时,并不挂起,它或者放弃,或者不停地查询,直到条件满足以进行操作为止.

linux阻塞与非阻塞,同步与异步、I/O模型

1. 概念理解      在进行网络编程时,我们常常见到同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式: 同步: 所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回.也就是必须一件一件事做,等前一件做完了才能做下一件事. 例如普通B/S模式(同步):提交请求->等待服务器处理->处理完毕返回 这个期间客户端浏览器不能干任何事 异步: 异步的概念和同步相对.当一个异步过程调用发出后,调用者不能立刻得到结果.实际处理这个调用的部件

linux下socket connect阻塞方式 阻塞时间控制

同事今天问我,如何在linux下的c代码里面控制connect的阻塞时间.应用的背景是:linux下的c程序有两个目标IP需要connect,如果用阻塞方式,当其中一个IP不能连接的情况下,程序将阻塞在connect函数上.本来以为用setsockopt修改个什么参数就可以搞定,结果baidu了半天也没有结果.倒是在网上搜到很多这样的解决方案:将connect方式设置为非阻塞方式,这样程序一旦执行就会马上返回,但问题是,到底有没有连接上呢,你需要等待一段时间,然后使用函数判断连接是否正常.试了下