免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 5632 | 回复: 19
打印 上一主题 下一主题

一个模板特化的匹配问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-02-01 20:47 |只看该作者 |倒序浏览
>> 在C++中,字符串字符值的类型是const char[NUM]型,为什么下面的函数调用func("hello", "world");
>> 会匹配到特化版本func<char [6]>?
>> 另一个问题:如果要特化模板形参为const char[NUM]的版本,应该怎么做?

现在对原问题和代码做了修改,问题集中于数组类型和其它类型(下面用的是字符指针类型作对比)在匹配模板及其特化版本时的问题(或者区别?):

从代码及输出得到如下认识:
   对于数组类型,下面的那个绿色的const char[NUM]类型的版本似乎没有机会被选用(我没找到方法),无论实参数组是const还是非const,都匹配到形参为非const数组的const引用。而对于指针类型就不一样,从第二个输出结果可看出这两者之间的区别(实在不好文字描述)

#include <iostream>
using namespace std;

template<typename T>
    void func (const T &v1, const T &v2) {
        cout<<"template"<<endl;
    }

template <>
    void func<char*> (char* const  &v1, char* const  &v2) {
        cout<<"Specialization: char*"<<endl;
    }
        
template <>
    void func<const char*> (const char* const  &v1, const char* const  &v2) {
        cout<<"Specialization: const char*"<<endl;
    }

   
// 下面写法有点奇怪
template <>
    void func<const char [6]> ( char const (&v1)[6],  char const (&v2)[6]) {
        cout<<"Specialization: const char[6]"<<endl;
    }

template <>
    void func<char [6]> ( char const (&v1)[6],  char const (&v2)[6]) {
        cout<<"Specialization: char[6]"<<endl;
    }
   
int main()
{
    char *p1 = "hello";
    char *p2 = "world";
    func(p1, p2);
        
    char * const p3 = "hello";
    char * const p4 = "world";
    func(p3, p4);
   
    const char *p5 = "hello";
    const char *p6 = "world";
    func(p5, p6);
        
    const char * const p7 = "hello";
    const char * const p8 = "world";
    func(p7, p8);
   
    char a1[6] = "hello";
    char a2[6] = "world";
    func(a1, a2);
        
    const char a3[6] = "hello";
    const char a4[6] = "world";
    func(a3, a4);
        
    return 0;
}

上面代码运行结果为:
Specialization: char*
Specialization: char*
Specialization: const char*
Specialization: const char*
Specialization: char[6]
Specialization: char[6]

然后我把代码中红色部分注释之后,运行结果为:
Specialization: char*
Specialization: char*
template
template
Specialization: char[6]
Specialization: char[6]

[ 本帖最后由 tyc611 于 2007-2-2 17:13 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2007-02-01 21:06 |只看该作者
会匹配最特化的情况.

论坛徽章:
0
3 [报告]
发表于 2007-02-01 21:45 |只看该作者
如果你把
char a1[6] = "hello";
        char a2[6] = "world";
中的元素个数改成其他的数量就可以有效果了,try it~~

论坛徽章:
0
4 [报告]
发表于 2007-02-01 21:59 |只看该作者
原帖由 converse 于 2007-2-1 21:06 发表
会匹配最特化的情况.

问题是,这儿的
   func("hello", "world");

    template <>
    void func<char [6]> (char const (&v1)[6],  char const (&v2)[6]) ;
并不完全匹配,形参是char [6],实参是const char[6]。按模板实例化规则,这里应该调用模板版本而不是特化版本

而调用
   func(p1, p2);
时,就没有匹配
   template <>
    void func<char*> (char* const  &v1, char* const  &v2);
这里,形参是char*, 实参是const char*

为什么有这种差别?

论坛徽章:
0
5 [报告]
发表于 2007-02-01 22:00 |只看该作者
原帖由 converse 于 2007-2-1 21:45 发表
如果你把
char a1[6] = "hello";
        char a2[6] = "world";
中的元素个数改成其他的数量就可以有效果了,try it~~

这样改了,类型完全不一样了,肯定与特化版本不匹配

论坛徽章:
0
6 [报告]
发表于 2007-02-02 11:57 |只看该作者
The top-level cv-qualifiers on the template-parameter are ignored when determining its type.

论坛徽章:
0
7 [报告]
发表于 2007-02-02 12:28 |只看该作者
char t1[n]
char t2[m]
类型是不一样的。

匹配到特化是因为函数会把字符数组进化成指针

论坛徽章:
0
8 [报告]
发表于 2007-02-02 13:11 |只看该作者
我的编译器显示是这样的

template
Specialization: char[6]
template
请按任意键继续. . .

论坛徽章:
0
9 [报告]
发表于 2007-02-02 13:12 |只看该作者
原帖由 whyglinux 于 2007-2-2 11:57 发表
The top-level cv-qualifiers on the template-parameter are ignored when determining its type.

不是很明白你上面这儿的意思,能否举例说明一下
    一般而言,不会转换实参以匹配已有的实例化,相反,会产生新的实例。除了产生新的实例化之外,编译器只会执行两种转换:
    > const转换:接受const引用或const指针的函数可以分别用非const对象的引用或指针来调用,而无须产生新的实例化。如果函数接受非引用类型,形参类型和实参都忽略const,即无论传递const或非const对象给接受非引用类型的函数,都使用相同的实例化。
    > 数组或函数到指针的转换:如果模板形参不是引用类型,则对数组或函数类型的实参应用常规指针转换。数组实参将当作指向其第一个元素的指针,函数实参当作指向函数类型的指针。
                -------------------- C++ Primer4, P538

[ 本帖最后由 tyc611 于 2007-2-2 13:13 编辑 ]

论坛徽章:
0
10 [报告]
发表于 2007-02-02 13:13 |只看该作者
原帖由 oract666 于 2007-2-2 13:11 发表
我的编译器显示是这样的

template
Specialization: char[6]
template
请按任意键继续. . .

请问一下,你是什么编译器,我是MinGW2.05
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP