- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在尝试使用 hadoop 找到任何给定点的总和,我遇到的问题是从单个 reducer 中的给定键获取所有值。看起来像这样。
reducer :
public static class Reduce extends MapReduceBase implements
Reducer<Text, IntWritable, Text, DoubleWritable> {
public void reduce(Text key, Iterator<IntWritable> values,
OutputCollector<Text, DoubleWritable> output, Reporter reporter)
throws IOException {
Text word = new Text();
Iterator<IntWritable> tr = values;
IntWritable v;
while (tr.hasNext()) {
v = tr.next();
Iterator<IntWritable> td = values;
while (td.hasNext()) {
IntWritable u = td.next();
double sum = u+v;
word.set( u + " + " + v);
output.collect(word, new DoubleWritable(sum));
}
}
}
}
我正在尝试创建 Iterator 变量的两个副本,以便我可以遍历第二个迭代器的所有值,同时从前一个迭代器获取单个值(上面的两个 while 循环)但是两个迭代器持有始终具有相同的值。
我不确定这样做是否正确。
最佳答案
reducer 中的迭代器并不像你想象的那么简单。
问题是您正在迭代的项目总数可能不适合内存。这意味着迭代器可能正在从磁盘读取。如果您有两个独立的迭代器副本,那么您可以让其中一个远远领先于另一个,这意味着不能删除两个迭代器指向的位置之间的数据。
为了简化实现,Hadoop 不支持为 reduce 值使用多个迭代器。
这样做的实际影响是您不能通过同一个迭代器两次。这不好,但事实就是如此。如果您绝对知道项目的数量将适合内存,那么您可以按照 MrGomez 的建议将所有项目复制到列表中。如果您不知道,您可能不得不使用辅助存储。
更好的方法是重新设计您的程序,这样您就不需要在 reducer 中无限存储。这可能有点棘手,但有解决该问题的标准方法。
对于您的特定问题,输出大小相对于最大归约输入集呈二次增长。这通常是一个非常糟糕的主意。在大多数情况下,您不需要所有对,只需要最重要的对。如果您可以通过某种方式修剪成对集合,那么您就万事大吉了,您也许可以移除所有成对约束。
例如,如果您试图为每个归约集找到具有最大总和的 100 对,您可以保留一个优先级队列,其中包含迄今为止看到的 100 个最大输入和一个具有迄今为止看到的 100 个最大总和的优先级队列.对于每个新输入,您可以用迄今为止看到的最大 100 个数字形成总和,并尝试将这些总和放入第二个队列。最后,您应该将新输入放入第一个队列,并通过删除最小值(如有必要)将两个队列修剪为 100 个元素。在 reduce 的关闭方法中,您应该转储优先级队列。这种方法保证您只需要 min(n^2, 200) 个存储元素,从而避免了 n^2 问题,并通过保留 100 个最大的项目而不是所有项目来避免重复输入。
关于hadoop - 在 mapreduce 中操作迭代器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3481914/
我之前让 dll 注入(inject)器变得简单,但我有 Windows 7,我用 C# 和 C++ 做了它,它工作得很好!但是现在当我在 Windows 8 中尝试相同的代码时,它似乎没有以正确的方
我正在尝试制作一个名为 core-splitter 的元素,该元素在 1.0 中已弃用,因为它在我们的项目中起着关键作用。 如果您不知道 core-splitter 的作用,我可以提供一个简短的描述。
我有几个不同的蜘蛛,想一次运行所有它们。基于 this和 this ,我可以在同一个进程中运行多个蜘蛛。但是,我不知道如何设计一个信号系统来在所有蜘蛛都完成后停止 react 器。 我试过了: cra
有没有办法在达到特定条件时停止扭曲 react 器。例如,如果一个变量被设置为某个值,那么 react 器应该停止吗? 最佳答案 理想情况下,您不会将变量设置为一个值并停止 react 器,而是调用
https://code.angularjs.org/1.0.0rc9/angular-1.0.0rc9.js 上面的链接定义了外部js文件,我不知道Angular-1.0.0rc9.js的注入(in
我正在尝试运行一个函数并将服务注入(inject)其中。我认为这可以使用 $injector 轻松完成.所以我尝试了以下(简化示例): angular.injector().invoke( [ "$q
在 google Guice 中,我可以使用函数 createInjector 创建基于多个模块的注入(inject)器。 因为我使用 GWT.create 在 GoogleGin 中实例化注入(in
我在 ASP.NET Core 1.1 解决方案中使用配置绑定(bind)。基本上,我在“ConfigureServices Startup”部分中有一些用于绑定(bind)的简单代码,如下所示: s
我在 Spring MVC 中设置 initBinder 时遇到一些问题。我有一个 ModelAttribute,它有一个有时会显示的字段。 public class Model { privat
我正在尝试通过jquery post发布knockoutjs View 模型 var $form = $('#barcodeTemplate form'); var data = ko.toJS(vm
如何为包含多态对象集合的复杂模型编写自定义模型绑定(bind)程序? 我有下一个模型结构: public class CustomAttributeValueViewModel { publi
您好,我正在尝试实现我在 this article 中找到的扩展方法对于简单的注入(inject)器,因为它不支持开箱即用的特定构造函数的注册。 根据这篇文章,我需要用一个假的委托(delegate)
你好,我想自动注册我的依赖项。 我现在拥有的是: public interface IRepository where T : class public interface IFolderReposi
我正在使用 Jasmine 测试一些 Angular.js 代码。为此,我需要一个 Angular 注入(inject)器: var injector = angular.injector(['ng'
我正在使用 Matlab 代码生成器。不可能包含代码风格指南。这就是为什么我正在寻找一个工具来“ reshape ”、重命名和重新格式化生成的代码,根据我的: 功能横幅约定 文件横幅约定 命名约定 等
这个问题在这里已经有了答案: Where and why do I have to put the "template" and "typename" keywords? (8 个答案) 关闭 8
我开发了一种工具,可以更改某些程序的外观。为此,我需要在某些进程中注入(inject)一个 dll。 现在我基本上使用这个 approach .问题通常是人们无法注入(inject) dll,因为他们
我想使用 swing、spring 和 hibernate 编写一个 java 应用程序。 我想使用数据绑定(bind)器用 bean 的值填充 gui,并且我还希望它反射(reflect) gui
我有这段代码,当两个蜘蛛完成后,程序仍在运行。 #!C:\Python27\python.exe from twisted.internet import reactor from scrapy.cr
要点是 Spring Batch (v2) 测试框架具有带有 @Autowired 注释的 JobLauncherTestUtils.setJob。我们的测试套件有多个 Job 类提供者。因为这个类不
我是一名优秀的程序员,十分优秀!