官术网_书友最值得收藏!

Querying the type of an expression using the decltype keyword

We discussed in the preceding section that the auto keyword can automatically deduce the type of the variable based on the type of values it stores. The keyword can also deduce the function's return type based on the type of its return value. Now, let's combine the auto keyword and the decltype keyword to gain the power of modern C++.

Before we combine the two keywords, we will find out what the decltype keyword is used for--it is used for asking the type of an object or an expression. Let's take a look at the following several lines of trivial variable declaration:

    const int func1();
const int& func2();
int i;

struct X { double d; };
const X* x = new X();

Now, based on the preceding code, we can declare other variables using the decltype keyword as follows:

    // Declaring const int variable
// using func1() type
decltype(func1()) f1;

// Declaring const int& variable
// using func2() type
decltype(func2()) f2;

// Declaring int variable
// using i type
decltype(i) i1;

// Declaring double variable
// using struct X type
decltype(x->d) d1; // type is double
decltype((x->d)) d2; // type is const double&

As we can see in the preceding code, we can specify the type of an object based on another object's type. Now, let's suppose we need to refactor the preceding add() method to become a template. Without the auto and decltype keyword, we will have the following template implementation:

    template<typename I, typename J, typename K>
K add(I i, J j)
{
return i + j;
}

Fortunately, since the auto keyword can specify the return type of the function, which is a trailing return type, and the decltype keyword can deduce the type based on the expression, we can refactor the preceding template as follows:

    template<typename I, typename J>
auto add(I i, J j) -> decltype(i + j)
{
return i + j;
}

To prove, let's compile and run the following decltype.cpp code. We will use the following template to calculate the addition of two different value types--integer and double:

    /* decltype.cpp */
#include <iostream>

// Creating template
template<typename I, typename J>
auto add(I i, J j) -> decltype(i + j)
{
return i + j;
}

auto main() -> int
{
std::cout << "[decltype.cpp]" << std::endl;

// Consuming the template
auto d = add<int, double>(2, 2.5);

// Displaying the preceding variables' type
std::cout << "result of 2 + 2.5: " << d << std::endl;

return 0;
}

The compilation process should run smoothly without error. We will see the following output on the screen if we run the preceding code:

As we can see, we have successfully combined the auto and decltype keyword to create a template simpler than we usually do before the modern C++ is announced.

主站蜘蛛池模板: 金寨县| 肥城市| 洛浦县| 土默特右旗| 托克托县| 剑川县| 鸡泽县| 南部县| 苏尼特右旗| 夏河县| 洞头县| 上蔡县| 南部县| 房产| 永新县| 湘潭市| 黄龙县| 大新县| 宽城| 正定县| 略阳县| 余庆县| 宜良县| 金堂县| 安仁县| 东台市| 南宁市| 嘉祥县| 辽阳县| 余姚市| 武邑县| 弥勒县| 扬州市| 炉霍县| 富阳市| 轮台县| 浠水县| 河北省| 色达县| 广宗县| 万安县|