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

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.

主站蜘蛛池模板: 荣昌县| 桂阳县| 琼中| 扬中市| 杂多县| 富顺县| 鹤山市| 常德市| 招远市| 桓仁| 三明市| 民丰县| 积石山| 莱州市| 县级市| 郑州市| 云林县| 嘉荫县| 祁东县| 房产| 汉川市| 郴州市| 上思县| 靖远县| 静海县| 博客| 镶黄旗| 田阳县| 淮滨县| 荆州市| 威海市| 林州市| 张家界市| 鲁山县| 抚松县| 嘉义市| 广宁县| 淮南市| 锡林郭勒盟| 兴化市| 凉山|