在 C++ 中更改私有原始变量的值

Changing the value of a private primitive variable in C++

class A {
    private:
        int numberOfElements;

    public:
        A() : numberOfElements(0) {}
        void add() { numberOfElements++; }

numberOfElements 的值保持为 0。

void PhoneBook::add(std::string name, std::string phoneNumber) {
entries[numberOfElements] = Entry(name, phoneNumber);
numberOfElements++;
}

那是应该在我的应用程序中递增变量的实际代码。 Class A 只是我原来的 class 样例。

std::string PhoneBook::find(std::string name) {
for(int i = 0; i < numberOfElements; ++i) {
    std::cout << i << std::endl;
    if(entries[i].getName().compare(name) == 0) {
        return entries[i].getPhoneNumber();
    }
    return "Name not found";
}
}

我打印出 i 的值以查看它是什么,它仍然为 0。

void PhoneBook::add(std::string name, std::string phoneNumber) {
entries[numberOfElements] = Entry(name, phoneNumber);
numberOfElements++;
}

std::ifstream in;
in.open("phonebook.txt");

while(in >> name && in >> phoneNumber) {
    book.add(name, phoneNumber);
}
std::string PhoneBook::find(std::string name) {
for(int i = 0; i < numberOfElements; ++i) {
    std::cout << i << std::endl;
    if(entries[i].getName().compare(name) == 0) {
        return entries[i].getPhoneNumber();
    }
    // end of if, still in the loop
    return "Name not found";
    // we never get past this, so the loop will
    // run no more than a single time
}
}

问题可能是您提前终止了查找功能。将 return 语句放在 for 循环之外应该可以解决这个问题:

std::string PhoneBook::find(std::string const & name) {
    for(int i = 0; i < numberOfElements; ++i) {
        std::cout << i << std::endl;
        if(entries[i].getName().compare(name) == 0) {
            return entries[i].getPhoneNumber();
        }
    }
    return "Name not found";
}

请注意,我更改了缩进。清楚地缩进代码有助于防止此类错误。 (我还更改了函数以接受 const 引用,这消除了制作无用副本的需要)