小编Pra*_*nay的帖子

Java Lambda 对单个流的多个操作

场景:我有一个具有 2 个函数的对象 -->

<Integer> getA(); <Integer> getB();
Run Code Online (Sandbox Code Playgroud)

我有一个对象列表,比如说List<MyObject> myObject

目标迭代列表并获得对象列表中 A 和 B 的总和。

我的解决方案

myObject.stream().map(a -> a.getA()).collect(Collectors.summingDouble());

myObject.stream().map(a -> a.getB()).collect(Collectors.summingDouble());
Run Code Online (Sandbox Code Playgroud)

问题:我怎样才能同时做到这两点?这样我就不必在原始列表上迭代两次。

@Edit:我这样做是因为我使用的一些过滤器是 O(n^3)。做两次真的很糟糕。

基准:当程序在 i5 上运行半小时时,它是 T 还是 2T 真的很重要。这是基于更少的数据,如果我在集群上运行,我的数据也会更大。

如果您可以在一行中完成这些,那很重要!

java lambda

5
推荐指数
1
解决办法
1639
查看次数

为什么当我不移动任何东西时,clang会抱怨删除的移动?

前提:

#include <iostream>
using namespace std;

class ABC {
 public:

   ABC() {
     cout << "Default constructor ..\n";
   }

   ABC(const ABC& a) {
     cout << "In copy constrcutor ..\n";
   }
   ABC(ABC&& aa) = delete;
};

int main(int argc, char* argv[]) {
  ABC b{ABC{}};
  return 0;
}
Run Code Online (Sandbox Code Playgroud)

用GCC vs Clang编译它

Clang - Apple LLVM version 8.1.0 (clang-802.0.42)

Gcc - 5.4.0 ubuntu

观察 Clang抱怨删除了Move构造函数.

Gcc完全不抱怨.并将正确输出.

问题为什么?

对于gcc,我知道如果你只是初始化lvalue和rvalue,它会优化并且实际上不会调用复制构造函数并将临时值复制到左值.

为什么Clang有所不同?我认为(不确定,因此问题)这是在C++标准中,哪一个偏离(或不)?或者我做错了什么.

编译命令:g++ --std=c++11 -O3 file.cpp

为了更多的乐趣,删除花括号,并添加括号;)

ABC b{ABC{}};to,ABC b(ABC());与此问题无关. …

c++ clang gcc-warning move-constructor move-semantics

3
推荐指数
1
解决办法
194
查看次数