一、要求:
功能: 实现对一个8bit数据(unsigned char类型)的指定位(例如第n位)的置0或者置1操作,并保持其他位不变。
函数原型:void bit_set(unsigned char *p_data, unsigned char position, int flag)
函数参数说明:p_data是指定的原数据,position是指定位(取值范围1~8),flag表示置0还是置1操作
二、思路分析:
本题有两个操作:置0和置1
(1)置1:例如要将10的二进制位的第三位置为1,则
0000 1010 (10的二进制表示)
0000 0100
0000 1110 (第三位置1后的表示)
用第一个数与第二个数进行或运算,则可变为第三个数,即(0000 1010) | (0000 0100)结果为0000 1110。
那么中间第二个数怎么来的呢?它是用1左移要操作的位数减去1,即1左移position-1位得来的。
(2)置0:那么要将10的二进制位的第二位置为0,怎么办呢?
0000 1010
1111 1101
0000 1000(第二位置0后的表示)
用第一个数与第二个数做与运算,则可变为第三个数。
那么同样地,第二个数是怎么来的呢?显然直接移动得不到它,我们用1左移position-1位,然后再取反就能
得到它了。
三:代码实现:(编译器:vs2010 语言:c语言)
#include <>
#include <>
#include <>
void bit_set(unsigned char* p_data, unsigned char position, int flag)
{
assert(p_data);
assert(position >= 0 && position <=8);
if(flag == 1)
{
*p_data |= (1<<(position-1));
}
else if(flag == 0)
{
*p_data &= ~(1<<(position-1));
}
}
int main()
{
unsigned char c = 10; //0000 1010
bit_set(&c, 3 ,1);
printf("%d\n",c);
system("pause");
return 0;
}