位图排序之bitMap实现

 位图排序通常用在特定的大数据量的场景下,如对给定的20亿条整形数据进行排序,要求使用的内存不能超过265M。此时我们可以采用位存储的方式来对数据进行排序。

2000000000/8/1024/1024<256M
首先,申请一个20亿的bit数组,然后读取20亿的数据,找到当前读取的整数所在的bit的位置,将其置1,直到所有的数据都读完。

第二,遍历bit数组,如果当前位置的bit位为1,则将下标输出到文件,否则判断下一个是否为1。

public class BitMap {
	public static void main(String[] args) {
		BitMap bitMap = new BitMap(2000000000);
		bitMap.set(100);
		System.out.println(bitMap.test(100));
		System.out.println(bitMap.test(101));
		System.out.println(bitMap.test(0));

	}

	byte[] bytes;

	public BitMap(int length) {
		int size = (length >>> 3) + 1;
		bytes = new byte[size];
	}

	private int getIndex(int index) {
		return index >>> 3;
	}

	private int getOffset(int index) {
		return index & 7;
	}

	public void set(int index) {
		bytes[getIndex(index)] = (byte) (bytes[getIndex(index)] | (1 << getOffset(index)));
	}

	public boolean test(int index) {
		return (bytes[getIndex(index)] & (1 << getOffset(index))) != 0;
	}

}

猜你喜欢

转载自blog.csdn.net/qq_28044241/article/details/81778443