如何在C++中将const结构体指针传递给一个setter方法?

3

我正在尝试将一个常量结构体指针传递给自动生成的C++ API代码的setter setContainer,因此我无法更改该类:

#include <iostream>
#include <memory>

class Class // Class definition
{
public:
    struct Container    // Container definition
    {
        double value = 0.0;
    };

    Class() { } // constructor
    ~Class() { } // destructor

    void setContainer(const Container * pContainer)
    {   
        mContainer = *pContainer; // setter
    }

    const Class::Container & getContainer() const
    {
        return mContainer; // getter
    }

private:
    Container mContainer;
};

正如你所看到的,我不知道如何以正确的方式将结构体对象传递给setContainer方法。 如果我使用C++14,智能指针会更好。

int main()
{    
    Class objClass; 

    const auto container1 = objClass.getContainer();

    // Output: container1.value: 0.0
    std::cout << "container1.value: " << container1.value << std::endl; 
    
    // Need to set this at runtime
    Class::Container container2;
    container2.value = 5.0; 

    // Output: container2.value: 5.0
    std::cout << "container2.value: " << container2.value << std::endl; 
    
    // ERROR: no matching function for call to ‘Class::setContainer(Class::Container&)’
    objClass.setContainer(container2); 
    
    const auto container3 = objClass.getContainer();

    // Desired Output: container3.value: 5.0 (set by setContainer)
    std::cout << "container3.value: " << container3.value << std::endl; 

    return 0;
}

我非常感激你能帮助我正确地完成这个任务。


你甚至可以考虑完全不使用指针。void setContainer(const Container& container) 将更加安全。(你不能在引用中放置 nullptr) - Pepijn Kramer
void setContainer(const Container * pContainer)更改为void setContainer(Container const& pContainer)。否则,您还需要检查nullptr,并且调用者必须传递一个Container的地址。 - Eljay
2个回答

1
你的setter函数期望一个指向Container对象的指针,所以给它一个:只需在参数中添加&运算符即可。
    objClass.setContainer(&container2);

-1
你可以使用智能指针和get()函数来提取原始指针,如下所示。
std::shared_ptr<Class::Container>m_container2 = std::make_shared<Class::Container>(container2);
 objClass.setContainer(m_container2.get()); 

或者你可以使用 & 运算符来获取指针。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接