zoukankan      html  css  js  c++  java
  • spring data redis 遇到的“坑”——set集合的 Srandmember

    sRandMember 命令是用于方法 set 集合中的“随机”元素
    1
    命令格式为

    sRandMember key [count]
    1
    以下内容来自 http://www.redis.net.cn/order/3604.html

    1.如果 count 为正数,且小于集合基数,那么命令返回一个包含 count 个元素的数组,数组中的元素各不相同。

    2.如果 count 大于等于集合基数,那么返回整个集合。

    3.如果 count 为负数,那么命令返回一个数组,数组中的元素可能会重复出现多次,而数组的长度为 count 的绝对值。
    1
    2
    3
    4
    5
    而 spring 封装的 redis 是每次使用的指令如下,即每次都是上述的第三种情况

    sRandMember key [-count]
    1
    spring 的默认是允许重复元素的,源码如下:

    List<V> org.springframework.data.redis.core.DefaultSetOperations.randomMembers(K key, long count)

    public List<V> randomMembers(K key, final long count) {
        if (count < 0) {
            throw new IllegalArgumentException("Use a positive number for count. "
                    + "This method is already allowing duplicate elements.");
        }
        final byte[] rawKey = rawKey(key);
        List<byte[]> rawValues = execute(new RedisCallback<List<byte[]>>() {
            public List<byte[]> doInRedis(RedisConnection connection) {
                return connection.sRandMember(rawKey, -count);
            }
        }, true);

        return deserializeValues(rawValues);
    }

  • 相关阅读:
    阻塞IO与非阻塞IO
    Java 中 IO 流分为几种?BIO,NIO,AIO 有什么区别?
    linux7启动时自动启动zookeeper和Tomcat
    linux7下配置Tomcat
    背景图片变色,或者背景渐变
    Linux7版本网络配置
    linux7中jdk安装
    linux7中zookeeper的安装-依赖于jdk
    Avoided redundant navigation to current location
    Auto Fix is enabled by default. Use the single string form
  • 原文地址:https://www.cnblogs.com/zhuyeshen/p/12147937.html
Copyright © 2011-2022 走看看