G++, clang++ and std::function
G++, clang++ and std::function
我只是在摆弄c++ 11中的新std::函数,我写了一个例子,可以用clang++ 3.2和Intel c++编译器13.1编译,但不能用g++ 4.8。在我将此报告为错误之前,我想我应该检查一下我没有做什么非常愚蠢的事情,并且应该实际编译。那么,下面的代码是有效的c++11吗?
template <typename C>
void map(C& c, std::function<typename C::value_type(typename C::value_type)> f)
{
for(auto& x : c) {
x = f(x);
}
}
int main()
{
std::vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
map(v, [](int x) { return x+2; });
for(auto x : v) {
std::cout << x << std::endl;
}
}
我意识到这段代码不是很有用,但它让我感到奇怪的是clang和Intel c++编译了它,而gcc没有。
EDIT: gcc也不会在向map传递函数函数或函数指针时编译相同的代码:
struct {
int operator() (int a) {
return a+2;
}
} add2s;
map(v, add2s);
int add2 (int a) {
return a+2;
}
map(v,add2);
clang和icpc也可以编译这两个文件
这是一个g++ bug,它可以简化为以下不使用std::function
(或来自标准库的任何东西)的示例:
template<typename T>
struct function
{
function(int)
{ }
};
struct V {
typedef int value_type;
};
template <typename C>
void map(C&, function<typename C::value_type>)
{
}
int main()
{
V v;
map(v, 1);
}
我已经向bugzilla报告了PR 56874。该问题与lambdas无关,而是与非推导上下文中的类型错误导致参数推导失败有关。
相关文章:
- 库函数需要一个 std::function<void(void)>,如何传入类函数?
- Confusion: decltype vs std::function
- 为什么 std::function 可以作为 std::not2 的参数?
- 'max'匹配'std::function<const int &(const int &, const int &)>'无过载
- 传递给std::function template的template参数究竟代表什么
- 将带有unique_ptr的可变 lambda 传递给 const&std::function
- 绑定派生类方法C++从实例范围之外的分隔 std::function 变量调用
- 如何在向量中删除 std::function<void()>?
- 将函数包装器转换为 std::function
- 类型擦除的std::function与虚拟函数调用的开销
- C++ std::function 对于类 exept 的所有实例都是空的(只有 Visual2019 编译器问题)
- 如果模板没有可变参数,则 Lambda 被推导出为 std::function
- 将 lambda 表达式传递给 std::function in C++
- 广义 std::function (std::any 表示可调用对象)
- std::function<std::optional<T>()> 如何与返回 T 的 lambda 兼容?
- std::function std::bind with lambda overload ambiguity
- Clang bug with std::function, std::bind and std::ref?
- 为什么我会收到编译错误"use of deleted function 'std::unique_ptr ..."
- 为什么我不能让 std::function<std::vector<T>::iterator> 绑定到返回该类型的 lambda?
- 回调(std::function/std::bind)与接口(抽象类)的优缺点