C ++中的is_lvalue_reference模板

在本文中,我们将讨论C ++ STL中std::is_lvalue_reference模板的工作,语法和示例。

C ++中的is_lvalue_reference模板用于检查定义的类型是否为左值引用。

什么是左值?

左值是赋值运算符左侧的值。左值是引用内存位置的表达式。

什么是左值引用?

左值引用是绑定到左值的引用。这与我们过去在传统的C ++或C语言中引用变量的方式非常相似,即使用与符号(&)和变量本身来引用其地址。

示例

int& a;

语法

template <class T> is_lvalue_reference;

参数

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

返回值

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

示例

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

Input: is_lvalue<int>::value;
Output: False

示例

#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_lvalue_reference<TP>::value;
   cout << "\nTP& : "<< is_lvalue_reference<TP&>::value;
   cout << "\nTP&&: "<< is_lvalue_reference<TP&&>::value;
   return 0;
}

输出结果

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

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

示例

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

输出结果

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

Checking for is_lvalue_reference:
int : false
int& : true
int&&: false
char : false
char& : true
char&&: false
float : false
float& : true
float&&: false
double: false
double : true
double&&: false