2015-02-10 47 views
-1

我不能找出为什么以下(大大简化)代码返回错误error: 'm_sID' was not called in this scopeC++类属性未定义用于非存取方法

#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(或东西左右)工作,但什么是工作相当于self在C++那编译并正确执行。

回答

1

comparePersonIDPerson成员,所以定义需要在Person的范围:

void Person::comparePersonID() { .... 
    ^^^^^^^^ 

否则,它仅仅是一个声明和一个非成员函数的定义,显然不能直接访问任何班级的成员。

另请注意,getID()comparePersonID()应该确实是const成员函数。

+0

啊确定,使得有很大的意义。来自更高级别的语言,我期望'Person'头文件中的函数声明足以让编译器推断范围,但很明显这会导致问题,如果在每个函数中有两个相同名称的方法单独的课程。 – JDRomano2 2015-02-10 18:49:21

0

在CPP:

void Person::comparePersonID() { 
    if (m_sID == "12345") 
     std::cout << "success!" << std::endl; 
} 

Person::Person(const std::string& sID) :m_sID(sID){} 
相关问题