當前位置: 首頁>>代碼示例>>Java>>正文


Java LongWritable.set方法代碼示例

本文整理匯總了Java中org.apache.hadoop.io.LongWritable.set方法的典型用法代碼示例。如果您正苦於以下問題:Java LongWritable.set方法的具體用法?Java LongWritable.set怎麽用?Java LongWritable.set使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.hadoop.io.LongWritable的用法示例。


在下文中一共展示了LongWritable.set方法的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: writeInStoreHour

import org.apache.hadoop.io.LongWritable; //導入方法依賴的package包/類
private void writeInStoreHour() throws IOException, InterruptedException{

        KeyWrapper cycleKey = new KeyWrapper();
        cycleKey.setType(new Text(MapKeyConfig.IN_STORE_HOUR));

        LongWritable longWritable = new LongWritable();
        cycleKey.setMillisTime(longWritable);

        IntWritable value = new IntWritable(1);


        List<Long> inStoreHours = statistic.getInStoreHours();
        for (Long inStoreTime : inStoreHours) {
            longWritable.set(IntervalCalculator.getInStoreInterval(inStoreTime));
            context.write(cycleKey, new ValueWrapper(value));
        }
    }
 
開發者ID:cuiods,項目名稱:WIFIProbe,代碼行數:18,代碼來源:MapperWriter.java

示例2: reduce

import org.apache.hadoop.io.LongWritable; //導入方法依賴的package包/類
public void reduce(LongWritable key, Iterator<Text> values,
                   OutputCollector<LongWritable, Text> output,
                   Reporter reporter) throws IOException {
  while (values.hasNext()) {
    Text value = values.next();
    writeFlag(conf, "reduce." + name + ".value." + value);
    key.set(10);
    output.collect(key, value);
    if (byValue) {
      assertEquals(10, key.get());
    } else {
      assertNotSame(10, key.get());
    }
    key.set(11);
  }
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:17,代碼來源:TestChainMapReduce.java

示例3: next

import org.apache.hadoop.io.LongWritable; //導入方法依賴的package包/類
private boolean next(LongWritable key, Text value) throws IOException {
    /**
     *  通過readUntilMatch方法查找xml段開始的標簽,直到找到了,才開始
     *  寫xml片段到buffer中去,如readUntilMatch的第二個參數為false則不查找的過
     *  程中寫入數據到buffer,如果為true的話就邊查找邊寫入
     */
    if( fsin.getPos() < end && readUntilMatch(startTag, false)) {
        //進入代碼段則說明找到了開始標簽,現在fsin的指針指在找到的開始標簽的
        //最後一位上,所以向buffer中寫入開始標簽
        buffer.write(startTag);
        try {
            /**
             * 在fsin中去查找結束標簽邊查找邊記錄直到找到結束標簽為止
             */
            if(readUntilMatch(endTag, true)) {
                /**
                 * 找到標簽後把start標簽的指針位置的偏移量賦值給key
                 * 把buffer中記錄的整個xml完整片斷賦值給value
                 */
                key.set(fsin.getPos() - buffer.getLength());
                value.set(buffer.getData(), 0, buffer.getLength());
                return true;
            }
        } finally {
            buffer.reset();
        }
    }
    return false;
}
 
開發者ID:lzmhhh123,項目名稱:Wikipedia-Index,代碼行數:30,代碼來源:XmlInputFormat.java

示例4: write

import org.apache.hadoop.io.LongWritable; //導入方法依賴的package包/類
public void write(DataOutput dataOutput) throws IOException {
    Text text = new Text(wifiProb==null?"":wifiProb);
    text.write(dataOutput);

    LongWritable longWritable = new LongWritable();
    longWritable.set(hour);
    longWritable.write(dataOutput);
    longWritable.set(newCustomer);
    longWritable.write(dataOutput);
    longWritable.set(oldCustomer);
    longWritable.write(dataOutput);

}
 
開發者ID:cuiods,項目名稱:WIFIProbe,代碼行數:14,代碼來源:NewOldCustomElement.java

示例5: writNewOldCustomer

import org.apache.hadoop.io.LongWritable; //導入方法依賴的package包/類
private void writNewOldCustomer() throws IOException, InterruptedException {

        KeyWrapper newOldKey = new KeyWrapper();
        newOldKey.setType(new Text(MapKeyConfig.NEW_OLD_CUSTOMER));

        LongWritable longWritable = new LongWritable();
        newOldKey.setMillisTime(longWritable);

        for (NewOldCustomElement newOldCustomElement : statistic.getNewOldCustomElements()) {
            longWritable.set(newOldCustomElement.getHour());
            context.write(newOldKey, new ValueWrapper(newOldCustomElement));
        }
    }
 
開發者ID:cuiods,項目名稱:WIFIProbe,代碼行數:14,代碼來源:MapperWriter.java

示例6: writCustomerFlow

import org.apache.hadoop.io.LongWritable; //導入方法依賴的package包/類
private void writCustomerFlow() throws IOException, InterruptedException{

        KeyWrapper customerFlowKey = new KeyWrapper();
        customerFlowKey.setType(new Text(MapKeyConfig.CUSTOMER_FLOW_KEY));

        LongWritable longWritable = new LongWritable();
        customerFlowKey.setMillisTime(longWritable);

        for (CustomerFlowElement customerFlowElement:statistic.getCustomerFlowElements()) {
            longWritable.set(customerFlowElement.getHour());
            context.write(customerFlowKey, new ValueWrapper(customerFlowElement));
        }
    }
 
開發者ID:cuiods,項目名稱:WIFIProbe,代碼行數:14,代碼來源:MapperWriter.java

示例7: writeCycle

import org.apache.hadoop.io.LongWritable; //導入方法依賴的package包/類
private void writeCycle() throws IOException, InterruptedException{

        KeyWrapper cycleKey = new KeyWrapper();
        cycleKey.setType(new Text(MapKeyConfig.CYCLE));

        LongWritable longWritable = new LongWritable();
        cycleKey.setMillisTime(longWritable);

        IntWritable value = new IntWritable(1);

        for (Long cycle : statistic.getCycles()) {
            longWritable.set(IntervalCalculator.getCycleInterval(cycle));
            context.write(cycleKey, new ValueWrapper(value));
        }
    }
 
開發者ID:cuiods,項目名稱:WIFIProbe,代碼行數:16,代碼來源:MapperWriter.java

示例8: getRecordReader

import org.apache.hadoop.io.LongWritable; //導入方法依賴的package包/類
public RecordReader<LongWritable, Text> getRecordReader(
    InputSplit ignored, JobConf conf, Reporter reporter) throws IOException {

  return new RecordReader<LongWritable, Text>() {

    boolean sentOneRecord = false;

    public boolean next(LongWritable key, Text value)
        throws IOException {
      key.set(1);
      value.set("dummy");
      if (sentOneRecord == false) { // first call
        sentOneRecord = true;
        return true;
      }
      return false; // we have sent one record - we are done
    }

    public LongWritable createKey() {
      return new LongWritable();
    }
    public Text createValue() {
      return new Text();
    }
    public long getPos() throws IOException {
      return 1;
    }
    public void close() throws IOException {
    }
    public float getProgress() throws IOException {
      return 1;
    }
  };
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:35,代碼來源:LoadGeneratorMR.java

示例9: map

import org.apache.hadoop.io.LongWritable; //導入方法依賴的package包/類
public void map(LongWritable key, Text value,
                OutputCollector<LongWritable, Text> output,
                Reporter reporter) throws IOException {
  writeFlag(conf, "map." + name + ".value." + value);
  key.set(10);
  output.collect(key, value);
  if (byValue) {
    assertEquals(10, key.get());
  } else {
    assertNotSame(10, key.get());
  }
  key.set(11);
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:14,代碼來源:TestChainMapReduce.java

示例10: next

import org.apache.hadoop.io.LongWritable; //導入方法依賴的package包/類
@Override
public synchronized boolean next(LongWritable key, BytesWritable value)
    throws IOException {
  boolean dataRead = reader.nextKeyValue();
  if (dataRead) {
    LongWritable newKey = reader.getCurrentKey();
    BytesWritable newValue = reader.getCurrentValue();
    key.set(newKey.get());
    value.set(newValue);
  }
  return dataRead;
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:13,代碼來源:FixedLengthRecordReader.java

示例11: next

import org.apache.hadoop.io.LongWritable; //導入方法依賴的package包/類
/** Read a line. */
public synchronized boolean next(LongWritable key, Text value)
  throws IOException {

  // We always read one extra line, which lies outside the upper
  // split limit i.e. (end - 1)
  while (getFilePosition() <= end || in.needAdditionalRecordAfterSplit()) {
    key.set(pos);

    int newSize = 0;
    if (pos == 0) {
      newSize = skipUtfByteOrderMark(value);
    } else {
      newSize = in.readLine(value, maxLineLength, maxBytesToConsume(pos));
      pos += newSize;
    }

    if (newSize == 0) {
      return false;
    }
    if (newSize < maxLineLength) {
      return true;
    }

    // line too long. try again
    LOG.info("Skipped line of size " + newSize + " at pos " + (pos - newSize));
  }

  return false;
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:31,代碼來源:LineRecordReader.java

示例12: transferToFully

import org.apache.hadoop.io.LongWritable; //導入方法依賴的package包/類
/**
 * Transfers data from FileChannel using 
 * {@link FileChannel#transferTo(long, long, WritableByteChannel)}.
 * Updates <code>waitForWritableTime</code> and <code>transferToTime</code>
 * with the time spent blocked on the network and the time spent transferring
 * data from disk to network respectively.
 * 
 * Similar to readFully(), this waits till requested amount of 
 * data is transfered.
 * 
 * @param fileCh FileChannel to transfer data from.
 * @param position position within the channel where the transfer begins
 * @param count number of bytes to transfer.
 * @param waitForWritableTime nanoseconds spent waiting for the socket 
 *        to become writable
 * @param transferTime nanoseconds spent transferring data
 * 
 * @throws EOFException 
 *         If end of input file is reached before requested number of 
 *         bytes are transfered.
 *
 * @throws SocketTimeoutException 
 *         If this channel blocks transfer longer than timeout for 
 *         this stream.
 *          
 * @throws IOException Includes any exception thrown by 
 *         {@link FileChannel#transferTo(long, long, WritableByteChannel)}. 
 */
public void transferToFully(FileChannel fileCh, long position, int count,
    LongWritable waitForWritableTime,
    LongWritable transferToTime) throws IOException {
  long waitTime = 0;
  long transferTime = 0;
  while (count > 0) {
    /* 
     * Ideally we should wait after transferTo returns 0. But because of
     * a bug in JRE on Linux (http://bugs.sun.com/view_bug.do?bug_id=5103988),
     * which throws an exception instead of returning 0, we wait for the
     * channel to be writable before writing to it. If you ever see 
     * IOException with message "Resource temporarily unavailable" 
     * thrown here, please let us know.
     * 
     * Once we move to JAVA SE 7, wait should be moved to correct place.
     */
    long start = System.nanoTime();
    waitForWritable();
    long wait = System.nanoTime();

    int nTransfered = (int) fileCh.transferTo(position, count, getChannel());
    
    if (nTransfered == 0) {
      //check if end of file is reached.
      if (position >= fileCh.size()) {
        throw new EOFException("EOF Reached. file size is " + fileCh.size() + 
                               " and " + count + " more bytes left to be " +
                               "transfered.");
      }
      //otherwise assume the socket is full.
      //waitForWritable(); // see comment above.
    } else if (nTransfered < 0) {
      throw new IOException("Unexpected return of " + nTransfered + 
                            " from transferTo()");
    } else {
      position += nTransfered;
      count -= nTransfered;
    }
    long transfer = System.nanoTime();
    waitTime += wait - start;
    transferTime += transfer - wait;
  }
  
  if (waitForWritableTime != null) {
    waitForWritableTime.set(waitTime);
  }
  if (transferToTime != null) {
    transferToTime.set(transferTime);
  }
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:79,代碼來源:SocketOutputStream.java

示例13: writeLong

import org.apache.hadoop.io.LongWritable; //導入方法依賴的package包/類
/** write the long value */
static void writeLong(long value, DataOutputStream out) throws IOException {
  LongWritable uLong = TL_DATA.get().U_LONG;
  uLong.set(value);
  uLong.write(out);
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:7,代碼來源:FSImageSerialization.java


注:本文中的org.apache.hadoop.io.LongWritable.set方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。