位运算(二):8bit数据指定位置0或置1操作

原创 2016年05月30日 14:58:46

一、要求:

       功能: 实现对一个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 <stdio.h>
#include <assert.h>
#include <stdlib.h>

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;
}


 

     

  

版权声明:本文为博主原创文章,未经博主允许不得转载。

C语言位运算详解

C语言位运算详解 位运算是指按二进制进行的运算。在系统软件中,常常需要处理二进制位的问题。C语言提供了6个位操作运算符。这些运算符只能用于整型操作数,即只能用于带符号或无符号的char,shor...
  • q775968375
  • q775968375
  • 2013年07月17日 16:44
  • 2309

【c语言】编写一个函数,这个函数可以将一个整数的指定位置1或置0

// 编写一个函数,这个函数可以将一个整数的指定位置1或置0 #include int set_bit(int a, int pos, int flag) { int b = 1 ...
  • zhaoyaqian552
  • zhaoyaqian552
  • 2015年06月30日 15:53
  • 1240

【C语言】编写函数,将一个数的指定位置置0或置1

//编写函数,将一个数的指定位置置0或置1 #include unsigned int set_bit(unsigned int num, int pos, int flag) { int n =...
  • doudouwa1234
  • doudouwa1234
  • 2015年06月30日 15:51
  • 2403

二进制数某一位置0或置1

某位置0: 按位& 1111110111……, 0的位置为想要置0的所在数的位置. 某位置1: 按位|  0000001000……, 1的位置为想要置1的所在数的位置....
  • u013397785
  • u013397785
  • 2016年07月28日 12:38
  • 1559

数据结构-位运算的使用

位运算:直接对整数在内存中的二进位进行操作的运算位运算包括与,或,非,异或,同或,移位等,位运算是最接近机器码的运算,在算法当中使用位运算会带来很大的便利注:java十进制转二进制:Integer.t...
  • qq_26971803
  • qq_26971803
  • 2016年04月19日 13:06
  • 1785

二分查找位运算——32位整数中寻找第一个为1的位

问题描述 在程序设计中经常会遇到这样一个问题,即在一个32位整数中,从右到左寻找第一个为1的位。这样的问题是很常见的,而面对这样一个问题,一种常见的解法就是逐位的遍历这个整数中的所有位,直到...
  • syzcch
  • syzcch
  • 2012年12月13日 09:47
  • 3273

C语言位操作中的置0和置1

     C语言中,有时需要进行置位操作,比如针对其中的某些位。这样做的目的是既达到了目标,又不会影响其它位。常用的置位操作如下:#define   setbit(x,y)    x|=(1...
  • zhandoushi1982
  • zhandoushi1982
  • 2011年01月11日 23:03
  • 8553

异或--和1与--和0或(保留某位-给某位取反-置0-置1)

在设置windows窗体样式的时候经常需要把某个位置1,方法如下: (1)和00100或,因为一个位和0或保留原值  【目前只有这一种方法】 如果把某个位置零,比如把中间位即第三位置零(共5位),...
  • WaitForFree
  • WaitForFree
  • 2013年06月04日 21:08
  • 1758

位运算——数0的个数

最简单的方法 移位来运算:N>>=1;然后用N 同1进行“与”运算,来判断末尾是否为1 下面有更快的方法; 快速的方法:判断某一位置是否是1的一个方法,v&=(v-1); 最经典: ‍ ...
  • zhhx2001
  • zhhx2001
  • 2016年05月07日 12:17
  • 737

实现一个对8bit数据指定某一位置0或1

#include void bit_set(unsigned char *p_date, unsigned char position, int flag) { if (flag == 1) {...
  • yangrujing
  • yangrujing
  • 2015年06月08日 23:24
  • 1497
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:位运算(二):8bit数据指定位置0或置1操作
举报原因:
原因补充:

(最多只允许输入30个字)