首页 > 代码库 > 跨平台的EVENT事件 windows linux
跨平台的EVENT事件 windows linux
#ifndef _HIK_EVENT_H_ #define _HIK_EVENT_H_#ifdef _MSC_VER#include <Windows.h>#define hik_event_handle HANDLE#else#include <pthread.h>typedef struct { bool state; bool manual_reset; pthread_mutex_t mutex; pthread_cond_t cond;}event_t;#define event_handle event_t*#endif//返回值:NULL 出错event_handle event_create(bool manual_reset, bool init_state);//返回值:0 等到事件,-1出错int event_wait(event_handle hevent);//返回值:0 等到事件,1 超时,-1出错int event_timedwait(event_handle hevent, long milliseconds);//返回值:0 成功,-1出错int event_set(event_handle hevent);//返回值:0 成功,-1出错int event_reset(event_handle hevent);//返回值:无void event_destroy(event_handle hevent);#endif////////////<PRE class=cpp name="code">#include "event.h"#ifdef __linux#include <sys/time.h>#include <errno.h>#endif#include <iostream>event_handle event_create(bool manual_reset, bool init_state){ #ifdef _MSC_VER HANDLE hevent = CreateEvent(NULL, manual_reset, init_state, NULL);#else event_handle hevent = new(std::nothrow) event_t; if (hevent == NULL) { return NULL; } hevent->state = init_state; hevent->manual_reset = manual_reset; if (pthread_mutex_init(&hevent->mutex, NULL)) { delete hevent; return NULL; } if (pthread_cond_init(&hevent->cond, NULL)) { pthread_mutex_destroy(&hevent->mutex); delete hevent; return NULL; }#endif return hevent;}int event_wait(event_handle hevent){#ifdef _MSC_VER DWORD ret = WaitForSingleObject(hevent, INFINITE); if (ret == WAIT_OBJECT_0) { return 0; } return -1;#else if (pthread_mutex_lock(&hevent->mutex)) { return -1; } while (!hevent->state) { if (pthread_cond_wait(&hevent->cond, &hevent->mutex)) { pthread_mutex_unlock(&hevent->mutex); return -1; } } if (!hevent->manual_reset) { hevent->state = false; } if (pthread_mutex_unlock(&hevent->mutex)) { return -1; } return 0;#endif}int event_timedwait(event_handle hevent, long milliseconds){#ifdef _MSC_VER DWORD ret = WaitForSingleObject(hevent, milliseconds); if (ret == WAIT_OBJECT_0) { return 0; } if (ret == WAIT_TIMEOUT) { return 1; } return -1;#else int rc = 0; struct timespec abstime; struct timeval tv; gettimeofday(&tv, NULL); abstime.tv_sec = tv.tv_sec + milliseconds / 1000; abstime.tv_nsec = tv.tv_usec*1000 + (milliseconds % 1000)*1000000; if (abstime.tv_nsec >= 1000000000) { abstime.tv_nsec -= 1000000000; abstime.tv_sec++; } if (pthread_mutex_lock(&hevent->mutex) != 0) { return -1; } while (!hevent->state) { if (rc = pthread_cond_timedwait(&hevent->cond, &hevent->mutex, &abstime)) { if (rc == ETIMEDOUT) break; pthread_mutex_unlock(&hevent->mutex); return -1; } } if (rc == 0 && !hevent->manual_reset) { hevent->state = false; } if (pthread_mutex_unlock(&hevent->mutex) != 0) { return -1; } if (rc == ETIMEDOUT) { //timeout return 1 return 1; } //wait event success return 0 return 0;#endif}int event_set(event_handle hevent){#ifdef _MSC_VER return !SetEvent(hevent);#else if (pthread_mutex_lock(&hevent->mutex) != 0) { return -1; } hevent->state = true; if (hevent->manual_reset) { if(pthread_cond_broadcast(&hevent->cond)) { return -1; } } else { if(pthread_cond_signal(&hevent->cond)) { return -1; } } if (pthread_mutex_unlock(&hevent->mutex) != 0) { return -1; } return 0;#endif}int event_reset(event_handle hevent) {#ifdef _MSC_VER //ResetEvent 返回非零表示成功 if (ResetEvent(hevent)) { return 0; } return -1;#else if (pthread_mutex_lock(&hevent->mutex) != 0) { return -1; } hevent->state = false; if (pthread_mutex_unlock(&hevent->mutex) != 0) { return -1; } return 0;#endif}void event_destroy(event_handle hevent){#ifdef _MSC_VER CloseHandle(hevent);#else pthread_cond_destroy(&hevent->cond); pthread_mutex_destroy(&hevent->mutex); delete hevent;#endif}
跨平台的EVENT事件 windows linux
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。