- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在尝试学习当前接受的 c++11 功能,但我在使用 auto 和 decltype 时遇到了问题。作为学习练习,我正在使用一些通用函数扩展 std 类列表。
template<class _Ty, class _Ax = allocator<_Ty>>
class FList : public std::list<_Ty, _Ax>
{
public:
void iter(const function<void (_Ty)>& f)
{
for_each(begin(), end(), f);
}
auto map(const function<float (_Ty)>& f) -> FList<float>*
{
auto temp = new FList<float>();
for (auto i = begin(); i != end(); i++)
temp->push_back(f(*i));
return temp;
}
};
auto *ints = new FList<int>();
ints->push_back(2);
ints->iter([](int i) { cout << i; });
auto *floats = ints->map([](int i) { return (float)i; });
floats->iter([](float i) { cout << i; });
对于成员映射,我希望返回类型是通用的,具体取决于传递的函数返回的内容。所以对于返回类型,我可以做这样的事情。
auto map(const function<float (_Ty)>& f) -> FList<decltype(f(_Ty))>*
这也需要去掉函数模板中的float类型。
auto map(const function<auto (_Ty)>& f) -> FList<decltype(f(_Ty))>*
我可以使用模板类,但这会使实例的使用更加冗长,因为我必须指定返回类型。
template<class T> FList<T>* map(const function<T (_Ty)>& f)
总而言之,我想弄清楚如何在不使用模板类的情况下定义 map ,并且在它返回的类型中仍然具有通用性。
最佳答案
不鼓励从 std::list
或其他 std::
容器派生。
将您的操作编写为自由函数,以便它们可以通过迭代器在任何标准容器上工作。
你的意思是“不使用模板函数定义 map ”吗?
您应该能够使用 std::function
的 result_type
成员类型来获取它返回的类型。
您也没有必要指定该函数作为 std::function
传递。您可以将其作为任何类型打开,并让编译器将所有内容连接起来。对于运行时多态性,您只需要 std::function
。
使用 new 创建原始堆分配对象并通过指针返回它们是 1992 年的事! :)
您的 iter 函数本质上与 range-based for loop 相同.
但是除此之外......你是说这样的意思吗?
template <class TFunc>
auto map(const TFunc &f) -> FList<decltype(f(_Ty()))>*
{
auto temp = new FList<decltype(f(_Ty()))>();
for (auto i = begin(); i != end(); i++)
temp->push_back(f(*i));
return temp;
}
这将匹配任何可调用的对象,并将使用 decltype 确定函数的返回类型。
请注意,它要求 _Ty 是默认可构造的。您可以通过制造一个实例来解决这个问题:
template <class T>
T make_instance();
不需要实现,因为没有生成调用它的代码,所以链接器没有什么可提示的(感谢 dribeas 指出了这一点!)
所以现在的代码变成了:
FList<decltype(f(make_instance<_Ty>()))>*
或者,从字面上看,通过引用 _Ty 的实例调用函数 f 将得到的任何类型的列表。
作为接受的免费奖励,查找右值引用 - 这些意味着您可以写:
std::list<C> make_list_somehow()
{
std::list<C> result;
// blah...
return result;
}
然后这样调用它:
std::list<C> l(make_list_somehow());
因为 std::list 将有一个“移动构造函数”(就像一个复制构造函数,但是当参数是临时的时被选择,就像这里一样),它可以窃取返回值的内容,即做与最优交换
。所以没有复制整个列表。 (这就是为什么 C++0x 会让天真编写的现有代码运行得更快——许多流行但丑陋的性能技巧将变得过时)。
并且您可以通过使用 unique_ptr
为您自己的任何现有类免费获得相同类型的东西,而无需编写正确的移动构造函数。
std::unique_ptr<MyThing> myThing(make_my_thing_somehow());
关于c++ - 在 C++11 中使用 auto 和 decltype,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1094046/
这个问题在这里已经有了答案: Range based loop: get item by value or reference to const? (5 个答案) 关闭 6 年前。 如果我有这样的类
最近,我使用 CSS grid 创建了一个布局.虽然这很好用,但我对它的工作原理感到困惑。具体来说,我对 grid-template-rows: auto auto 1fr auto; 这一行感到困惑
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Why don't margin-top: auto and margin-bottom:auto work
我几乎已经尝试了所有我知道的方法,但是当我将我的 Android studio 更新到最新版本时,它仍然显示此错误。我该怎么办? gradle.build 是: buildscript { r
我想创建一个deep_flatten函数模板,该模板将生成包含range ed的元素的join。例如,如果仅考虑嵌套的std::vector,我可以拥有: template struct is_ve
我刚刚看了 Scott Meyers Universal References in C++11有一件事我不太明白。 我对作为“通用引用”的 auto 之间的区别感到有点困惑,即 auto&& 和常规
这个问题在这里已经有了答案: C++11 Range-based for-loop efficiency "const auto &i" versus "auto i" (3 个答案) 关闭 3 年
由于 auto 关键字在编译时获取类类型,我想知道使用 auto* 是否有任何效率,或者是否有任何特殊用途该表达式,因为 auto 在编译时已经获得了指针类型。 最佳答案 这个“新奇的 C++11”与
请问我是否正确,对函数返回值使用 auto&& 总是比使用 auto 更好。例如,在 auto val = someObj.getVal(); 如果 getVal() 返回引用,则 val 将是一个拷
有区别吗: template constexpr decltype(auto) f(T&& x) -> decltype(std::get(std::forward(x))) { retur
我想创建一个 deep_flatten会产生 range 的函数模板深的元素join编。例如,如果我们只考虑嵌套 std::vector s,我可以有: template struct is_vec
我在玩auto在 std::pair .在下面的代码中,函数 f应该返回 std::pair依赖于模板参数的类型。 一个工作示例: 示例 1 template auto f() { if c
我是一名 Android 开发人员,我正在尝试开发一个定制的 Android Auto 应用程序,它可以简单地镜像手机屏幕。 我知道目前 API 仅适用于音乐和消息应用程序,但我会编写一个应用程序来镜
我有一个很大的 div,里面有文字: #big-div { height: 400px; overflow: auto; } 如何才能使当新内容添加到 div(并发生溢出)时,div
我正在尝试设计一个网站,其中包含一个带有溢出的内容区域:自动和一个动态高度。最好是,我希望能够在 overflow: auto div 下方放置一个页眉和一个页脚,并让该 div 占用剩余的空间,但到
这个问题在这里已经有了答案: Does 'auto' type assignments of a pointer in c++11 require '*'? (3 个答案) 关闭 6 年前。 以下在
当使用 auto&& 处理返回左值的函数时: int func() { int v=42; return v; } auto && v = func(); 将 v 视为引用而不是左值会产生
我读了一篇关于 auto 类型推导的文章,使用 decltype 我想知道我在下面的例子中关于如何推导类型的逻辑是否正确(所以如果我是有误请指正:) #include using namespace
这个问题在这里已经有了答案: What's the semantically accurate position for the ampersand in C++ references (3 个回答)
假设我有 class Container { public: T getValue() const { return t; } const T& getCRef() const {
我是一名优秀的程序员,十分优秀!