171人参与 • 2025-02-24 • C/C++
在 c++ 中,mutable 关键字用于修饰类的成员变量,允许在 const 成员函数中修改这些变量。它的核心作用是区分 物理常量性(对象内存不可修改)和 逻辑常量性(对象对外表现的状态不变)。以下是详细解析:
class dataprocessor {
private:
mutable std::string cachedresult; // 缓存计算结果
mutable bool iscachevalid = false; // 缓存有效性标志
std::vector<int> rawdata;
public:
const std::string& getresult() const {
if (!iscachevalid) {
// 在 const 函数中更新缓存
cachedresult = computeresult();
iscachevalid = true;
}
return cachedresult;
}
void updatedata(const std::vector<int>& newdata) {
rawdata = newdata;
iscachevalid = false; // 数据更新后缓存失效
}
private:
std::string computeresult() const { /* 复杂计算 */ }
};getresult() 函数的调用不会改变对象的“有效状态”(rawdata 未变)。mutable 允许修改缓存相关变量,提升性能。class threadsafecontainer {
private:
mutable std::mutex mtx; // 互斥锁
std::vector<int> data;
public:
void add(int value) {
std::lock_guard<std::mutex> lock(mtx);
data.push_back(value);
}
bool contains(int value) const {
std::lock_guard<std::mutex> lock(mtx); // const 函数中锁定
return std::find(data.begin(), data.end(), value) != data.end();
}
};锁状态修改:互斥锁(std::mutex)需要在 const 函数中被锁定和解锁,但其内部状态的修改不影响容器数据的逻辑状态。
class sensor {
private:
mutable int readcount = 0; // 记录读取次数(调试用)
double currentvalue;
public:
double readvalue() const {
readcount++; // 不影响传感器数据逻辑状态
return currentvalue;
}
int getreadcount() const { return readcount; }
};const 成员函数保证)。mutable 用于支持逻辑常量性,允许在 const 函数中修改不影响对象外部行为的成员变量。// 错误示例:mutable 破坏了逻辑常量性
class bankaccount {
private:
mutable double balance; // 危险!
public:
double getbalance() const {
balance -= 1.0; // 错误!const 函数不应改变账户余额
return balance;
}
};class networkconnection {
private:
mutable std::atomic<bool> isconnected_{false}; // 明确标记可变状态
// ... 其他成员 ...
};class cache {
private:
mutable std::shared_mutex cachemutex;
mutable std::unordered_map<int, std::string> cache;
public:
std::string get(int key) const {
std::shared_lock lock(cachemutex); // 读锁(共享)
if (auto it = cache.find(key); it != cache.end()) {
return it->second;
}
return "";
}
void update(int key, const std::string& value) {
std::unique_lock lock(cachemutex); // 写锁(独占)
cache[key] = value;
}
};class configmanager {
private:
mutable std::once_flag initflag; // 仅用于延迟初始化
mutable std::string configpath;
void loadconfig() const {
std::call_once(initflag, [this] {
configpath = readconfigfile(); // 延迟初始化
});
}
public:
const std::string& getconfigpath() const {
loadconfig(); // 首次调用时初始化
return configpath;
}
};| 错误类型 | 示例 | 解决方法 |
|---|---|---|
| 破坏逻辑常量性 | mutable 修饰关键业务数据 | 严格区分内部状态与外部状态 |
| 未同步的多线程访问 | mutable 变量无锁访问 | 结合互斥锁或原子操作 |
| 构造函数中误用 | 在构造函数中依赖 mutable 状态 | 确保状态初始化完成前不依赖 |
错误类型示例解决方法破坏逻辑常量性mutable 修饰关键业务数据严格区分内部状态与外部状态未同步的多线程访问mutable 变量无锁访问结合互斥锁或原子操作构造函数中误用在构造函数中依赖 mutable 状态确保状态初始化完成前不依赖
mutable 变量的修改不破坏对象的逻辑常量性。到此这篇关于c++中使用mutable关键字的场景分析的文章就介绍到这了,更多相关c++ 使用mutable关键字内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
您想发表意见!!点此发布评论
版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。
发表评论