程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> function object研究之addressof

function object研究之addressof

編輯:C++入門知識

來看看boost::detail::addr_impl_ref模板,在addressof.hpp文件中:

[cpp] 
template<class T> struct addr_impl_ref 

    T & v_; 
 
    inline addr_impl_ref( T & v ): v_( v ) {} 
    inline operator T& () const { return v_; } 
 
private: 
    addr_impl_ref & operator=(const addr_impl_ref &); 
}; 

這個模板將構造函數的參數保存到內部引用變量中,並禁止賦值操作,同時提供了T&類型轉換操作。下面是使用例子:
[cpp] 
string str = "ok"; 
boost::detail::addr_impl_ref<string> r(str); 
string & str2 = (string &)r; 

再看看addressof_impl模板:
[cpp] 
template<class T> struct addressof_impl 

    static inline T * f( T & v, long ) 
    { 
        return reinterpret_cast<T*>( 
            &const_cast<char&>(reinterpret_cast<const volatile char &>(v))); 
    } 
 
    static inline T * f( T * v, int ) 
    { 
        return v; 
    } 
}; 

這個模板的構造函數接受T& v作為參數,並返回v的指針。注意,這裡碰到了非常奇怪的reinterpret_cast的連續使用,主要是為了防止T類型重載了operator & 導致行為未定義。這種奇怪的使用方式解決了這個問題,能夠獲得真是的v的地址。
 有了前兩個基礎,看看boost提供的非常有用的addressof模板:

[cpp]
template<class T> T * addressof( T & v ) 

#if defined( __BORLANDC__ ) && BOOST_WORKAROUND( __BORLANDC__, BOOST_TESTED_AT( 0x610 ) ) 
 
    return boost::detail::addressof_impl<T>::f( v, 0 ); 
 
#else 
 
    return boost::detail::addressof_impl<T>::f( boost::detail::addr_impl_ref<T>( v ), 0 ); 
 
#endif 


現在可以總結下:
boost::addressof接受T& v,返回T指針。而且無需擔心T是否重載了自己的operator &.

 

 


 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved