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


C++ value::size方法代码示例

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


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

示例1: traverse

void traverse(const value&                                           tree,
              const std::function<void (const path&, const value&)>& func,
              const path&                                            base_path,
              bool                                                   leafs_only
             )
{
    if (!leafs_only || tree.empty() || (tree.kind() != kind::array && tree.kind() != kind::object))
        func(base_path, tree);
    
    if (tree.kind() == kind::object)
    {
        for (const auto& field : tree.as_object())
        {
            traverse(field.second,
                     func,
                     base_path + field.first,
                     leafs_only
                    );
        }
    }
    else if (tree.kind() == kind::array)
    {
        for (value::size_type idx = 0; idx < tree.size(); ++idx)
            traverse(tree[idx],
                     func,
                     base_path + idx,
                     leafs_only
                    );
    }
}
开发者ID:poseidon1214,项目名称:vanilla-rtb,代码行数:30,代码来源:algorithm_traverse.cpp

示例2: GenStat

static void GenStat(Stat& stat, const value& v) {
    switch (v.kind()) {
    case kind::array:
        {
            for (value::const_array_iterator itr = v.begin_array(); itr != v.end_array(); ++itr)
                GenStat(stat, *itr);
            stat.arrayCount++;
            stat.elementCount += v.size();
        }
        break;

    case kind::object:
        {
            for (value::const_object_iterator itr = v.begin_object(); itr != v.end_object(); ++itr) {
                GenStat(stat, itr->second);
                stat.stringLength += itr->first.size();
            }
            stat.objectCount++;
            stat.memberCount += v.size();
            stat.stringCount += v.size();
        }
        break;

    case kind::string: 
        stat.stringCount++;
        stat.stringLength += v.size();
        break;

    case kind::integer:
    case kind::decimal:
        stat.numberCount++;
        break;

    case kind::boolean:
        if (v.as_boolean())
            stat.trueCount++;
        else
            stat.falseCount++;
        break;

    case kind::null:
        stat.nullCount++;
        break;
    }
}
开发者ID:Lyoko-Jeremie,项目名称:nativejson-benchmark,代码行数:45,代码来源:voorheestest.cpp

示例3: if

    std::pair<bool, value> delta( const object& a, const object& b, std::size_t max_size )
    {
        array result;

        const std::vector<string> akeys = a.keys();
        const std::vector<string> bkeys = b.keys();

        std::vector<string>::const_iterator pa = akeys.begin(), pb = bkeys.begin();

        for ( ; (pa != akeys.end() || pb != bkeys.end()) && result.size() < max_size; ) 
        {
            if ( pb == bkeys.end() || pa != akeys.end() && *pa < *pb )
            {
                result.add( delete_at_operation() )
                      .add( *pa );

                ++pa;
            }
            else if ( pa == akeys.end() || pb != bkeys.end() && *pb < *pa )
            {
                result.add( insert_at_operation() )
                      .add( *pb )
                      .add( b.at( *pb ) );

                ++pb;
            }
            else
            {
                assert( *pa == *pb );
                const value b_element = b.at( *pb );

                std::pair<bool, value> edit_op = delta(a.at(*pa), b_element, max_size - result.size());

                // use edit, if possible and shorter
                if ( edit_op.first && edit_op.second.size() < b_element.size() )
                {
                    result.add( edit_at_operation() )
                          .add( *pa )
                          .add( edit_op.second );

                }
                else
                {
                    result.add( update_at_operation() )
                          .add( *pa)
                          .add( b_element );
                }

                ++pa;
                ++pb;
            }
        }

        return result.size() <= max_size
            ? std::make_pair(true, value(result))
            : std::make_pair(false, value(b));
    }
开发者ID:TorstenRobitzki,项目名称:Sioux,代码行数:57,代码来源:object_delta.cpp

示例4: create

 virtual TContainer create(const extraction_context& context, const value& from) const override
 {
     using std::end;
     
     TContainer out;
     from.as_array(); // get nice error if input is not an array
     for (value::size_type idx = 0U; idx < from.size(); ++idx)
         out.insert(end(out), context.extract_sub<element_type>(from, idx));
     return out;
 }
开发者ID:poseidon1214,项目名称:vanilla-rtb,代码行数:10,代码来源:serialization_util.hpp

示例5: diff

diff_result diff(value left, value right)
{
    diff_result result;
    if (left == right)
    {
        result.same = std::move(left);
    }
    else if (left.kind() != right.kind())
    {
        result.left  = std::move(left);
        result.right = std::move(right);
    }
    else switch (left.kind())
    {
    case kind::boolean:
    case kind::decimal:
    case kind::integer:
    case kind::null:
    case kind::string:
        result.left = std::move(left);
        result.right = std::move(right);
        break;
    case kind::array:
        result.same = array();
        result.left = array();
        result.right = array();
        for (value::size_type idx = 0; idx < std::min(left.size(), right.size()); ++idx)
        {
            diff_result subresult = diff(std::move(left.at(idx)), std::move(right.at(idx)));
            result.same.push_back(std::move(subresult.same));
            result.left.push_back(std::move(subresult.left));
            result.right.push_back(std::move(subresult.right));
        }

        if (left.size() > right.size())
            result.left.insert(result.left.end_array(),
                               std::make_move_iterator(left.begin_array() + right.size()),
                               std::make_move_iterator(left.end_array())
                              );
        else if (left.size() < right.size())
            result.right.insert(result.right.end_array(),
                                std::make_move_iterator(right.begin_array() + left.size()),
                                std::make_move_iterator(right.end_array())
                               );
        break;
    case kind::object:
        result.same = object();
        result.left = object();
        result.right = object();
        for (value::object_iterator liter = left.begin_object();
             liter != left.end_object();
             liter = left.erase(liter)
            )
        {
            auto riter = right.find(liter->first);
            if (riter == right.end_object())
            {
                result.left.insert({ liter->first, std::move(liter->second) });
            }
            else if (liter->second == riter->second)
            {
                result.same[liter->first] = std::move(liter->second);
                right.erase(riter);
            }
            else
            {
                diff_result subresult = diff(std::move(liter->second), std::move(riter->second));
                result.left[liter->first] = std::move(subresult.left);
                result.right[liter->first] = std::move(subresult.right);
                right.erase(riter);
            }
        }

        for (value::object_iterator riter = right.begin_object();
             riter != right.end_object();
             riter = right.erase(riter)
            )
        {
            result.right.insert({ riter->first, std::move(riter->second) });
        }
        break;
    }
    return result;
}
开发者ID:tgockel,项目名称:json-voorhees,代码行数:84,代码来源:algorithm_diff.cpp


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