PHP中使用BigMap实例

 这篇文章主要介绍了PHP中使用BigMap实例,本文直接给出实现代码,代码中包含详细注释,需要的朋友可以参考下

 
 

?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87

<?php
//所谓的Bit-map就是用一个bit位来标记某个元素对应的Value, 而Key即是该元素。由于采用了Bit为单位来存储数据,因此在存储空间方面,可以大大节省。
 
/*
 
若 N =1 ; 申请内存空间为 int a[2] ;
假设需要排序或者查找的总数N=10000000,那么我们需要申请内存空间的大小为int a[1 + N/32],其中:a[0]在内存中占32为可以对应十进制数0-31,依次类推:
 
1.求十进制0-N对应在数组a中的下标: n/32
 
2.求0-N对应0-31中的数: N%32=M
 
3.利用移位0-31使得对应32bit位为1: 1<<M,并置1;
 
举例 :
 
如果想存储 3
(1) a下标 30/ 32 = 0 ; 放在a[0] 中;
(2) 3% 32 = 30;
(3) 左移 30 位 01000000 00000000 00000000 00000000 这个对应的值$a[0] = 1073741824 ;
 
 
1.求十进制0-N对应在数组a中的下标:
十进制0-31,对应在a[0]中,先由十进制数n转换为与32的余可转化为对应在数组a中的下标。比如n=24,那么 n/32=0,则24对应在数组a中的下标为0。又比如n=60,那么n/32=1,则60对应在数组a中的下标为1,同理可以计算0-N在数组a中的下标。
 
2.求0-N对应0-31中的数:
 
十进制0-31就对应0-31,而32-63则对应也是0-31,即给定一个数n可以通过模32求得对应0-31中的数。
 
3.利用移位0-31使得对应32bit位为1.
 
找到对应0-31的数为M, 左移M位:即2^M. 然后置1.
 
由此我们计算10000000个bit占用的空间:
 
1byte = 8bit
 
1kb = 1024byte
 
1mb = 1024kb
占用的空间为:10000000/8/1024/1024mb。
 
大概为1mb多一些。
 
*/
 
class bigMap {
//使用两个字节保存
private $mask = 0x1f ;
private $bitsperword = 32 ;
// 移位的位数为5 pow(2,5) = 32
private $shift = 5 ;
// 存储数据的数组
public $bitArray = array();
 
/**
$i 对应的数归零
*/
function clearbit($i){
////则将当前byte中的指定bit位取0,&后其他对方数组bit位必然不变,这就是 1 的妙用
// $i>>SHIFT 这里相当于 intval($i /32) ;
// $i & $this->mask 这里相当于 $i % $this->mask ,取余
@$this->bitArray[$i >> $this->shift] &= ~(1<<($i & $this->mask));
}
 
/**
$i 对应的数致1
*/
function setbit($i){
@$this->bitArray[$i >> $this->shift] |= (1<<($i & $this->mask));
}
 
//test 测试所在的bit为是否为1
function testbit($i){
return $this->bitArray[$i >> $this->shift] & (1<<($i & $this->mask));
}
}
 
 
$oBig = new bigMap() ;
 
$oBig->setbit(30) ;
 
var_dump($oBig->testbit(2)) ;
var_dump($oBig->bitArray) ;  

时间: 2024-12-03 02:33:37

PHP中使用BigMap实例的相关文章

PHP中使用BigMap实例_php技巧

<?php //所谓的Bit-map就是用一个bit位来标记某个元素对应的Value, 而Key即是该元素.由于采用了Bit为单位来存储数据,因此在存储空间方面,可以大大节省. /* 若 N =1 ; 申请内存空间为 int a[2] ; 假设需要排序或者查找的总数N=10000000,那么我们需要申请内存空间的大小为int a[1 + N/32],其中:a[0]在内存中占32为可以对应十进制数0-31,依次类推: 1.求十进制0-N对应在数组a中的下标: n/32 2.求0-N对应0-31中的

不定参数在C语言中的应用实例

不定参数在C语言中的应用实例:不定参数当年做为C/C++语言一个特长被很多人推崇,但是实际上这种技术并没有应用很多.除了格式化输出之外,我实在没看到多少应用.主要原因是这种技术比较麻烦,副作用也比较多,而一般情况下重载函数也足以替换它.尽管如此,既然大家对它比较感兴趣,我就简单总结一下它的使用和需要注意的常见问题. 刚学C语言的时候,一般人都会首先接触printf函数.通过这个函数,你可以打印不定个数的变量到屏幕,如: printf("%d", 3): printf("%d,

php中memcache 基本操作实例

  本文实例讲述了PHP中Memcache的基本操作及用法.分享给大家供大家参考.有需要的小伙伴快来研究下吧. php中memcache 基本操作实例 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 <!DOCTYPE html> <html> <head&g

python中as用法实例分析

  这篇文章主要介绍了python中as用法,实例分析了as的功能及相关使用技巧,非常具有实用价值,需要的朋友可以参考下 本文实例讲述了python中as用法.分享给大家供大家参考.具体分析如下: ? 1 import some # some 为一个模组 如果想要改变被导入模组在当前模组中的名称,而不是sys.modules中的名称.可以使用import as,例如: ? 1 2 import some as other print(other.name) 和 ? 1 2 3 4 import

C#中矩阵运算方法实例分析

  C#中矩阵运算方法实例分析         这篇文章主要介绍了C#中矩阵运算方法,实例分析了通过C#实现矩阵的初始化.转置矩阵.求逆矩阵等各种常用的操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下 本文实例讲述了C#中矩阵运算方法.分享给大家供大家参考.具体分析如下: 一.测试环境: 主机:XP 开发环境:VS2008 二.功能: 在C#中实现矩阵运算 三.源代码: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23

Javascript中innerHTML用法实例分析

 这篇文章主要介绍了Javascript中innerHTML用法,实例分析了实用innerHTML获取对应元素内容的使用技巧,需要的朋友可以参考下     本文实例讲述了Javascript中innerHTML用法.分享给大家供大家参考. 具体实现方法如下:   代码如下: <html> <head> <script type="text/javascript"> function t(){ var cont = document.getElemen

nodejs中实现阻塞实例

 这篇文章主要介绍了nodejs中实现阻塞实例,本文直接给出实例代码,需要的朋友可以参考下     node.js中与生俱来的单线程编程.回调函数异步式风格让我们有时喜有时忧.先说单线程,很多人会费解于node.js的单线程如何能做到高并发?这个问题不是本文重点,点到为止.澄清一点,node.js的单线程仅仅指javascript引擎是单线程的,无论如何我们没有办法在javascript中实现多线程和阻塞(本文用到的方法同样不是通过V8引擎实现同步的):但对于node.js的其他方面不代表不能多

jQuery中animate用法实例分析

 这篇文章主要介绍了jQuery中animate用法,实例分析了animate的使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下     本文实例讲述了jQuery中animate用法.分享给大家供大家参考.具体如下: 这是一个简单的animate函数尝试.代码如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 <script type="text/javascript"> $(document).ready

jQuery中noConflict()用法实例分析

 这篇文章主要介绍了jQuery中noConflict()用法,实例分析了noConflict()的功能.定义及相关使用技巧,需要的朋友可以参考下     本文实例讲述了jQuery中noConflict()用法.分享给大家供大家参考.具体分析如下: jQuery默认使用"$"操作符,$ 符号只是 window.jQuery 对象的一个引用,jQuery.noConflict() ,这个函数将变量$的控制权让渡给第一个实现它的那个库.这有助于确保jQuery不会与其他库的$对象发生冲突