- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
使用非并发数据结构源流的非干扰要求是否意味着我们不能在流管道执行期间更改数据结构的元素状态(除此之外我们不能改变源数据结构本身)? (问题一)
在关于 non-interference 的部分,在流包描述中,它说:“对于大多数数据源而言,防止干扰意味着确保数据源在流管道执行期间根本不被修改。”
这段话没有提到修改元素的状态?
例如,假设“shapes”是非线程安全集合(例如ArrayList
),下面的代码是否被认为有干扰? (问题二)
shapes.stream()
.filter(s -> s.getColor() == BLUE)
.forEach(s -> s.setColor(RED));
这个例子取自 reliable source (至少可以说),所以它应该是正确的。但是,如果我将 stream()
更改为 parallelStream()
,它仍然是安全和正确的吗? (问题三)
另一方面,另一可靠来源Naftalin Maurice的“Mastering Lambdas”明确指出,通过管道操作改变元素的状态(值)确实是干扰。来自关于不干扰的部分(3.2.3):
“但流的规则禁止任何线程对流源进行任何修改,例如,包括更改元素的值,而不仅仅是管道操作。”
如果书中所说的是正确的,是否意味着我们不能使用 Stream API 来修改元素的状态(使用 forEach
),而必须使用常规迭代器(或 for-each,或 Iterable.forEach
)? (问题四)
最佳答案
有一类更大的函数叫做“有副作用的函数”。 JavaDoc 声明是正确和完整的:这里的干扰意味着修改可变源。另一种情况是有状态表达式:依赖于应用程序状态或更改此状态的表达式。您可以阅读 Parallelism Oracle 站点上的教程。
一般来说,你可以自己修改流元素,这不应该被称为“干扰”。请注意,如果流源多次生成相同的可变对象(例如,使用 Collections.nCopies(10, new MyMutableObject()).parallelStream()
。虽然它确保相同流元素不会被多个线程同时处理,如果您的流两次生成相同的元素,您在 forEach
中修改它时肯定会遇到竞争条件,例如。
因此,虽然有状态表达式有时会产生异味,如果有无状态的替代方案,应谨慎使用并避免使用,但如果它们不干扰流源,则它们可能没问题。当需要无状态表达式时(例如,在 Stream.map
方法中),API 文档中会特别提及。在 forEach
文档中,只需要不干涉。
回到你的问题:
问题1:不可以改变元素状态,这不叫干扰(虽然叫statefullness)
问题 2:不,除非您的流源中有重复对象,否则它没有干扰)
问题 3:您可以在那里安全地使用 parallelStream()
问题4:不可以,这种情况下可以使用Stream API。
关于java - Java 8 流中的非干扰确切含义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32837415/
这个问题在这里已经有了答案: Towards the "true" definition of JAVA_HOME (5 个答案) 关闭 4 年前。 为什么 ActiveMQ 提供者需要设置 JAV
这个问题在这里已经有了答案: What is a lambda expression in C++11? (10 个答案) 关闭 8 年前。 这是来自 boosts asio 的一个例子。这是什么意
这个问题在这里已经有了答案: What does the double colon (::) mean in CSS? (3 个答案) 关闭 7 年前。 我经常看到这种用法。特别是伪类。“::”在
嗨,另一个愚蠢的简单问题。我注意到在Apple框架中的某些typedef中使用符号"<<"谁能告诉我这是什么意思?: enum { UIViewAutoresizingNone
someObject.$() 是什么意思? 我正在浏览 sapui5 工具包中的 tilecontainer-dbg 文件,发现了这个: var oDomRef = this.$(); or some
这个问题已经有答案了: How to interpret function parameters in software and language documentation? (4 个回答) 已关闭
我遇到过这个语法。任何人都可以解释一下 getArg1ListInfo:()=>(object.freeze(arg1)) 的含义 function foo (arg1,arg2) { let
对于子类,我有以下代码: class child1 : public parent { public: static parent* function1(void) { ret
这个问题在这里已经有了答案: What does "|=" mean? (pipe equal operator) (6 个答案) 关闭 1 年前。 我有一部分代码包含以下功能: void Keyb
以下在 C++ 中是什么意思? typedef PComplex RComplex [100]; 请注意,PComplex 是我代码中的用户定义类型。 谢谢 最佳答案 RComplex 是 PComp
在我的 Lisp 代码中,我有函数 (nfa-regex-compile),它创建一个包含初始状态、转换和最终状态的 cons 列表(表示自动机的节点)从作为参数给出的正则表达式开始。 在这种情况下,
以下文字摘自 Learning Spark 第 3 章 One issue to watch out for when passing functions is inadvertently seria
PHP 文档 block 中以下内容的含义是什么: #@+ zend框架代码中的一个例子: /**#@+ * @const string Version constant numbers */ c
由于 python 的一些版本控制问题,我必须使用自定义函数来比较 HMAC (SHA512)。为此,我找到了这个函数: def compare_digest(x, y): if not (i
取自this answer here : static const qi::rule node = '{' >> *node >> '}' | +~qi::char_("{}"); 请注意,声明了名称
我正在查看 chi 包的文档。我看到类似的东西: https://github.com/pressly/chi/blob/master/_examples/rest/main.go#L154 data
我想知道如果我采用值为 8 的 INT,这是否意味着我只能从 1 到 99999999 或从 1 到 4294967295 UNSIGNED? 最佳答案 文档似乎很清楚这一点: Numeric Typ
我想知道如果我采用值为 8 的 INT,这是否意味着我只能从 1 到 99999999 或从 1 到 4294967295 UNSIGNED? 最佳答案 文档似乎很清楚这一点: Numeric Typ
这个问题在这里已经有了答案: 关闭9年前。 Possible Duplicate: Does “/* (non-javadoc)” have a well-understood meaning? 以下
在 Prolog 代码中,可以使用“ headless ”Horn 子句将指令传递给编译器,这些子句与指向左侧的物质蕴涵 ':-' (⇐) 的左侧没有头部关系。例如,导入模块或声明 Unit Test
我是一名优秀的程序员,十分优秀!