在 C++ 中,std::decay
是一個模板元函數,它可以將類型轉換為其對應的非引用、非 cv-qualified(即非 const/volatile 修飾)類型
以下是一個簡單的例子,展示了如何使用 std::decay
實現一個簡單的智能指針:
#include<iostream>
#include <type_traits>
template<typename T>
class SmartPointer {
public:
explicit SmartPointer(T* ptr = nullptr) : _ptr(ptr) {}
// 析構時釋放資源
~SmartPointer() {
delete _ptr;
}
// 重載解引用運算符
typename std::add_lvalue_reference<T>::type operator*() const {
return *_ptr;
}
// 重載箭頭運算符
T* operator->() const {
return _ptr;
}
private:
T* _ptr;
};
template<typename T>
using DecaySmartPointer = SmartPointer<typename std::decay<T>::type>;
int main() {
DecaySmartPointer<int> p1(new int(42));
std::cout << "Value of p1: " << *p1<< std::endl;
DecaySmartPointer<int[]> p2(new int[3]{1, 2, 3});
std::cout << "Value of p2[0]: " << p2[0] << ", Value of p2[1]: " << p2[1] << ", Value of p2[2]: " << p2[2]<< std::endl;
return 0;
}
在這個例子中,我們定義了一個簡單的智能指針 SmartPointer
,并使用 std::decay
創建了一個新的類型別名 DecaySmartPointer
。這樣,當我們使用 DecaySmartPointer
時,傳入的類型會被自動轉換為其對應的非引用、非 cv-qualified 類型。這使得我們可以更方便地使用智能指針來管理不同類型的資源。