Package com.senseidb.indexing.activity

Source Code of com.senseidb.indexing.activity.RecentlyAddedUids

/**
* This software is licensed to you under the Apache License, Version 2.0 (the
* "Apache License").
*
* LinkedIn's contributions are made under the Apache License. If you contribute
* to the Software, the contributions will be deemed to have been made under the
* Apache License, unless you expressly indicate otherwise. Please do not make any
* contributions that would be inconsistent with the Apache License.
*
* You may obtain a copy of the Apache License at http://www.apache.org/licenses/LICENSE-2.0
* Unless required by applicable law or agreed to in writing, this software
* distributed under the Apache License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the Apache
* License for the specific language governing permissions and limitations for the
* software governed under the Apache License.
*
* © 2012 LinkedIn Corp. All Rights Reserved. 
*/
package com.senseidb.indexing.activity;

import java.util.BitSet;

import it.unimi.dsi.fastutil.longs.LongLinkedOpenHashSet;

public class RecentlyAddedUids {
  private final int capacity; 
  private LongLinkedOpenHashSet elems;
  public RecentlyAddedUids(int capacity) {
    this.capacity = capacity;
    elems = new LongLinkedOpenHashSet(capacity);
  }
 
  public synchronized void add(long uid) {
    if (elems.size() == capacity) {
      elems.remove(elems.firstLong());
    }
    elems.add(uid);
  }
  public synchronized int markRecentAsFoundInBitSet(long[] uids, BitSet found, int bitSetLength) {
    if (found.length() == 0) {
      return 0;
    }
    int ret = 0;
    int index = 0;
    while (true) {
      if (index < 0 || index >= bitSetLength) {
        break;
     
      index = found.nextClearBit(index);
      if (index < 0 || index >= bitSetLength) {
        break;
      }    
     
      if (elems.contains(uids[index])) {
      
        found.set(index);
        ret++;
      } else {
      }
      index++;
    }
    return ret;
  }
  protected synchronized void clear() {
    elems.clear();
  }
}
TOP

Related Classes of com.senseidb.indexing.activity.RecentlyAddedUids

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.