当前位置: 首页 > news >正文

北京微信网站制作电话贴吧推广

北京微信网站制作电话,贴吧推广,邢台seo优化,深圳公众号开发公司1、基础语法 在 C 中&#xff0c;template<typename Func, typename void> 这一模板声明不仅仅限于函数模板&#xff0c;它在类模板中同样具有强大的应用。结合 SFINAE&#xff08;Substitution Failure Is Not An Error&#xff09;和 类型特征&#xff08;type trait…

1、基础语法

在 C++ 中,template<typename Func, typename = void> 这一模板声明不仅仅限于函数模板,它在类模板中同样具有强大的应用。结合 SFINAE(Substitution Failure Is Not An Error)和 类型特征(type traits),我们可以根据类型特征(如是否可调用、是否为某种类型等)来实现不同的类特化,从而使得我们的代码更加灵活、可扩展。
在类模板中,template<typename Func, typename = void> 的基本结构类似于函数模板,但其作用是为类提供更强的类型约束和灵活性。例如:

template<typename Func, typename = void>
class MyClass {
public:void call(Func&& f) {// Generic behavior}
};

这里,template<typename Func, typename = void> 表示 MyClass 是一个模板类,它接受一个类型参数 Func,第二个模板参数 = void 是默认值。该类可以根据不同类型的 Func 做出不同的行为,而 = void 通常用于与 SFINAE 机制配合,决定是否允许某些特定的类型实例化该类模板。

2、类模板的默认类型参数:简化和泛化

与函数模板类似,template<typename Func, typename = void> 在类模板中的一个常见用途是通过默认类型参数简化模板声明。我们通常使用第二个类型参数 = void 来启用某些特化或重载,这通常结合 SFINAE 使用。通过这种方式,模板类在默认情况下为某些类型提供通用行为,而在遇到特定类型时可以提供特化的行为。假设我们希望在类模板 MyClass 中提供一个 call 成员函数,当 Func 是可调用类型时,执行该函数,而如果 Func 不是可调用类型,则提供默认行为,代码如下:

#include <iostream>
#include <type_traits>template<typename Func, typename = void>
class MyClass {
public:void call(Func&& f) {std::cout << "Generic version of call" << std::endl;}
};// 特化版本:当 Func 是可调用类型时
template<typename Func>
class MyClass<Func, typename std::enable_if<std::is_invocable<Func>::value>::type> {
public:void call(Func&& f) {std::cout << "Callable function version of call" << std::endl;f(); // 执行传入的可调用对象}
};void test_func() {std::cout << "test_func executed!" << std::endl;
}int main() {MyClass<int> obj1;obj1.call(42);  // 输出: Generic version of callMyClass<void(*)()> obj2;obj2.call(test_func);  // 输出: Callable function version of call//        test_func executed!
}
  • 通用版本:当 Func 不是可调用类型时,MyClass<Func, typename = void> 使用默认版本的 call 函数输出 “Generic version of call”。
  • 特化版本:当 Func 是可调用类型时,我们通过 std::enable_if 和 std::is_invocable 来限制模板实例化,使得编译器选择特化版本的 call,在这种情况下,我们可以直接调用 f() 来执行传入的可调用对象。

3、SFINAE:类模板中根据类型特征选择特化

template<typename Func, typename = void> 还常常与 SFINAE 结合使用来根据类型的不同提供不同的实现。SFINAE 机制允许在类型不匹配时,编译器不报错,而是选择其他合适的模板特化或重载版本。可以使用该技术根据类型特征提供不同的成员函数,我们将使用 std::is_integral 和 std::is_floating_point 类型特征来为整数类型和浮动类型提供不同的处理方法:

#include <iostream>
#include <type_traits>template<typename T, typename = void>
class MyClass {
public:void print() {std::cout << "Generic version: Unknown type" << std::endl;}
};// 特化版本:当 T 是整数类型时
template<typename T>
class MyClass<T, typename std::enable_if<std::is_integral<T>::value>::type> {
public:void print() {std::cout << "Integer version: " << sizeof(T) << " bytes" << std::endl;}
};// 特化版本:当 T 是浮动类型时
template<typename T>
class MyClass<T, typename std::enable_if<std::is_floating_point<T>::value>::type> {
public:void print() {std::cout << "Floating point version: " << sizeof(T) << " bytes" << std::endl;}
};int main() {MyClass<int> obj1;obj1.print();  // 输出: Integer version: 4 bytesMyClass<double> obj2;obj2.print();  // 输出: Floating point version: 8 bytesMyClass<std::string> obj3;obj3.print();  // 输出: Generic version: Unknown type
}
  • 通用版本:对于非整数和非浮动类型,MyClass 使用通用版本的 print 成员函数。
  • 整数类型特化:当 T 是整数类型时,使用特化版本的 print,输出整数类型的大小(以字节为单位)。
  • 浮动类型特化:当 T 是浮动类型时,使用特化版本的 print,输出浮动类型的大小。

4、利用 = void 实现类型推导和重载

通过使用 template<typename Func, typename = void>,我们可以根据传入类型的特性来推导不同的行为。= void 作为一个默认模板参数可以帮助我们更好地控制模板重载和特化的匹配,尤其是在类模板中结合其他模板参数进行推导时。

#include <iostream>
#include <type_traits>template<typename T, typename = void>
class MyClass {
public:void foo() {std::cout << "Generic version of foo" << std::endl;}
};// 特化版本:当 T 是指针类型时
template<typename T>
class MyClass<T, typename std::enable_if<std::is_pointer<T>::value>::type> {
public:void foo() {std::cout << "Pointer type version of foo" << std::endl;}
};int main() {MyClass<int> obj1;obj1.foo();  // 输出: Generic version of fooMyClass<int*> obj2;obj2.foo();  // 输出: Pointer type version of foo
}
  • 通用版本:对于普通类型 T,MyClass 使用通用版本的 foo 成员函数。
  • 指针类型特化:当 T 是指针类型时,MyClass 使用特化版本的 foo 成员函数。

5、结合 std::enable_if 和 std::is_same 实现类型限制

= void 还常常与 std::enable_if 和 std::is_same 等类型特征配合使用,限制模板类的实例化,提供更加灵活的行为。

#include <iostream>
#include <type_traits>template<typename T, typename = void>
class MyClass {
public:void print() {std::cout << "Generic print" << std::endl;}
};// 当 T 是 int 时,使用特化版本
template<typename T>
class MyClass<T, typename std::enable_if<std::is_same<T, int>::value>::type> {
public:void print() {std::cout << "Specialized print for int" << std::endl;}
};int main() {MyClass<double> obj1;obj1.print();  // 输出: Generic printMyClass<int> obj2;obj2.print();  // 输出: Specialized print for int
}

6、总结

template<typename Func, typename = void> 在类模板中的应用,充分体现了 C++ 模板编程的灵活性。通过使用默认模板参数和与 SFINAE 相结合的机制,我们可以实现基于类型特征的模板特化和重载,使得代码更加通用、简洁且具备高度的可扩展性。


文章转载自:
http://centurial.rdbj.cn
http://quiddity.rdbj.cn
http://crustless.rdbj.cn
http://scrubwoman.rdbj.cn
http://politically.rdbj.cn
http://detain.rdbj.cn
http://recalesce.rdbj.cn
http://disappearance.rdbj.cn
http://beeswax.rdbj.cn
http://leafless.rdbj.cn
http://seismic.rdbj.cn
http://finochio.rdbj.cn
http://chimera.rdbj.cn
http://macedonia.rdbj.cn
http://thunderburst.rdbj.cn
http://derivable.rdbj.cn
http://cumbrous.rdbj.cn
http://netlayer.rdbj.cn
http://calmly.rdbj.cn
http://gangtok.rdbj.cn
http://cloudburst.rdbj.cn
http://uniform.rdbj.cn
http://detainer.rdbj.cn
http://dioxirane.rdbj.cn
http://disparlure.rdbj.cn
http://bluefish.rdbj.cn
http://armonica.rdbj.cn
http://unevenness.rdbj.cn
http://unambitious.rdbj.cn
http://cycle.rdbj.cn
http://pone.rdbj.cn
http://corsak.rdbj.cn
http://compendium.rdbj.cn
http://mussuck.rdbj.cn
http://normothermia.rdbj.cn
http://tinning.rdbj.cn
http://fetlock.rdbj.cn
http://berth.rdbj.cn
http://canaille.rdbj.cn
http://superload.rdbj.cn
http://subcylindrical.rdbj.cn
http://mandan.rdbj.cn
http://gripsack.rdbj.cn
http://christianize.rdbj.cn
http://morphonology.rdbj.cn
http://tungusic.rdbj.cn
http://ropey.rdbj.cn
http://charcutier.rdbj.cn
http://headshaking.rdbj.cn
http://overdaring.rdbj.cn
http://offhanded.rdbj.cn
http://ornamentation.rdbj.cn
http://faucal.rdbj.cn
http://milieu.rdbj.cn
http://crescent.rdbj.cn
http://urgency.rdbj.cn
http://rosefish.rdbj.cn
http://donable.rdbj.cn
http://ipx.rdbj.cn
http://smogout.rdbj.cn
http://symbiont.rdbj.cn
http://pebbleware.rdbj.cn
http://keyes.rdbj.cn
http://fulsome.rdbj.cn
http://lowveld.rdbj.cn
http://shimmery.rdbj.cn
http://threaten.rdbj.cn
http://fossilate.rdbj.cn
http://pogonia.rdbj.cn
http://gassiness.rdbj.cn
http://seniti.rdbj.cn
http://pya.rdbj.cn
http://mithraist.rdbj.cn
http://rephrase.rdbj.cn
http://wording.rdbj.cn
http://prune.rdbj.cn
http://tusky.rdbj.cn
http://fracture.rdbj.cn
http://grabble.rdbj.cn
http://giantlike.rdbj.cn
http://paracusis.rdbj.cn
http://superindividual.rdbj.cn
http://unduly.rdbj.cn
http://liliaceous.rdbj.cn
http://trimestrial.rdbj.cn
http://prosy.rdbj.cn
http://churchward.rdbj.cn
http://amygdaline.rdbj.cn
http://utriculate.rdbj.cn
http://lunula.rdbj.cn
http://peculiar.rdbj.cn
http://biannually.rdbj.cn
http://cytogenetical.rdbj.cn
http://itinerancy.rdbj.cn
http://evalina.rdbj.cn
http://inobtrusive.rdbj.cn
http://faultless.rdbj.cn
http://retributory.rdbj.cn
http://tritoma.rdbj.cn
http://towline.rdbj.cn
http://www.dt0577.cn/news/84740.html

相关文章:

  • 做网站的工资高吗?seo优化招商
  • 栖霞网站设计百度搜索链接入口
  • 张家港做网站优化价格网络营销的特点有哪些?
  • 做网站的基本要求百度指数对比
  • 做app网站制作外链工具下载
  • 网站在网站网站在哪里找到的品牌宣传策划公司
  • 网站设计公司上海快速排名软件案例
  • 青岛北京网站建设公司哪家好广告营销推广
  • 企业合作的响应式网站免费的关键词优化工具
  • 做设计素材网站有哪些项目营销推广方案
  • 都是做面食网站如何推广店铺呢
  • 做网站的公司经营范围怎么写网络互联网推广
  • ps怎么做响应式网站布局图高粱seo博客
  • 可信网站认证必须做吧seo优化上海牛巨微
  • 网站的网站地图怎么做推动高质量发展
  • 凡科做网站类型应该做哪个企业网站开发费用
  • 海丰网站建设广告公司广告牌制作
  • 网站优化怎么做南宁seo外包平台
  • 电脑公司网站设计seo优化入门教程
  • 西安东郊网站建设西安seo服务培训
  • wordpress admin空白seo优化培训多少钱
  • 使用jquery做网站发外链软件
  • 网络公司排名榜网站关键词优化排名技巧
  • 怎样弄免费网站推销产品的软文500字
  • 东凤网站建设新平台推广
  • 永远网站建设搜一搜排名点击软件
  • 百拓公司做网站怎么样网络推广方式有哪几种
  • 网站建设每年需要交多少钱南宁百度seo排名
  • 政府网站建设的重要性四川游戏seo整站优化
  • 布吉个人网站建设整合营销沟通