从'std :: string'转换为请求的非标量类型

Xir*_*dus 3 c++ constructor stdstring copy-constructor

我在实施课程时遇到了麻烦.它应该能够从std :: string初始化.所以我写了一个副本(?)构造函数:

CVariable (std::string&, const int p_flags = 0);
Run Code Online (Sandbox Code Playgroud)

我正在尝试制作一个CVariable的对象:

MCXJS::CVariable s_var = (string)"good job";
Run Code Online (Sandbox Code Playgroud)

我收到以下错误:

F:\Projekty\MCXJS\src\main.cpp|8|error: conversion from 'std::string' to non-scalar type 'MCXJS::CVariable' requested|
Run Code Online (Sandbox Code Playgroud)

如何解决?

我正在寻找能够完全按照以下方式获得解决方案的解决方案:

MCXJS::CVariable s_var = (string)"good job";
Run Code Online (Sandbox Code Playgroud)

编辑:添加(几乎)完整的源代码:

cvariable.h

#ifndef CVARIABLE_H
#define CVARIABLE_H

#include <string>
#include <sstream>

namespace MCXJS
{
enum VARTYPE
{
    STRING = 0,
    INT = 1,
    FLOAT = 2
};

class CVariable
{
    public:
    VARTYPE Type () {return m_type;};
    std::string& Value () {return m_value;};
    bool SetType (VARTYPE);

    private:
    const int m_flags;
    VARTYPE m_type;
    std::string m_value;

    // ctors and operators
    public:
    CVariable (const int p_flags = 0);
    CVariable (CVariable&, const int);
    CVariable (std::string const&, const int);
    CVariable (const int&, const int);
    CVariable (const float&, const int);

    CVariable& operator= (const CVariable&);
    CVariable& operator= (const std::string&);
    CVariable& operator= (const int);
    CVariable& operator= (const float);
};
};

#endif // CVARIABLE_H
Run Code Online (Sandbox Code Playgroud)

cvariable.cpp

#include "cvariable.h"

using namespace MCXJS;
using namespace std;

CVariable::CVariable (const int p_flags):
m_flags (p_flags)
{};

CVariable::CVariable (CVariable& p_var, const int p_flags = 0):
m_flags (p_flags),
m_type (p_var.Type()),
m_value (p_var.Value())
{};

CVariable::CVariable (std::string const& p_value, const int p_flags = 0):
m_flags (p_flags),
m_type (STRING),
m_value (p_value)
{};

CVariable::CVariable (const int p_value, const int p_flags = 0):
m_flags (p_flags),
m_type (INT)
{
std::ostringstream buffer;
buffer << p_value;
m_value = buffer.str();
};

CVariable::CVariable (const float p_value, const int p_flags = 0):
m_flags (p_flags),
m_type (FLOAT)
{
std::ostringstream buffer;
buffer << p_value;
m_value = buffer.str();
};
Run Code Online (Sandbox Code Playgroud)

main.cpp中

#include "cvariable.h"
#include <iostream>

using namespace std;

int main()
{
MCXJS::CVariable s_var = (string)"good job"; // error
cout << s_var.Value() << '\n';
return 0;
}
Run Code Online (Sandbox Code Playgroud)

编辑:添加枚举VARPARAM

编辑:好的,上面解决了,现在我有这个:

cvariable.cpp|12|error: passing 'const MCXJS::CVariable' as 'this' argument of 'MCXJS::VARTYPE MCXJS::CVariable::Type()' discards qualifiers|
cvariable.cpp|13|error: passing 'const MCXJS::CVariable' as 'this' argument of 'std::string& MCXJS::CVariable::Value()' discards qualifiers|
Run Code Online (Sandbox Code Playgroud)

Joh*_*itb 6

你需要通过const引用来获取它

CVariable (std::string const&, const int p_flags = 0);
Run Code Online (Sandbox Code Playgroud)

通过非const引用接受临时转换结果是没有意义的.之后对该参数的更改将会丢失.通过使它成为const引用使其工作很容易,因此标准C++只是禁止它.

  • 哇哇哇哇哇哇哇哇哇哇 如果我的答案只是一个公然的猜测,我会理解有没有理由的downvotes.但是因为我不只是猜测而是应用推理,所以我希望对于downvote,人们也是如此. (4认同)