`
369540808
  • 浏览: 196343 次
文章分类
社区版块
存档分类
最新评论

C++ - 函数模板(function template)返回值

阅读更多

函数模板(function template)返回值


本文地址:http://blog.csdn.net/caroline_wendy/article/details/17003679


函数模板的返回值也可以定义为模板参数(template parameter), 但是由于无法推导(deduce), 需要显式(explicit)指定;

由于显式指定的顺序是从左至右, 返回值参数尽量放在左面,其余函数参数可以通过传入实参(argument)进行推导;

也可以提供由其他参数推导出的返回值类型, 需要使用拖尾返回类型(trailing return type);

使用decltype()函数推导, 即"编译时定义的类型", 注意使用拖尾返回类型时, 前置需要"auto", 后面使用"->";

也可以使用类型转换模板(type transformation templates)修改返回值类型, 主要应用于模板元编程(template metaprogramming);

注意使用"typename"限定词, 表明是类型, 不是静态成员; 类型转换函数包含type成员, 表明类型;

代码如下:

/*
 * cppprimer.cpp
 *
 *  Created on: 2013.11.28
 *      Author: Caroline
 */

/*eclipse cdt, gcc 4.8.1*/

#include <iostream>
#include <vector>
#include <string>
#include <type_traits>
#include <typeinfo>

using namespace std;

/*需要显示定义返回类型*/
template <typename T1, typename T2, typename T3>
T1 sum (T2, T3)
{
	T2 i2; T3 i3;
	return static_cast<T1>(i2+i3);
}

/*注意拖尾返回类型(trailing return type)前面需要加auto*/
template <typename It>
auto fcn(It beg, It end) -> decltype(*beg)
{
	return *beg;
}

/*注意拖尾返回类型是值, 注意第二个typename, 表明为类型*/
template <typename It>
auto fcn2(It beg, It end) ->
	typename remove_reference<decltype(*beg)>::type
{
	return *beg;
}

int main (void) {

	std::cout << "The type of sum return : " <<
			typeid(sum<float>(2, 3)).name() << std::endl;

	std::vector<int> vi = {1, 2, 3, 4, 5};
	std::vector<std::string> vs = {"girl", "lady"};

	/*返回的是引用*/
	auto &i = fcn(vi.begin(), vi.end());
	auto &s = fcn(vs.begin(), vs.end());
	i = 12, s = "woman";

	std::cout << "*vi.begin() = " << *vi.begin() << std::endl;
	std::cout << "*vs.begin() = " << *vs.begin() << std::endl;

	/*返回的是值, 所以不能在使用&符号*/
	auto i2 = fcn2(vi.begin(), vi.end());
	auto s2 = fcn2(vs.begin(), vs.end());

	std::cout << "i2 = " << i2 << std::endl;
	std::cout << "s2 = " << s2 << std::endl;

	return 0;

}


输出:

The type of sum return : f
*vi.begin() = 12
*vs.begin() = woman
i2 = 12
s2 = woman





分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics