您的位置:首页 > 编程语言 > PHP开发

利用php数组实现Bitset位处理模块功能

2014-09-10 11:23 253 查看
接上篇,php的bitset模块介绍和安装

利用php的bitset模块可以实现c++的bitset相关功能。但是,在生产环境下需要给线上服务器安装模块是很危险和麻烦的事,所以需要另辟蹊径。

我用php的array数组模拟了bitset的几个主要方法的实现过程,其实就是利用Array的key模拟内存地址,value模地址内容。php的Array还是超级方便的 :)

<?php
define('CHAR_BIT', 8);
/**
* bitset操作php实现
* @version:1.0
* @author:Kenny{Kenny.F<mailto:kennyffly@gmail.com>}
* @since:2014/05/21
*/
class Bitset {

private $bitset_data = array();
private $_len = 0;

//分配位数组空间
function &bitset_empty($bit=0)
{
if(!is_numeric($bit) || $bit<0)
{
echo "argument must be a positive integer";
return False;
}
$this->_len = $bit;
return $this->bitset_data;
}

//位数组位置$bit上的值置为1
public function bitset_incl(&$bitset_data=array(), $bit=0)
{
if (!is_numeric($bit) || $bit<0)
{
echo "Second argument must be a positive integer";
return False;
}

$bitset_temp = isset($bitset_data[intval($bit/CHAR_BIT)]) ? $bitset_data[intval($bit/CHAR_BIT)] : 0;
$bitset_data[intval($bit/CHAR_BIT)]  = $bitset_temp | 1 << ($bit % CHAR_BIT);

unset($bitset_data);
}

//判断某个位置bit上的值是否为1
public function bitset_in($bitset_data=array(), $bit=0)
{
if (!is_array($bitset_data))
{
echo "first argument is not a array";
return False;
}

if ($bit < 0)
{
return False;
}
if ($this->_len == 0)
{
return False;
} elseif($bit >= $this->_len*CHAR_BIT){
return False;
} elseif ($bitset_data[intval($bit/CHAR_BIT)] & (1 << ($bit % CHAR_BIT))){
return True;
} else{
return False;
}
}

}


你可以查看我的github
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: