我用X10写了一个规范的"Hello,World“演示类:
class Hello {
public static def main(args:Rail[String]):void {
finish for (p in Place.places()) {
at (p) async Console.OUT.println(here+" says hello");
}
Console.OUT.println("Goodbye");
}
}我的计算机有一个双核CPU,但是X10代码不能识别两个处理核心。据我所知,它只能识别CPU的一个核心。因此,控制台的输出如下所示:
Place(0) says hello
Goodbye而不是
Place(0) says hello
Place(1) says hello
Goodbye正如它可能预期的那样。
如何强制X10代码识别我笔记本电脑上可用的CPU的所有处理核心?我的笔记本电脑配备了英特尔酷睿2双核CPU。操作系统为Windows 7。
提前谢谢你。
发布于 2014-07-06 02:13:04
默认情况下,无论有多少物理核心可用,X10都将只启动一个位置。(实际上,根据您的应用程序,对于每个多核CPU,最好在一个地方运行一个地方,并使用async在一个地方利用多线程并行性。
要请求不同数量的位置,请设置环境变量X10_NPLACES或使用x10启动器的-np选项。
X10_NPLACES=2 x10 Hello
x10 -np 2 Hellohttps://stackoverflow.com/questions/24234014
复制相似问题