此文编写的时候,使用到的 Libevent 为 2.0.21
常用基本数据类型
- evutil_socket_t 用于保存 socket
- ev_uint64_t 取值范围 [0, EV_UINT64_MAX]
- ev_int64_t 取值范围 [EV_INT64_MIN, EV_INT64_MAX]
- ev_uint32_t 取值范围 [0, EV_UINT32_MAX]
- ev_int32_t 取值范围 [EV_INT32_MIN, EV_INT32_MAX]
- ev_uint16_t 取值范围 [0, EV_UINT16_MAX]
- ev_int16_t 取值范围 [EV_INT16_MIN, EV_INT16_MAX]
- ev_uint8_t 取值范围 [0, EV_UINT8_MAX]
- ev_int8_t 取值范围 [EV_INT8_MIN, EV_INT8_MAX]
- ev_ssize_type(signed size_t)取值范围 [EV_SSIZE_MIN, EV_SSIZE_MAX]
时间相关
- // 用于加或者减前两个参数,结果被保存在第三个参数中
- #define evutil_timeradd(tvp, uvp, vvp) /* ... */
- #define evutil_timersub(tvp, uvp, vvp) /* ... */
- // 清除 timeval 将其值设置为 0
- #define evutil_timerclear(tvp) /* ... */
- // 判断 timeval 是否为 0,如果是 0 返回 false,否则返回 true
- #define evutil_timerisset(tvp) /* ... */
- // 比较两个 timeval
- // 使用的时候这样用:
- // evutil_timercmp(t1, t2, <=) 含义为判断 t1 <= t2 是否成立
- // cmp 为所有的 C 关系操作符
- #define evutil_timercmp(tvp, uvp, cmp)
- // 获取当前时间并保存到 tv
- // tz 目前无用
- int evutil_gettimeofday(struct timeval *tv, struct timezone *tz);
Socket API
- // 用于关闭一个 socket
- int evutil_closesocket(evutil_socket_t s);
- #define EVUTIL_CLOSESOCKET(s) evutil_closesocket(s)
- // 返回当前线程的最后一次 socket 操作的错误码
- #define EVUTIL_SOCKET_ERROR()
- // 改变当前 socket 的错误码
- #define EVUTIL_SET_SOCKET_ERROR(errcode)
- // 返回特定的 sock 的错误码
- #define evutil_socket_geterror(sock)
- // 通过 socket 错误码获取到一个字符串描述
- #define evutil_socket_error_to_string(errcode)
- // 设置 sock 为非阻塞的 socket
- int evutil_make_socket_nonblocking(evutil_socket_t sock);
- // 设置 sock 的地址可重用
- int evutil_make_listen_socket_reuseable(evutil_socket_t sock);
字符串相关
- // 它们对应于标准的 snprintf 和 vsnprintf
- int evutil_snprintf(char *buf, size_t buflen, const char *format, ...);
- int evutil_vsnprintf(char *buf, size_t buflen, const char *format, va_list ap);
安全的随机数生成
- // 此函数将使用随机的数据填充 n 个字节的 buf
- void evutil_secure_rng_get_bytes(void *buf, size_t n);