立志做一个佳娃~ 2015-07-03 04:00 采纳率: 0%
浏览 1737

forkjointask类的invokeAll(t1,t2)方法请教

各位前辈,
看了网址:
http://www.molotang.com/articles/706.html
但有一些问题需要请教一下:
public class MyRecursiveTask extends RecursiveTask {
@Override
protected String compute() {
this.invokeAll(t1, t2)
return null;
}
}
当我使用具有返回值RecursiveTask的类时,方法invokeAll(t1, t2)并没有处理返回值,是否代表invokeAll(t1,t2)方法只适用于RecursiveAction无返回值的情况?(问题1)
如果只适用于RecursiveAction无返回值的情况那我的清楚了,
如果不是只适用于RecursiveAction无返回值的情况,还适用于RecursiveTask的情况时,那invokeAll(t1,t2)如何处理返回值呢?(问题2)
难道要这样写吗?(问题3)伪代码如下:
public class MyRecursiveTask extends RecursiveTask {
@Override
protected String compute() {
MyRecursiveTask t1Left = new MyRecursiveTask();
MyRecursiveTask t2Right = new MyRecursiveTask();
this.invokeAll(t1Left, t2Right);
String returnString = t1Left.join() + " " + t2Right.join();
return returnString;
}
}

如果像上面这样写的话,您说这种情况影响效率,那这样写可以吗?(问题4)如下面
public class MyRecursiveTask extends RecursiveTask {
@Override
protected String compute() {
MyRecursiveTask t1Left = new MyRecursiveTask();
MyRecursiveTask t2Right = new MyRecursiveTask();
this.invokeAll(t1Left, t2Right);
//right移到前面
String returnString = t2Right.join() + " " + t1Left.join();
return returnString;
}
}

那如果这样写的话,如果是t2Right影响效率怎么办呢,有这种可能,或情况出现吗?(问题5)如果t2Right影响了效率,那什么样的写法是完全不影响效率的呢?(问题6)
如果文章用代码再案例化t1Left.join() + " " + t2Right.join();一下影响效率的时间比较差别就更好了,可惜没有看到啊,请教大家了!

  • 写回答

1条回答

  • devmiao 2015-07-18 07:07
    关注

    递归调用肯定是有性能的开销的,最好不要递归。

    评论

报告相同问题?

悬赏问题

  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛