- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试实现allocate_traits
,然后我尝试了很多方法,最后让它在gcc(>= 5)下运行良好,下面是一个判断的类>allocate_traits::construct
template <typename ...>
using type_helper = void;
template <typename T, typename... Args>
struct has_construct_helper {
template <typename Alloc, typename = type_helper<
decltype(declval<Alloc &>().construct
(declval<T *>(), declval<Args>()...))
>> static constexpr true_type test(Alloc, int);
template <typename Alloc> static constexpr false_type test(Alloc, ...);
};
template <typename Alloc, typename T, typename... Args>
using has_construct =
decltype(has_construct_helper<T, Args...>::test(declval<Alloc>(), 0));
我用一个不包含 construct
的分配器对其进行了测试,并且它与 gcc (>= 5) 配合得很好,但是 clang (>= 3.7) 给我 true
。此代码有效吗?
有一个完整的文件有同样的错误并且可能更简单: https://gist.github.com/anonymous/9a6125c4796d4c0227cb
最佳答案
问题出在您的 type_helper
别名模板上。对于如何处理未使用的可变参数模板参数,标准中曾经存在歧义。 Clang 决定不理会它们,因此您的 decltype
表达式实际上从未被检查过,因此 SFINAE 不会发生。
简单的解决方法是推迟到另一个特征,以便评估参数:
template <typename...> struct voider { using type = void; };
template <typename...Ts> using type_helper = typename voider<Ts...>::type;
这是您的代码的一个稍微简单的版本,它使用 SFINAE 的检测习惯用法。
template <typename...> struct voider { using type = void; };
template <typename...Ts> using void_t = typename voider<Ts...>::type;
template <typename Alloc, typename T, typename, typename... Args>
struct has_construct_helper : std::false_type{};
template <typename Alloc, typename T, typename... Args>
struct has_construct_helper<Alloc, T,
void_t<decltype(declval<Alloc &>().construct
(declval<T *>(), declval<Args>()...))>,
Args...> : std::true_type
{};
template <typename Alloc, typename T, typename... Args>
using has_construct = typename has_construct_helper<Alloc, T, void, Args...>::type;
template <typename Alloc, typename T, typename... Args>
void doConstruct(std::true_type, Alloc &a, T *p, Args&&... args)
{
a.construct(p, forward<Args>(args)...);
}
template <typename Alloc, typename T, typename... Args>
void doConstruct(std::false_type, Alloc &, T *p, Args&&... args)
{
::new (static_cast<void *>(p)) T(forward<Args>(args)...);
}
template <typename Alloc>
class allocator_traits {
public:
//...
template <typename T, typename... Args> static
void construct(Alloc &a, T *p, Args&&... args)
{
doConstruct(has_construct<Alloc,T,Args...>{}, a, p, forward<Args>(args)...);
}
//...
};
关于c++ - 为什么 `has_construct<Alloc, T, Args...>::value` 在 gcc (false) 和 clang (true) 上给出不同的值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34676716/
我有这个代码。为了让它工作,我必须使用 Args&&... 而不是 Args... 或 Args&... 我注意到 args 从 & 转换为 const& 或 && 转换为 &。 Args...Arg
当我定义类时,我总是去 Class A(object): def __init__(self, arg): self.arg = arg def print_arg(s
假设我想定义两个 {Type} 类的变量。构造函数采用 1 个参数。下面两种方式是否完全等价(编译成相同的目标代码)? Type a(arg), b(arg); 和 Type a(arg); Type
(旁白:我是一名 Perl 程序员,正如您所知,这是我的第一个重要的 Java 程序。简单的术语将不胜感激。) 我有以下启动器作为编码工作: import java.lang.reflect.*; i
Math.nextUp(arg) 始终与 arg + Math.ulp(arg) 相同,还是我遗漏了什么? System.out.println( 0.5 + Math.ulp(0.5));
今天我在学习完美转发,我创建了这个代码示例 #include #include template auto toStdFun(Function&& fun, Args&&...ar
我想知道你会选择哪个选项? putStrLn (show randomNum) putStrLn $ show randomNum (putStrLn . show) randomNum 所有选项在语
我试图在 visual studio 2012 中编译一个库,它最初是用 c++ 为 visual studio 2015 编写的。我有一个错误说 'class' missing tag。 错误消息的
我在下面的代码中遇到了运行时异常ArrayIndexOutOfBoundException,行中: if ( args[0].equals("t") || args[0].equals("time")
我有以下代码 import React, { Component } from "react"; import { Accounts } from "meteor/accounts-base"; ex
这个问题已经有答案了: Difference between Arrays and 3 dots (Varargs) in java (3 个回答) 已关闭 5 年前。 受学校线性代数 I 和 II
所以我定义了一个函数: def getDistnace(self, strings, parentD, nodeName, nodeDistance): 我用它来调用: Node.getDistnac
这个问题在这里已经有了答案: subprocess.call() arguments ignored when using shell=True w/ list [duplicate] (2 个答案
我想将参数传递给 java 应用程序,但喜欢 linux 应用程序风格。 java 中的main 方法对所有参数使用一个String 数组。在 Linux 中,大多数应用程序接受如下参数:ls -l
这是我的代码片段 #include void change(int a[]){ printf("%p\n",&a); } int main(){
我需要使用 python 3.6 subprocess.run() 函数发出以下命令: gsettings set org.gnome.shell enabled-extensions "['appl
这两个函数是否有任何有意义的不同?有什么理由通常更喜欢一个而不是另一个吗? void foo(auto x, auto &... y) { /* ... */ } template void foo(
例如: def m(arg, ...args) { println "arg: $arg" println "args: $args" } m('arg', k:'v') 输出: ar
我对 Java 还很陌生。目前正在尝试将 args[] 中给出的文件名传递给此 FileReader,但当我编译时,它说找不到指定的文件。如果我对文件名进行硬编码,它就可以正常工作。这应该如何运作?
为什么这是一个语法错误??做这件事的合适方法是什么? >>> def f(*args, option=None): File "", line 1 def f(*args, option=
我是一名优秀的程序员,十分优秀!