从上一篇文章我们知道了,在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)