![](/img/trans.png)
[英]Lifetime extension of temporary by non-const reference using const-cast
[英]C++ const-cast a reference
這個對嗎? 它可以使用我的編譯器進行編譯,但是有人告訴我它不使用AIX。
typedef std::vector<Entry>::iterator Iterator;
typedef std::vector<Entry>::const_iterator ConstIterator;
bool funct(ConstIterator& iter) const;
inline bool funct(Iterator& iter){return funct(const_cast<ConstIterator&>(iter));}
我應該怎么做才能使我的代碼在AIX平台上編譯? (除了使用Ctrl-C Ctrl-V重新實現非const版本外)。
const_cast
用於刪除變量的常數。 也就是說,如果您具有const A& a
,則可以編寫A& b = const_cast<A&>(a)
。 現在,您將可以修改b
或對其調用非常量方法。
在這種情況下,您可以從常規iterator
構造const_iterator
,即使不使用const_cast
也總是可能的。 請記住,這是兩種不同的類型,而const_iterator
恰好是可以從iterator
構造的,在這種情況下,C ++ const-ness沒什么要緊的。
iterator
和const_iterator
(通常)是不同的類型,因此您不能轉換引用。 但是, iterator
可轉換為const_iterator
,因此您可以執行
return funct(static_cast<ConstIterator>(iter));
或者,更安全,因為它僅允許顯式轉換:
ConstIterator citer = iter;
return funct(citer);
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.