我无法弄清楚为什么以下(大大简化)代码会返回错误error: 'm_sID' was not called in this scope
:
#include <iostream>
#include <string>
//////////////////////////////////////////
//header
class Person {
private:
std::string m_sID;
public:
//constructor
Person(std::string sID);
//getter
std::string getID() { return m_sID; }
//setter
void setID(std::string sID) { m_sID = sID; }
void comparePersonID();
};
//////////////////////////////////////////
//implementation
Person::Person(std::string sID) {
setID(sID);
}
void comparePersonID() {
if (m_sID == "12345")
std::cout << "success!" << std::endl;
}
//////////////////////////////////////////
//main
int main() {
std::string myStr = "1";
Person aPerson(myStr);
aPerson.setID("12345");
aPerson.comparePersonID();
}
由于comparePerson()
是类Person
的成员函数,因此它不应该能够访问私有变量m_sID
吗?
或者提出问题的另一种方式: 我知道在Ruby中,你可以通过调用self.getID
(或其中的某些内容)来实现这样的工作),但C ++中self
的工作等价物是什么,可以正确编译和执行。
答案 0 :(得分:1)
comparePersonID
是Person
的成员,因此定义必须位于Person
的范围内:
void Person::comparePersonID() { ....
^^^^^^^^
否则它只是非成员函数的声明和定义,显然不能直接访问任何类的成员。
另请注意,getID()
和comparePersonID()
应该是const
成员函数。
答案 1 :(得分:0)
在cpp:
void Person::comparePersonID() {
if (m_sID == "12345")
std::cout << "success!" << std::endl;
}
和
Person::Person(const std::string& sID) :m_sID(sID){}