当前位置:  开发笔记 > 编程语言 > 正文

C ++中定义上下文和实例化点之间非依赖性构造的解释差异

如何解决《C++中定义上下文和实例化点之间非依赖性构造的解释差异》经验,为你挑选了1个好方法。

这是一个例子:

extern const int b;

template
void f(int);

template
void f(long);

template
void g() {
    f<0, b>(0);
}
// #1

extern const int b = 0;


int main(){
    g(); 
}

// #2

在#1处的假设实例化将调用void f<0, b>(long),因为此时b不是常量表达式,所以(int)重载SFINAE消失了。#2处的实例化(这是的实例化点g)将调用void f<0, 0>(int),因为到那时b是一个常量表达式,(int)重载是可行的,并赢得了重载解决方案。

Clang和GCC实际上将f使用此代码调用不同的。



1> T.C...:

这是一个例子:

extern const int b;

template
void f(int);

template
void f(long);

template
void g() {
    f<0, b>(0);
}
// #1

extern const int b = 0;


int main(){
    g(); 
}

// #2

在#1处的假设实例化将调用void f<0, b>(long),因为此时b不是常量表达式,所以(int)重载SFINAE消失了。#2处的实例化(这是的实例化点g)将调用void f<0, 0>(int),因为到那时b是一个常量表达式,(int)重载是可行的,并赢得了重载解决方案。

Clang和GCC实际上将f使用此代码调用不同的。

推荐阅读
mobiledu2402852413
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有