Day1 select 实现 timeout

本文介绍如何利用select函数实现文件描述符的超时等待处理。通过示例代码展示了如何在循环中设置和检查超时,以及如何处理超时情况下的数据接收。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include <sys/select.h>  /* According to POSIX .1-2001 */

#include <sys/types.h>

#include <sys/time.h>

#include <unistd.h>  /*According to earlier standards*/

从键盘,socket中读数据时,数据到来时刻是随机的,使用select函数来设置超时响应。

示例:

select 函数会修改fd_set ,timeval的值,所以,每次循环需要重新设置。

#include <stdio.h>
#include <sys/select.h>

#include <string.h>
#include <unistd.h>

int main()
{
    int fd = 0;
    int ret;
    char buf[11];

    fd_set readfds;
    struct timeval timeout;

    while(1)
    {
        FD_ZERO(&readfds);
        FD_SET(fd,&readfds);
        timeout.tv_sec = 10;
        timeout.tv_usec = 0;

        ret = select(8,&readfds,NULL,NULL,&timeout);

        if(ret == 0) {
            printf("No data coming in. Timeout\n"); 
        }
        else {
            memset(buf,0,11);
            if(read(fd,buf,10) != -1) {
                printf("%s",buf);
            }
        }
    }

    return 0;
}

转载于:https://www.cnblogs.com/jfm-cs/p/7919849.html

SELECT T1.CALENDAR_DATE,T1.STAGE_MOVE,T1.DMOVE,T1.NMOVE,L2.EOH,L2.ENG,L2.HOLD_QTY,L2.BANK FROM ((SELECT DM.CALENDAR_DATE FROM RPTDW.DAY_MASTER DM WHERE TRUNC(DM.CALENDAR_DATE,'MM') =TO_DATE('${monthID}'||'-01','YYYY-MM-DD')) T2 LEFT JOIN (SELECT TRUNC (T1.TRACK_OUT_TIME) TIME1, SUM(T1.TRACK_OUT_QTY) STAGE_MOVE, SUM(CASE WHEN T1.SHIFT_NUMBER=1 THEN T1.TRACK_OUT_QTY ELSE 0 END) DMOVE, SUM(CASE WHEN T1.SHIFT_NUMBER=2 THEN T1.TRACK_OUT_QTY ELSE 0 END) NMOVE FROM (SELECT L1.TRACK_OUT_TIME,L1.TRACK_OUT_QTY, CASE WHEN TO_CHAR (L1.TRACK_OUT_TIME,'HH24:MI:SS') >= '07:30:00' AND TO_CHAR (L1.TRACK_OUT_TIME,'HH24:MI:SS') < '19:30:00' THEN '1' ELSE '2' END AS SHIFT_NUMBER FROM (SELECT TRACK_OUT_TIME ,TRACK_OUT_QTY FROM RPTDW.LOT_STAGE_HISTORY) L1)T1 GROUP BY TRUNC(T1.TRACK_OUT_TIME))T1 ON T2.CALENDAR_DATE = T1.TIME1)T1 LEFT JOIN (SELECT TO_DATE (L1.run_time_date,'YYYY-MM-DD') CALENDAR_DATE,SUM (L1.component_qty)EOH, SUM (CASE WHEN L1.LOT_CATEGORY ='ENG' THEN L1.COMPONENT_QTY ELSE 0 END ) ENG, SUM (CASE WHEN L1.LOT_STATE IN ('hold','running hold') THEN L1.COMPONENT_QTY ELSE 0 END ) HOLD_QTY, SUM (CASE WHEN L1.LOT_STATE IN ('bank') THEN L1.COMPONENT_QTY ELSE 0 END ) BANK FROM (SELECT DISTINCT run_time_date,run_time_hour,RUN_TIMESTAMP,LOT_NAME,PRIORITY,INTERNAL_PRIORITY ,product_name,LOT_STATE,lot_type,lot_category,component_qty FROM RPTDW.LOT_MASTER_SNAPSHOT_HOUR) L1 WHERE L1.RUN_TIME_DATE <= TO_CHAR(TRUNC(SYSDATE),'YYYY-MM-DD') AND L1.run_time_hour = '07:30' GROUP BY TO_DATE (L1.RUN_TIME_DATE,'YYYY-MM-DD'))L2 ON T1.CALENDAR_DATE = L2.CALENDAR_DATE 代码报错:errMsg=Sql syntax error: invalid table alias,修改sql代码
06-10
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值