模板函数中指针作为调用参数时模板参数的推导问题
2009-09-04 09:43
609 查看
在看C++ Templates的时候发现有下面的一段代码。试图比较两个int指针所指的内容的大小:
1
#include
<
iostream
>
2
3
template
<
typename T
>
4
inline T
*
const
&
max(T
*
const
&
a, T
*
const
&
b)
5
{
6
return
*
a
<
*
b
?
*
b :
*
a;
7
}
8
9
int
main()
10
{
11
int
a
=
7
;
12
int
b
=
42
;
13
14
int
*
p1
=
&
a;
15
int
*
p2
=
&
b;
16
17
std::cout
<<
"
max(p1 , p2):
"
<<
::max(p1 , p2)
<<
std::endl;
18
19
return
0
;
20
}
不能通过编译。提示[将类型为‘int* const&’的引用初始化为类型为‘int’的表达式无效]。
错误原因是第六行返回的是一个int类型的值,而返回值要求的是一个指针,因此出现了将一个int类型转化为一个指针无效的错误。
仔细想想,其实上面的代码有很严重的问题,max调用的时候传递的是一个int*,即指向整型的指针。那么,第三行的T应该是什么类型呢?
如果也是int*,那么模板实例化后的函数参数就成了int**,即指向int型的指针的指针。这明显不是想要的。
但是,如果将模板的定义改为一般的不带指针的形式:
1
template
<
typename T
>
2
inline T
const
&
max(T
const
&
a, T
const
&
b)
3
{
4
return
a
<
b
?
b : a;
5
}
那么,在比较的时候将会是两个指针地址的比较。因此,这也不能达到目的。
因此,唯一合理的解释就是对于两个int指针作为函数参数的max模板,在调用的时候模板参数将实例化为int类型,而非int*类型。
为此,作一个验证,代码修改如下:
1
#include
<
iostream
>
2
3
template
<
typename T
>
4
inline T
const
&
max(T
*
const
&
a, T
*
const
&
b)
5
{
6
return
*
a
<
*
b
?
*
b :
*
a;
7
}
8
9
int
main()
10
{
11
int
a
=
7
;
12
int
b
=
42
;
13
14
int
*
p1
=
&
a;
15
int
*
p2
=
&
b;
16
17
std::cout
<<
"
max(p1 , p2):
"
<<
::max(p1 , p2)
<<
std::endl;
18
19
return
0
;
20
}
编译器能很好的匹配主需要调用的模板,并实例化一个模板实例。需要注意的是第四行返回值已经不再是T*,而是T。
这样,上面的代码就能正常执行,并得到正确的结果了。
总结:模板函数实例化时参数类型可以通过调用参数推导出来。对于调用参数为指针的情况,实例化后模板函数的参数应该是指针原型的类型。而非指针类型。
己下来,以备忘记。如果发现有不对的地方,渴望指正。
1
#include
<
iostream
>
2
3
template
<
typename T
>
4
inline T
*
const
&
max(T
*
const
&
a, T
*
const
&
b)
5
{
6
return
*
a
<
*
b
?
*
b :
*
a;
7
}
8
9
int
main()
10
{
11
int
a
=
7
;
12
int
b
=
42
;
13
14
int
*
p1
=
&
a;
15
int
*
p2
=
&
b;
16
17
std::cout
<<
"
max(p1 , p2):
"
<<
::max(p1 , p2)
<<
std::endl;
18
19
return
0
;
20
}
不能通过编译。提示[将类型为‘int* const&’的引用初始化为类型为‘int’的表达式无效]。
错误原因是第六行返回的是一个int类型的值,而返回值要求的是一个指针,因此出现了将一个int类型转化为一个指针无效的错误。
仔细想想,其实上面的代码有很严重的问题,max调用的时候传递的是一个int*,即指向整型的指针。那么,第三行的T应该是什么类型呢?
如果也是int*,那么模板实例化后的函数参数就成了int**,即指向int型的指针的指针。这明显不是想要的。
但是,如果将模板的定义改为一般的不带指针的形式:
1
template
<
typename T
>
2
inline T
const
&
max(T
const
&
a, T
const
&
b)
3
{
4
return
a
<
b
?
b : a;
5
}
那么,在比较的时候将会是两个指针地址的比较。因此,这也不能达到目的。
因此,唯一合理的解释就是对于两个int指针作为函数参数的max模板,在调用的时候模板参数将实例化为int类型,而非int*类型。
为此,作一个验证,代码修改如下:
1
#include
<
iostream
>
2
3
template
<
typename T
>
4
inline T
const
&
max(T
*
const
&
a, T
*
const
&
b)
5
{
6
return
*
a
<
*
b
?
*
b :
*
a;
7
}
8
9
int
main()
10
{
11
int
a
=
7
;
12
int
b
=
42
;
13
14
int
*
p1
=
&
a;
15
int
*
p2
=
&
b;
16
17
std::cout
<<
"
max(p1 , p2):
"
<<
::max(p1 , p2)
<<
std::endl;
18
19
return
0
;
20
}
编译器能很好的匹配主需要调用的模板,并实例化一个模板实例。需要注意的是第四行返回值已经不再是T*,而是T。
这样,上面的代码就能正常执行,并得到正确的结果了。
总结:模板函数实例化时参数类型可以通过调用参数推导出来。对于调用参数为指针的情况,实例化后模板函数的参数应该是指针原型的类型。而非指针类型。
己下来,以备忘记。如果发现有不对的地方,渴望指正。
相关文章推荐
- 模板函数中指针作为调用参数时模板参数的推导问题
- 使用<a>标签提交表单数据的问题以及获取session作为函数的参数调用的问题
- 问题(怎样在dephi中引用.net中定义的类.方法参数,参数类型为XMLdocument?我要调用此方法并把实例花的xmldocument类型的变量作为参数给它。)
- 指针作为函数的参数传递的问题
- c++之指针作为函数参数传递的问题
- 关于指针作为函数参数传递的理解,对比普通变量作为函数参数的需注意点,其实就是行参和实参的问题。
- c++之指针作为函数参数传递的问题
- 使用指针作为函数返回值和参数的问题总结
- 指针作为函数的参数传递的问题
- 字符串参数的模板函数推导问题
- 指针作为函数的参数传递的问题
- c++之指针作为函数参数传递的问题
- 指针作为函数参数的问题
- C++指针作为函数参数的问题
- 指针数组作为函数参数的使用问题
- C++指针作为函数的参数进行传递时注意的问题
- 关于指针和数组对申请内存malloc和作为参数传递的一些问题
- 关于数组和指针作为参数时遇到的问题
- js调用方法传递变量作为参数的问题
- 数组作为函数参数的指针问题