0

下面显示的源代码是检查 Document 类对象的成员的一部分。我们试图创建一个值类的对象,即“memberObject”,并将对象引用存储到“_value”值引用私有成员变量中。查看输出,我们可以看到对象的类型是 3(对象)。但是,使用 memberObject 分配 _value 引用变量后,输出显示类型更改为 0 (NULL)。我们希望这样的类型更改不应该发生。你能解释一下为什么会这样吗?

  for (Value::MemberIterator itr = _document.MemberBegin(); itr != _document.MemberEnd(); itr++)
  {
        _itr = itr;

        _name = itr->name.GetString();
        _objectTypeID = (int)itr->value.GetType();

        cout << "Member [" << _name << "] - type is [" << _objectTypeID << "]" << endl;

        _typeID = _objectTypeID;

        if (itr->value.IsObject())
        {
              Value& memberObject = _document[_name.c_str()];
              cout << "Value type(1): " << memberObject.GetType() << endl;

              _value = (Value&)memberObject;
              cout << "Value type(2): " << memberObject.GetType() << endl;
        }


        _st.push(_itr);

        parseValue();

        _itr = _st.top();  // returns the next element in the stack
        _st.pop();         // removes an element from the stack
  }

"firmwareSettings": {
    "manageFirmware": false,
    "firmwareBaselineUri": ""
},

成员 [firmwareSettings] - 类型为 [3]
值类型 (1):3
值类型 (2):0

4

1 回答 1

1

这种行为是预期的,因为 GenericValue 的赋值运算符使用移动语义

这是rapidjsonGenericValue的赋值运算符:

 //! Assignment with move semantics.
    /*! \param rhs Source of the assignment. It will become a null value after assignment.
    */
    GenericValue& operator=(GenericValue& rhs) {
        RAPIDJSON_ASSERT(this != &rhs);
        this->~GenericValue();
        memcpy(this, &rhs, sizeof(GenericValue));
        rhs.flags_ = kNullFlag;
        return *this;
    }

memberObject分配给_value时,赋值运算符开始更改flags_成员,该成员是右值对象的 GetType() 方法返回的值。

有关移动语义的更多详细信息,请参阅什么是移动语义?

于 2014-04-14T22:01:40.730 回答