大数据量,海量数据 处理方法总结 来源: 葛林华的日志 大数据量的问题是很多面试笔试中经常出现的问题,比如baidu google 腾讯 这样的一些涉及到海量数据的公司经常会问到
下面的方法是我对海量数据的处理方法进行了一个一般性的总结,当然这些方法可能并不能完全覆盖所有的问题,但是这样的一些方法也基本可以处理绝大多数遇到的问题
下面的一些问题基本直接来源于公司的面试笔试题目,方法不一定最优,如果你有更好的处理方法,欢迎与我讨论
Bloom filter 适用范围:可以用来实现数据字典,进行数据的判重,或者集合求交集 基本原理及要点: 对 于原理来说很简单,位数组+k 个独立 hash 函数
将 hash 函数对应的值的位数组置 1,查找时如果发现所有 hash 函数对应位都是1 说明存在,很明显这 个过程并不保证查找的结果是100%正确的
同时也不支持删除一个已经插入的关键字,因为该关键字对应的位会牵动到其他的关键字
所以一个简单的改进就是 cou nting Bloom filter,用一个 cou nter 数组代替位数组,就可以支持删除了
还有一个比较重要的问题,如 何根据输入元素个数n,确定位数组 m 的大小及hash 函数个数
当 hash函数个数k=(ln2)*(m/n)时错误率最小
在错误率不大于 E 的情况 下,m 至少要等于 n*lg(1/E)才能表示任意 n 个元素的集合
但 m 还应该更大些,因为还要保证 bit 数组里至少一半为 0,则 m 应 该>=nlg(1/E)*lge 大概就是nlg(1/E)1
44 倍(lg 表示以 2 为底的对数)
举个例子我们假设错误率为 0
01,则此时 m 应大概是n 的13 倍
这样k 大概是8 个
注意这里 m 与 n 的单位不同,m 是bit为单位,而 n 则是以元素个数为单位(准确的说是不同