优雅地处理重复、常量和非常量 Getter
作为程序员,我们经常遇到同时拥有 const 和非 const 的问题- 我们类中 getter 方法的 const 版本。虽然单独实现它们可能会导致代码重复,但找到解决此难题的优雅解决方案可能具有挑战性。
挑战
在提供的示例中,类 Foobar 需要两种 getSomething() 方法:一种非常量 (Something& getSomething(int index)) 和一种 const (const Something& getSomething(int index))常量)。然而,尝试与其他方法一起实现这些方法不可避免地会导致编译器错误。从 const 版本转换为非 const 版本也是一种必要的罪恶。
优雅的解决方案
尽管绝对原始的解决方案可能不可行,但最常见的解决方案是推荐的方法是放弃其他函数中的 cons 。虽然不太美观,但它是一种安全的技术,因为调用成员函数是非常量的,这意味着对象本身是非常量的,并且允许丢弃常量。
将以下代码片段视为示例:
class Foo { public: const int& get() const { // non-trivial work return foo; } int& get() { return const_cast<int&>(const_cast<const Foo*>(this)->get()); } };
在此示例中,get() 的非 const 版本从 const 版本中抛弃了 const,从而允许它修改对象本身。
以上是我们如何优雅地处理重复的 const 和非 const getter 方法?的详细内容。更多信息请关注PHP中文网其他相关文章!