C ++中的is_rvalue_reference模板

在本文中,我们将讨论C ++ STL中std::is_rvalue_reference模板的工作,语法和示例。C ++中的is_rvalue_reference模板用于检查定义的类型是否为右值引用。

什么是右值?

Rvalues是赋值运算符右侧的值。右值是值

什么是右值参考?

右值参考由双与号(&&)标识。仅用于使用右值初始化它。

语法

int&& a;

语法

template <class T> is_rvalue_reference;

参数

模板只能具有类型T的参数,并检查给定类型是否为右值引用

返回值

它返回一个布尔值,如果给定值是右值引用,则返回true;如果给定值不是右值引用,或者当我们引用未知位置时,则返回false。

示例

Input: is_rvalue<int&>::value;
Output: False

Input: is_rvalue<int&&>::value;
Output: True

示例

#include <iostream>
#include <type_traits>
using namespace std;
int main() {
   cout << std::boolalpha;
   cout << "Checking for is_lvalue_reference: ";
   cout << "\nint : "<<is_rvalue_reference<int>::value;
   cout << "\nint& : "<< is_rvalue_reference<int&>::value;
   cout << "\nint&&: "<< is_rvalue_reference<int&&>::value;
   cout << "\nchar : "<<is_rvalue_reference<char>::value;
   cout << "\nchar& : "<< is_rvalue_reference<char&>::value;
   cout << "\nchar&&: "<< is_rvalue_reference<char&&>::value;
   cout << "\nfloat : "<<is_rvalue_reference<float>::value;
   cout << "\nfloat& : "<< is_rvalue_reference<float&>::value;
   cout << "\nfloat&&: "<< is_rvalue_reference<float&&>::value;
   cout << "\ndouble : "<<is_rvalue_reference<double>::value;
   cout << "\ndouble& : "<< is_rvalue_reference<double&>::value;
   cout << "\ndouble&&: "<< is_rvalue_reference<double&&>::value;
   return 0;
}

输出结果

如果我们运行上面的代码,它将生成以下输出-

Checking for is_rvalue_reference:
int : false
int& : false
int&&: ture
char : false
char& : false
char&&: ture
float : false
float& : false
float&&: ture
double: false
double : false
double&&: ture

示例

#include <iostream>
#include <type_traits>
using namespace std;
class TP {
};
int main() {
   cout << std::boolalpha;
   cout << "Checking for is_lvalue_reference: ";
   cout << "\nTP class : "<<is_rvalue_reference<TP>::value;
   cout << "\nTP& : "<< is_rvalue_reference<TP&>::value;
   cout << "\nTP&&: "<< is_rvalue_reference<TP&&>::value;
   return 0;
}

输出结果

如果我们运行上面的代码,它将生成以下输出-

Checking for is_rvalue_reference:
TP class : false
TP& : false
TP&&: true