当前位置: 首页>>代码示例>>C++>>正文


C++ Ardb::GetConfig方法代码示例

本文整理汇总了C++中Ardb::GetConfig方法的典型用法代码示例。如果您正苦于以下问题:C++ Ardb::GetConfig方法的具体用法?C++ Ardb::GetConfig怎么用?C++ Ardb::GetConfig使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Ardb的用法示例。


在下文中一共展示了Ardb::GetConfig方法的11个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: test_lists_push

void test_lists_push(Context& ctx, Ardb& db)
{
    db.GetConfig().list_max_ziplist_entries = 16;
    RedisCommandFrame del;
    del.SetFullCommand("del mylist");
    db.Call(ctx, del, 0);
    //ziplist push
    for (int i = 0; i < 10; i++)
    {
        RedisCommandFrame lpush;
        lpush.SetFullCommand("lpush mylist value%d", i);
        db.Call(ctx, lpush, 0);
        CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "lpush mylist failed");
        CHECK_FATAL(ctx.reply.integer != i + 1, "lpush mylist failed");
    }
    RedisCommandFrame mlpush;
    mlpush.SetFullCommand("lpush mylist value10 value11 value12");
    db.Call(ctx, mlpush, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "lpush mylist failed");
    CHECK_FATAL(ctx.reply.integer != 13, "lpush mylist failed");

    //non ziplist lpush
    for (int i = 13; i < db.GetConfig().list_max_ziplist_entries + 100; i++)
    {
        RedisCommandFrame lpush;
        lpush.SetFullCommand("lpush mylist value%d", i);
        db.Call(ctx, lpush, 0);
        CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "lpush mylist failed");
        CHECK_FATAL(ctx.reply.integer != i + 1, "lpush mylist failed");
    }

    db.Call(ctx, del, 0);
    //ziplist push
    for (int i = 0; i < 10; i++)
    {
        RedisCommandFrame rpush;
        rpush.SetFullCommand("rpush mylist value%d", i);
        db.Call(ctx, rpush, 0);
        CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "rpush mylist failed");
        CHECK_FATAL(ctx.reply.integer != i + 1, "rpush mylist failed");
    }
    RedisCommandFrame mrpush;
    mrpush.SetFullCommand("rpush mylist value10 value11 value12");
    db.Call(ctx, mrpush, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "rpush mylist failed");
    CHECK_FATAL(ctx.reply.integer != 13, "rpush mylist failed");

    //non ziplist lpush
    for (int i = 13; i < db.GetConfig().list_max_ziplist_entries + 100; i++)
    {
        RedisCommandFrame rpush;
        rpush.SetFullCommand("rpush mylist value%d", i);
        db.Call(ctx, rpush, 0);
        CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "rpush mylist failed");
        CHECK_FATAL(ctx.reply.integer != i + 1, "rpush mylist failed");
    }
}
开发者ID:cvan,项目名称:ardb,代码行数:57,代码来源:list_test.cpp

示例2: test_lists_pushx

void test_lists_pushx(Context& ctx, Ardb& db)
{
    db.GetConfig().list_max_ziplist_entries = 10;
    RedisCommandFrame del;
    del.SetFullCommand("del mylist");
    db.Call(ctx, del, 0);
    RedisCommandFrame lpushx;
    lpushx.SetFullCommand("lpushx mylist value");
    db.Call(ctx, lpushx, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "lpushx mylist failed");
    CHECK_FATAL(ctx.reply.integer != 0, "lpushx mylist failed");
    RedisCommandFrame rpushx;
    rpushx.SetFullCommand("rpushx mylist value");
    db.Call(ctx, rpushx, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "rpushx mylist failed");
    CHECK_FATAL(ctx.reply.integer != 0, "rpushx mylist failed");

    RedisCommandFrame mlpush;
    mlpush.SetFullCommand(
            "lpush mylist value10 value11 value12 value13 value10 value10 value10 value10 value10 value10");
    db.Call(ctx, mlpush, 0);
    db.Call(ctx, lpushx, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "lpushx mylist failed");
    CHECK_FATAL(ctx.reply.integer != 11, "lpushx mylist failed");
    db.Call(ctx, rpushx, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "rpushx mylist failed");
    CHECK_FATAL(ctx.reply.integer != 12, "rpushx mylist failed");
}
开发者ID:cvan,项目名称:ardb,代码行数:28,代码来源:list_test.cpp

示例3: test_lists_rpoplpush

void test_lists_rpoplpush(Context& ctx, Ardb& db)
{
    db.GetConfig().list_max_ziplist_entries = 16;
    RedisCommandFrame del, del1;
    del.SetFullCommand("del mylist");
    del1.SetFullCommand("del mylist1");
    db.Call(ctx, del, 0);
    db.Call(ctx, del1, 0);
    //ziplist push
    for (int i = 0; i < 10; i++)
    {
        RedisCommandFrame lpush;
        lpush.SetFullCommand("lpush mylist value%d", i);
        db.Call(ctx, lpush, 0);
    }
    RedisCommandFrame rpoplpush;
    rpoplpush.SetFullCommand("rpoplpush mylist mylist1");
    db.Call(ctx, rpoplpush, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_STRING, "rpoplpush mylist failed");
    CHECK_FATAL(ctx.reply.str != "value0", "rpoplpush mylist failed");

    //non ziplist lpush
    for (int i = 0; i < 20; i++)
    {
        RedisCommandFrame lpush;
        lpush.SetFullCommand("lpush mylist xvalue%d", i);
        db.Call(ctx, lpush, 0);
    }
    db.Call(ctx, rpoplpush, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_STRING, "rpoplpush mylist failed");
    CHECK_FATAL(ctx.reply.str != "value1", "rpoplpush mylist failed");
}
开发者ID:cvan,项目名称:ardb,代码行数:32,代码来源:list_test.cpp

示例4: test_lists_llen

void test_lists_llen(Context& ctx, Ardb& db)
{
    db.GetConfig().list_max_ziplist_entries = 16;
    RedisCommandFrame del;
    del.SetFullCommand("del mylist");
    db.Call(ctx, del, 0);
    //ziplist push
    for (int i = 0; i < 10; i++)
    {
        RedisCommandFrame lpush;
        lpush.SetFullCommand("lpush mylist value%d", i);
        db.Call(ctx, lpush, 0);
    }
    RedisCommandFrame llen;
    llen.SetFullCommand("llen mylist");
    db.Call(ctx, llen, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "llen mylist failed");
    CHECK_FATAL(ctx.reply.integer != 10, "llen mylist failed");

    //non ziplist lpush
    for (int i = 0; i < 10; i++)
    {
        RedisCommandFrame lpush;
        lpush.SetFullCommand("lpush mylist xvalue%d", i);
        db.Call(ctx, lpush, 0);
    }
    db.Call(ctx, llen, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "llen mylist failed");
    CHECK_FATAL(ctx.reply.integer != 20, "llen mylist failed");
}
开发者ID:cvan,项目名称:ardb,代码行数:30,代码来源:list_test.cpp

示例5: test_lists_lrem

void test_lists_lrem(Context& ctx, Ardb& db)
{
    db.GetConfig().list_max_ziplist_entries = 16;
    RedisCommandFrame del;
    del.SetFullCommand("del mylist");
    db.Call(ctx, del, 0);
    //ziplist push
    for (int i = 0; i < 10; i++)
    {
        RedisCommandFrame lpush;
        lpush.SetFullCommand("lpush mylist valuexx");
        db.Call(ctx, lpush, 0);
    }
    RedisCommandFrame lrem;
    lrem.SetFullCommand("lrem mylist 2 valueyy");
    db.Call(ctx, lrem, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "lrem mylist failed");
    CHECK_FATAL(ctx.reply.integer != 0, "lrem mylist failed");
    lrem.SetFullCommand("lrem mylist -2 valuexx");
    db.Call(ctx, lrem, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "lrem mylist failed");
    CHECK_FATAL(ctx.reply.integer != 2, "lrem mylist failed");
    lrem.SetFullCommand("lrem mylist 0 valuexx");
    db.Call(ctx, lrem, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "lrem mylist failed");
    CHECK_FATAL(ctx.reply.integer != 8, "lrem mylist failed");

    //non ziplist lpush
    for (int i = 0; i < 20; i++)
    {
        RedisCommandFrame lpush;
        lpush.SetFullCommand("lpush mylist valuexx");
        db.Call(ctx, lpush, 0);
    }
    lrem.SetFullCommand("lrem mylist -2 valueyy");
    db.Call(ctx, lrem, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "lrem mylist failed");
    CHECK_FATAL(ctx.reply.integer != 0, "lrem mylist failed");
    lrem.SetFullCommand("lrem mylist -2 valuexx");
    db.Call(ctx, lrem, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "lrem mylist failed");
    CHECK_FATAL(ctx.reply.integer != 2, "lrem mylist failed");
    lrem.SetFullCommand("lrem mylist 0 valuexx");
    db.Call(ctx, lrem, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "lrem mylist failed");
    CHECK_FATAL(ctx.reply.integer != 18, "lrem mylist failed");
}
开发者ID:cvan,项目名称:ardb,代码行数:47,代码来源:list_test.cpp

示例6: test_geo_common

void test_geo_common(Context& ctx, Ardb& db)
{
    db.GetConfig().zset_max_ziplist_entries = 16;
    RedisCommandFrame del;
    del.SetFullCommand("del mygeo");
    db.Call(ctx, del, 0);
    double x = 300.3;
    double y = 300.3;

    double p_x = 1000.0;
    double p_y = 1000.0;
    uint32 raius = 1000;
    uint32 total = 100000;
    GeoPointArray cmp;
    for (uint32 i = 0; i < total; i++)
    {
        char name[100];
        sprintf(name, "p%u", i);
        /*
         * min accuracy is 0.2meters
         */
        double xx = x + i * 0.3;
        double yy = y + i * 0.3;
        if (((xx - p_x) * (xx - p_x) + (yy - p_y) * (yy - p_y)) <= raius * raius)
        {
            GeoPoint p;
            p.x = xx;
            p.y = yy;
            cmp.push_back(p);
        }
        RedisCommandFrame geoadd;
        geoadd.SetFullCommand("geoadd mygeo MERCATOR %.2f %.2f %s", xx, yy, name);
        db.Call(ctx, geoadd, 0);
    }

    RedisCommandFrame zcard;
    zcard.SetFullCommand("zcard mygeo");
    db.Call(ctx, zcard, 0);
    CHECK_FATAL(ctx.reply.integer != total, "geoadd failed");
    RedisCommandFrame geosearch;
    geosearch.SetFullCommand("geosearch mygeo MERCATOR %.2f %.2f radius %d ASC WITHCOORDINATES WITHDISTANCES", p_x, p_y,
            raius);
    db.Call(ctx, geosearch, 0);
    CHECK_FATAL(ctx.reply.MemberSize() != cmp.size() * 4, "geosearch failed");
}
开发者ID:Abioy,项目名称:ardb,代码行数:45,代码来源:geo_test.cpp

示例7: test_lists_insert

void test_lists_insert(Context& ctx, Ardb& db)
{
    db.GetConfig().list_max_ziplist_entries = 16;
    RedisCommandFrame del;
    del.SetFullCommand("del mylist");
    db.Call(ctx, del, 0);
    for (int i = 0; i < 10; i++)
    {
        RedisCommandFrame rpush;
        rpush.SetFullCommand("rpush mylist value%d", i);
        db.Call(ctx, rpush, 0);
    }
    RedisCommandFrame insert;
    insert.SetFullCommand("linsert mylist before value3 valuexx");
    db.Call(ctx, insert, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "linsert mylist failed");
    CHECK_FATAL(ctx.reply.integer != 11, "linsert mylist failed");

    RedisCommandFrame index;
    index.SetFullCommand("lindex mylist 3");
    db.Call(ctx, index, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_STRING, "lindex mylist failed");
    CHECK_FATAL(ctx.reply.str != "valuexx", "lindex mylist failed");

    //now list is not ziplist
    for (int i = 0; i < 10; i++)
    {
        RedisCommandFrame rpush;
        rpush.SetFullCommand("rpush mylist xvalue%d", i);
        db.Call(ctx, rpush, 0);
    }
    insert.SetFullCommand("linsert mylist after xvalue3 valueyy");
    db.Call(ctx, insert, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_INTEGER, "linsert mylist failed");
    CHECK_FATAL(ctx.reply.integer != 22, "linsert mylist failed");
    index.SetFullCommand("lindex mylist 14");
    db.Call(ctx, index, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_STRING, "lindex mylist failed");
    CHECK_FATAL(ctx.reply.str != "valueyy", "lindex mylist failed");
}
开发者ID:cvan,项目名称:ardb,代码行数:40,代码来源:list_test.cpp

示例8: test_sequential_list

void test_sequential_list(Context& ctx, Ardb& db)
{
    db.GetConfig().list_max_ziplist_entries = 16;
    RedisCommandFrame del;
    del.SetFullCommand("del mylist");
    db.Call(ctx, del, 0);

    for (int i = 0; i < 10000; i++)
    {
        RedisCommandFrame lpush;
        lpush.SetFullCommand("lpush mylist xvalue%d", i);
        db.Call(ctx, lpush, 0);
    }
    for (int i = 0; i < 10000; i++)
    {
        RedisCommandFrame rpush;
        rpush.SetFullCommand("rpush mylist yvalue%d", i);
        db.Call(ctx, rpush, 0);
    }
    RedisCommandFrame index;
    index.SetFullCommand("lindex mylist 10001");
    uint64 start = get_current_epoch_millis();
    db.Call(ctx, index, 0);
    uint64 end = get_current_epoch_millis();
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_STRING, "lindex mylist failed");
    CHECK_FATAL(ctx.reply.str != "yvalue1", "lindex mylist failed");
    CHECK_FATAL((end - start) > 100, "lindex too slow for sequential list");

    RedisCommandFrame lrange;
    lrange.SetFullCommand("lrange mylist 10000 10005");
    start = get_current_epoch_millis();
    db.Call(ctx, lrange, 0);
    end = get_current_epoch_millis();
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_ARRAY, "lrange mylist failed");
    CHECK_FATAL(ctx.reply.MemberSize() != 6, "lrange mylist failed");
    CHECK_FATAL(ctx.reply.MemberAt(5).str != "yvalue5", "lrange mylist failed");
    CHECK_FATAL((end - start) > 100, "lrange too slow for sequential list");

}
开发者ID:Abioy,项目名称:ardb,代码行数:39,代码来源:list_test.cpp

示例9: test_lists_lset

void test_lists_lset(Context& ctx, Ardb& db)
{
    db.GetConfig().list_max_ziplist_entries = 16;
    RedisCommandFrame del;
    del.SetFullCommand("del mylist");
    db.Call(ctx, del, 0);
    //ziplist push
    for (int i = 0; i < 10; i++)
    {
        RedisCommandFrame lpush;
        lpush.SetFullCommand("lpush mylist value%d", i);
        db.Call(ctx, lpush, 0);
    }
    RedisCommandFrame lset;
    lset.SetFullCommand("lset mylist 4 abcd");
    db.Call(ctx, lset, 0);
    RedisCommandFrame index;
    index.SetFullCommand("lindex mylist 4");
    db.Call(ctx, index, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_STRING, "lindex mylist failed");
    CHECK_FATAL(ctx.reply.str != "abcd", "lindex mylist failed");

    //non ziplist lpush
    for (int i = 0; i < 10; i++)
    {
        RedisCommandFrame lpush;
        lpush.SetFullCommand("lpush mylist xvalue%d", i);
        db.Call(ctx, lpush, 0);
    }
    lset.SetFullCommand("lset mylist -5 xxyy");
    db.Call(ctx, lset, 0);
    index.SetFullCommand("lindex mylist -5");
    db.Call(ctx, index, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_STRING, "lindex mylist failed");
    CHECK_FATAL(ctx.reply.str != "xxyy", "lindex mylist failed");

}
开发者ID:cvan,项目名称:ardb,代码行数:37,代码来源:list_test.cpp

示例10: test_lists_index

void test_lists_index(Context& ctx, Ardb& db)
{
    db.GetConfig().list_max_ziplist_entries = 16;
    RedisCommandFrame del;
    del.SetFullCommand("del mylist");
    db.Call(ctx, del, 0);
    for (int i = 0; i < 10; i++)
    {
        RedisCommandFrame lpush;
        lpush.SetFullCommand("lpush mylist value%d", i);
        db.Call(ctx, lpush, 0);
    }
    RedisCommandFrame index;
    index.SetFullCommand("lindex mylist 5");
    db.Call(ctx, index, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_STRING, "lindex mylist failed");
    CHECK_FATAL(ctx.reply.str != "value4", "lindex mylist failed");
    index.SetFullCommand("lindex mylist 50");
    db.Call(ctx, index, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_NIL, "lindex mylist failed");

    //now list is not ziplist
    for (int i = 0; i < 10; i++)
    {
        RedisCommandFrame lpush;
        lpush.SetFullCommand("lpush mylist value%d", i);
        db.Call(ctx, lpush, 0);
    }
    index.SetFullCommand("lindex mylist 15");
    db.Call(ctx, index, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_STRING, "lindex mylist failed");
    CHECK_FATAL(ctx.reply.str != "value4", "lindex mylist failed");
    index.SetFullCommand("lindex mylist 50");
    db.Call(ctx, index, 0);
    CHECK_FATAL(ctx.reply.type != REDIS_REPLY_NIL, "lindex mylist failed");
}
开发者ID:cvan,项目名称:ardb,代码行数:36,代码来源:list_test.cpp

示例11: test_lists_lrange

void test_lists_lrange(Context& ctx, Ardb& db)
{
    db.GetConfig().list_max_ziplist_entries = 16;
    RedisCommandFrame del;
    del.SetFullCommand("del mylist");
    db.Call(ctx, del, 0);
    for (int i = 0; i < 10; i++)
    {
        RedisCommandFrame rpush;
        rpush.SetFullCommand("rpush mylist value%d", i);
        db.Call(ctx, rpush, 0);
    }
    RedisCommandFrame lrange;
    lrange.SetFullCommand("lrange mylist 0 -1");
    db.Call(ctx, lrange, 0);
    CHECK_FATAL(ctx.reply.MemberSize() != 10, "lrange mylist failed");
    CHECK_FATAL(ctx.reply.MemberAt(4).str != "value4", "lrange mylist failed");

    //now list is not ziplist
    for (int i = 0; i < 10; i++)
    {
        RedisCommandFrame rpush;
        rpush.SetFullCommand("rpush mylist xvalue%d", i);
        db.Call(ctx, rpush, 0);
    }
    lrange.SetFullCommand("lrange mylist 0 -1");
    db.Call(ctx, lrange, 0);
    CHECK_FATAL(ctx.reply.MemberSize() != 20, "lrange mylist failed");

    lrange.SetFullCommand("lrange mylist 10 12");
    db.Call(ctx, lrange, 0);
    CHECK_FATAL(ctx.reply.MemberSize() != 3, "lrange mylist failed");
    CHECK_FATAL(ctx.reply.MemberAt(0).str != "xvalue0", "lrange mylist failed");
    CHECK_FATAL(ctx.reply.MemberAt(1).str != "xvalue1", "lrange mylist failed");
    CHECK_FATAL(ctx.reply.MemberAt(2).str != "xvalue2", "lrange mylist failed");
}
开发者ID:cvan,项目名称:ardb,代码行数:36,代码来源:list_test.cpp


注:本文中的Ardb::GetConfig方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。