#pragma once #include "acl_cpp/acl_cpp_define.hpp" namespace acl { class redis_client; class redis_result; /** * redis 客户端命令类的纯虚父类 */ class ACL_CPP_API redis_command { public: redis_command(redis_client* conn = NULL); virtual ~redis_command() = 0; /** * 在重复使用一个继承于 redis_command 的子类操作 redis 时,需要在下一次 * 调用前调用本方法以释放上次操作的临时对象 */ void reset(); /** * 在使用连接池方式时,通过本函数将从连接池获得的连接对象(redis_client)与 * redis 客户端命令进行关联 */ void set_client(redis_client* conn); /** * 获得当前 redis 客户端命令的连接对象 * @return {redis_client*} */ redis_client* get_client() const { return conn_; } /** * 判断当前所绑定的 redis 连接流对象(redis_client) 连接是否已经关闭;只有 * 内部的 conn_ 流对象非空时调用此函数才有意义 * @return {bool} */ bool eof() const; /** * 获得本次 redis 操作过程的结果 * @return {redis_result*} */ const redis_result* get_result() const; /** * 当查询结果为数组对象时调用本方法获得查询结果集的个数;该方法可以获得结果为下面 * 两个方法 (get_child/get_value) 所需要的数组元素的个数 * @return {size_t} */ size_t get_size() const; /** * 当查询结果为数组对象时调用本方法获得一个数组元素对象 * @param i {size_t} 数组对象的下标值 * @return {const redis_result*} 当结果非数组对象或结果为空或出错时该方法 * 返回 NULL */ const redis_result* get_child(size_t i) const; /** * 当从 redis-server 获得的数据是一组字符串类型的结果集时,可以调用本函数获得 * 某个指定下标位置的数据 * @param i {size_t} 下标(从 0 开始) * @param len {size_t*} 若该指针非空,则存储所返回结果的长度(仅当该方法 * 返回非空指针时有效) * @return {const char*} 返回对应下标的值,当返回 NULL 时表示该下标没有值, * 为了保证使用上的安全性,返回的数据总能保证最后是以 \0 结尾,在计算数据长度 * 时不包含该结尾符,但为了兼容二进制情形,调用者还是应该通过返回的 len 存放 * 的长度值来获得数据的真实长度 */ const char* get_value(size_t i, size_t* len = NULL) const; protected: redis_client* conn_; const redis_result** scan_keys(const char* cmd, const char* key, int& cursor, size_t& size, const char* pattern, const size_t* count); }; } // namespace acl