TLSF算法2:位图的相关计算


从上一篇文章我们知道了,在TLSF算法分配内存时,给定一个所需大小r,怎么计算出相关的二级位图的索引fl和sl,在具体讲TLSF的结构之前,我们先讲一下在有关位图操作的一些算法。主要包括32位数的最小非零位和最大非零位,和将一个32位数的某一位置0或者置1,这一共四个操作。

一、最大非零位

这个原理和上一篇文章中将到的求fl的算法一样,通过对半查找之后再采用空间换时间的方式直接在一个数组中查找出相关值就可以了。代码参考如下:

int GetMaxOBit(int n) {
   
	int a;
	a = n <= 0xffff ? (n <= 0xff ? 0 : 8) : (n <= 0xffffff ? 16 : 24);
	return TLSF_Table[n >> a] + a;
}

二、最小非零位

求一个数最小非零位的原理需要用到原码,补码,反码的知识,为了简单描述,假设是个一字节的数。为数字18为例,其二进制原码表示为“00010010”,记为a,为了表示-18,首先得出18的不包含符号位的反码是“1101101”,然后对其加1并添加上符号位,得出“11101110”,记为b,我们可以观察a和b的值,发现从低位开始直到第一个1是是相同的,其他的位都是相反的。所以实际上计算a&b,就得出值“00000010”,也就是说,将求一个数的最低非零位,就转变为了求其最高非零位。当然,也可以使用移位判断的方式求得最低有效位,但是显然,在嵌入式系统中,还是需要可以知道代码的确定执行时间的。代码参考如下:

int GetMinBit(int n) {
   
	int a = (int)n & (int)(-n);
	return GetMaxOBit(a)
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值