据我了解,成员函数末尾的 const 说明符意味着类的成员在该函数内不能被修改,除非它们被声明为可变的。 话虽如此,我有以下几点:
mns::list::list 是我的链表实现,其函数不是 const。
template<typename T> class HashTable{
private:
std::vector<mns::list::list<T> * > * hashtable;
long long int size;
public:
HashTable(int _size){
hashtable = new std::vector<mns::list::list<T> * >(_size, NULL);
size = _size;
}
....
bool insert(T _value) const {
long long int hash_value = getHash(_value);
if (hashtable->at(hash_value) == NULL) hashtable->at(hash_value) = new mns::list::list<T>(_value);
else if (hashtable->at(hash_value)->find_forward(_value) == -1) hashtable->at(hash_value)->push_top(_value);
}
....
}
我的 main 中有一个函数:
void testhash(){
HashTable<int> testhashtable1(100);
std::cout << testhashtable1.find(45) << std::endl;
testhashtable1.insert(45);
std::cout << testhashtable1.find(45) << std::endl;
}
鉴于 HashTable::insert 是一个 const 函数,我假设我无法修改私有成员哈希表。但是 testhash() 打印:
0
1
这意味着成员被修改了......对吗? 所以我似乎在这里错过了一些东西......为什么私有成员向量哈希表被修改?
你的数据成员是一个指向向量的指针。在
const
成员函数 insert
中,所有数据成员都将是 const
,因此您的数据成员现在被视为指向向量的 const 指针。由于您不尝试修改指针本身(例如hashtable = nullptr
)而是它指向的向量,因此向量将被修改。
指向某种类型的常量指针
指向某个 const 类型的指针
他们完全不同
成员函数的
const
说明符允许在对象为 const
时调用该函数。因此该函数不允许修改成员或调用非常量成员函数。