模板特化是指程序员为特定类型生成的模板显式特化。
考虑以下类模板。 模板 类型名称 T> 类实体{ // 某物 }; 显式专门化 Entity 的正确语法是什么: 由你, 由 T (
给定一个函数作为模板参数传递给函数,我如何确定它的第一个参数的类型? 例如: 模板 void run_func(/* 参数类型??...
下面我有两个单独的模板类层次结构(Account -> CheckingAccount 和 Logger -> ConsoleLogger)和一个使用这两个层次结构的模板 Bank 类。 目标是使用不同的记录器,...
C++:类成员函数的模板特化,与其他成员函数的区别仅在于通过引用接受参数,而不是通过值接受参数
在模板类 Bank 中,我的目标是为类型 Account 创建一个重载到成员函数 void Bank::makeTransfer(T, T, const double),签名为 void Bank::
首先,我正在做的事情似乎适用于所有 GCC/Clang/MSVC/icc/etc,所以我的问题是;这是偶然的还是标准要求允许的? 从某种意义上说,这似乎是合乎逻辑的
通过 using 别名显式专门化 C++ 模板类应该有效吗?
首先,我正在做的事情似乎适用于所有 GCC/Clang/MSVC,所以我的问题是;这是偶然的还是标准要求允许的? 从某种意义上说,这似乎是一种合乎逻辑的延伸……
我有一个通用模板类,我不想(无法)更改它 模板 类打印机{ 民众: bool Write(std::ostream& ostr, const TData& data) const {...
#include“向量” 模板 结构返回类型; 模板<> 结构体返回类型<0> { 使用类型=双精度; // 值的返回类型 }; 模板 &l...
在 C++14 中是否可能(因此没有约束、require 或折叠表达式,但有 SFINAE)对类模板进行部分模板特化 模板 基因类...
我想检查是否存在某种模板专门化,其中未定义一般情况。 鉴于: 模板 结构 A; // 通用定义未定义 圣殿...
在这种情况下,模板特化在 C++20 中是如何工作的: #包括 模板 void AFuncToTest() { std::cout << "it fails!" <&l...
当我遇到一些我不明白的东西时,我在代码中使用转发引用。 示例代码 为了说明这一现象,我写了这个场景的简化版本: #包括...
作为上一个问题的后续:给定一个任意容器,推导出相关类型的容器类型,其中@marek-r建议创建模板专业化,例如: 模板 作为上一个问题的后续:给出任意容器,推导相关类型的容器类型,其中@marek-r建议创建模板专业化,例如: template<template<typename> typename Wrapper, typename Container> struct repack; template<template<typename> typename Wrapper, typename ValueT, std::size_t N> struct repack<Wrapper, std::array<ValueT, N>> { using type = std::array<Wrapper<ValueT>, N>; }; template<template<typename> typename Wrapper, typename ValueT> struct repack<Wrapper, std::vector<ValueT>> { using type = std::vector<Wrapper<ValueT>>; }; template<template<typename> typename Wrapper, typename Key, typename Value> struct repack<Wrapper, std::map<Key, Value>> { using type = std::map<Wrapper<Key>, Wrapper<Value>>; }; 或链接:https://godbolt.org/z/naz9v48vb 通过尝试使其更通用,我用模板化模板参数交换了 vector 和 map,并通过检查 value_type 是否与 pair<const key_type, mapped_type> 相同: 使用 c++20 约束分派每个解决方案 template<template<typename> typename Wrapper, template<typename, typename> typename Mapped_Container, typename Key, typename Value> requires std::is_same_v< typename Mapped_Container<Key, Value>::value_type, std::pair<const typename Mapped_Container<Key, Value>::key_type, typename Mapped_Container<Key, Value>::mapped_type>> struct repack<Wrapper, Mapped_Container<Key, Value>> { using type = Mapped_Container<Wrapper<Key>, Wrapper<Value>>; }; template<template<typename> typename Wrapper, template<typename> typename Unmapped_Container, typename Value> struct repack<Wrapper, Unmapped_Container<Value>> { using type = Unmapped_Container<Wrapper<Value>>; }; 但是这个解决方案似乎只能在 gcc 中编译,在 clang 和 msvc 中失败:https://godbolt.org/z/zzY7WvoEd clang 会报告错误:“隐式实例化未定义模板”,而 msvc 似乎无法专门化别名模板。 我在这里遗漏了什么,还是我遇到了编译器扩展? 如果类型repack也定义了C,则可以重新实现mapped_type类型特征,以便选择第二部分特化。假设类型特征仅与标准容器一起使用,这足以保证为关联容器选择专门化。 可以通过SFINAE或requires-clause添加约束。在这种情况下,首选前者与 C++11 标准兼容。 示例: namespace detail { template <template <typename> typename, typename, typename = void> struct repack {}; template <template <typename> typename Wrapper, template <typename...> typename C, typename T> struct repack<Wrapper, C<T>> { using type = C<Wrapper<T>>; }; template <template <typename> typename Wrapper, template <typename...> typename C, typename T, typename U> struct repack<Wrapper, C<T, U>, std::void_t<typename C<T, U>::mapped_type>> { using type = C<Wrapper<T>, Wrapper<U>>; }; } template <template <typename> typename Wrapper, typename C> struct repack : detail::repack<Wrapper, C> {}; template <template <typename> typename Wrapper, typename C> using repack_t = typename repack<Wrapper, C>::type;
为什么分离`std::formatter`专业化的接口和实现会导致约束失败?
我试图将 std::formatter 专门用于基本自定义类型 Vector3D,但收到编译器错误。这是一个最小的可重现示例: vector.h 定义了 Vector3D 类...
在 C++20 中,而不是这样做 size_t 计数 = 42; std::vector my_vector; vec.reserve(计数); std::copy_n(std::istream_iterator(std::cin), count, std::back_inserter(vec)); 我想...
带有值模板参数的 C++ 类模板专业化 - 如何优先选择其中一个?
我有以下代码: 模板 结构组合; 模板 类型名称 Tpl,类型名称... Ts,类型名称... Us> 结构组合< Tpl<...
变量“val”声明中存在 C++ 无关的“template<>”
我正在尝试元编程,以便可以在编译时计算阶乘。这是第一个版本: 模板 结构体 Fac { 静态常量 int val; }; 模板<> 结构Fa...
我正在尝试实现一个具有可以处理不同类型的静态成员函数的类模板。我的代码如下所示(非常简单的示例): #包括 结构体 Foo { 特...
我正在尝试实现一个具有可以处理不同类型的静态成员函数的类模板。我的代码如下所示(非常简单的示例): #包括 结构体 Foo { 你...
删除了模板类构造函数,但有一个专门化与 clang 和 gcc 的行为不同
我正在尝试理解这种行为。 我创建了一个模板类,其中删除了构造函数,然后将其专门用于 int 类型。我的目标是仅为 int 创建实例(