时间:2021-05-26
<?php//所谓的Bit-map就是用一个bit位来标记某个元素对应的Value, 而Key即是该元素。由于采用了Bit为单位来存储数据,因此在存储空间方面,可以大大节省。 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) ; echo decbin($oBig->bitArray[0]),"<br>";
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了PHP中STDCLASS用法。分享给大家供大家参考,具体如下:PHP中STDCLASS在我们开发应用中使用到的不多,但是PHP中STDCLASS作
本文实例讲述了PHP缓存工具XCache安装与使用方法。分享给大家供大家参考,具体如下:XCache是另外一种在PHP中使用的Opcode缓存工具。像APC一样
本文实例讲述了php中使用baseHTTP验证的方法。分享给大家供大家参考。具体如下:functionhttp_auth($un,$pw,$realm="Sec
本文实例讲述了php中使用key,value,current,next和prev函数遍历数组的方法。分享给大家供大家参考。具体分析如下:php中针对数组遍历有一
本文实例讲述了php实现在新浪云中使用imagick生成缩略图并上传的方法。分享给大家供大家参考,具体如下:imagick是一款php的图像处理插件了我们可以使