用bis和bic实现位级操作
20世纪70年代末至80年代末,DigitalEquipment的VAX计算机是一种非常流行的机型。它没有布尔运算AND和OR指令,仅仅有bis(位设置)和bic(位清除)这两种指令。两种指令的输入都是一个数据字x和一个掩码字m。
他们生成一个结果z。z是有依据掩码m的位来改动x的位得到的。使用bis指令。能够在m为1的每一个位置上,将z相应的位置设为1。
使用bic指令。能够在m为1的每一个位置上,将z相应的位置设为0。
为了弄清bis和bic运算与C语言位级运算的关系,如果我们有两个函数bis和bic来实现位设置和位清除操作。仅仅想用这两个函数,而不使用不论什么其它C语言运算,来实现按位|和^运算,即或运算和异或运算。
示比例如以下:
/*定义两个运算函数*/
int bis(intx, int m);
intbic(int x, int m);
/*或运算的实现*/
intbool_or(int x, int y){
int result = _______;
return result;
}
/*异或运算的实现*/int
bool_xor(int x, int y){
int result = ______;
return result;
}
首先来看或(OR)运算的实现。先简单分析下bis运算的功能:
由给出的规则。能够得出例如以下演示样例:
bis([1001],[0110])= [1111];
bis([01010101],[10011011])=[11011111];
能够得出。对于掩码m中为1的位,不管x为0或1。结果均为1,对于掩码m中位0的位,结果保持为x的值。即x为1时。结果为1,x为0时。结果为0。
这个与C语言中位级运算的或运算非常相似。所以或运算相应的结果即bis(x,y);
异或运算的结果有些复杂,先来看一下其它的稍简单的几个位级运算。
位取反运算(~)
假设要对x取反。需将0置为1,1置为0。bic函数当掩码为1时,可将结果该位置0,当掩码为0时,保持x值置结果该位。所以能够把x作为掩码,把全高位值0xFFFF作为bic函数的第一个參数。就可以对x取反。取反运算的函数能够表演示样例如以下:
int bool_not(int x){
int result =bic(0xFFFF,x);
//此处讨论的为16位机
return result;
}
与运算(AND)
由布尔代数可知:x&
y = ~(~x | ~y),所以由刚得出的取反运算函数。可得出与运算的函数:
int bool_and(int x, int y){
int result =bic(0xFFFF,bis(bic(0xFFFF,x),bic(0xFFFF, y));
return result;
}
以下探讨下位异或运算(XOR):
异或运算,仅仅有当两个位不同一时候。结果才为1。
用1位数位能够表示成例如以下演示样例:
0^0= 0
0^1 = 1
1^0 = 1
1^1 = 0
相同用1位数位表示最简单的bis和bic函数。能够得出以下8个公式。这对于后面的分析非常实用:
bis(0,0)= 0
bis(0,1)= 1
bis(1,0) = 1
bis(1,1)= 1
bic(0,0) = 0
bic(0,1)= 0
bic(1,0) = 1
bic(1,1)= 0
注意上面标红的几个式子,恰好能够被我们利用:
对于bis函数。当两个位不同一时候,结果为1。而bic函数却取决于掩码的数值。对于bic函数,当两个位同样时。结果为0。所以能够得出以下几个式子:
bis(bic(0,1),bic(1,0))=bis(0,1)=1
bis(bic(1,0),bic(0,1))= bis(1,0)= 1
bis(bic(0,0),bic(0,0))= bis(0,0)= 0
bis(bic(1,1),bic(1,1))= bis(0,0)= 0
这就是对于(0,1)、(1,0)、(0,0)和(1,1)四对数位的异或运算结果。所以异或运算可写成例如以下形式:
int bool_xor(int x, int y){
int result =bis(bic(x,y),bic(y,x));
return result;
}
用bis和bic实现位级操作的更多相关文章
- bis和bic命令实现或和异或运算
从20世纪70年代末到80年代末,Digital Equipment的VAX计算机是一种非常流行的机型.它没有布尔运算AND和OR指令,只有bis(位设置)和bic(位清除)这两种指令.两种指令的输入 ...
- STM32之GPIO端口位带操作
#ifndef __SYS_H #define __SYS_H #include "stm32f10x.h" //位带操作 //把“位带地址+位序号”转换别名地址宏 #define ...
- Matlab位运算操作
本文为转载他人文章: bitand 按位与操作 a = 7; b = bitand(10,a); disp(dec2bin(a,8)); %ans = 00000111 disp(dec2bin(b, ...
- STM32位带操作总结---浅显易懂
正在准备做毕业设计,配置LED_Config()的时候,又看到了位带操作的宏定义,我又嘀咕了,什么是位带操作,一年前在使用位带操作的时候,就查阅过好多资料,Core-M3也看过,但是对于博主这种“低能 ...
- STM32F030系列实现仿位带操作
1.闲言 最近开发的时候,用到了STM32F030F4P6型号的单片机,它只有20个引脚,价格非常便宜,但是功能齐全:定时器.外部中断.串口.IIC.SPI.DMA和WWDG等等,应用尽有,非常适合用 ...
- 第13章 GPIO—位带操作
第13章 GPIO—位带操作 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/fire ...
- 玩转X-CTR100 l STM32F4 l 基础例程printf、LED、蜂鸣器、拨码开关、位带操作
我造轮子,你造车,创客一起造起来!塔克创新资讯[塔克社区 www.xtark.cn ][塔克博客 www.cnblogs.com/xtark/ ] 本文介绍X-CTR100控制器基础板载资源 ...
- 玩转X-CTR100 | STM32F4 l GPIO位带操作
更多塔克创新资讯欢迎登陆[塔克社区 www.xtark.cn ][塔克博客 www.cnblogs.com/xtark/ ] STM32F4位带概念,及位带的GPIO操作实践应用. 原理介 ...
- 关于STM32位带操作随笔
以前在学习STM32时候关注过STM32的位带操作,那时候只是知道位带是啥,用来干嘛用,说句心里话,并没有深入去学习,知其然而不知其所以然.但一直在心中存在疑惑,故今日便仔细看了一下,写下心得供日后参 ...
随机推荐
- ajax 实现订单商品数量的增减及订单的删除进行异步更新界面
[转载]https://blog.csdn.net/luliuying_01/article/details/78177617?locationNum=8&fps=1 由于在做答辩项目,做到购 ...
- CSS3---渲染属性
1.计数器 CSS3计数器( CSS Counters )可以允许我们使用css对页面中的任意元素进行计数,实现类似于有序列表的功能.与有序列表相比,它的突出特性在于可以对任意元素计数,同时实现个性化 ...
- 搭建Mysql主从复制
mysql 主从复制流程图 Server version: 10.0.24-MariaDB-7 Ubuntu 16.04 Master 记录二进制文件 导出数据并记录二进制位置 导入数据,设置二进制位 ...
- Python数据可视化库-Matplotlib(二)
我们接着上次的继续讲解,先讲一个概念,叫子图的概念. 我们先看一下这段代码 import matplotlib.pyplot as plt fig = plt.figure() ax1 = fig.a ...
- JQuery给元素动态增删类或特性
背景:通过JQuery动态给Html元素增加.删除类或属性,使Html元素在不同的时刻呈现不同的样式,给用户更好的体验感觉. 如存在以下p片段和button按钮,代码如下: <p id=&quo ...
- 【Ajax 1】Ajax与传统Web开发的区别
导读:从用户体验度的角度来说,利用Ajax进行开发的网站,其体验度高于利用传统Web开发技术,那么,是什么因素导致了这一现象呢?难道说Ajax开发,就一定优于传统Web技术吗?本篇文章,将主要介绍Aj ...
- PHP建立和删除目录
<?php/*linux中的文件权限filedir 用户 组 其它 rwx rwx rwx 读写执行 6 4 6 读写 读 读写 7 7 7 rw_ r__ rw_ r__ _w_ ___ r ...
- react.js 渲染一个列表的实例
//引入模块 import React,{Component} from 'react'; import ReactDOM from 'react-dom'; //定义一个要渲染的数组 let use ...
- 最长递增子序列 (LIS) Longest Increasing Subsequence
问题描述: 有一个长为n的数列a0, a1,..., an-1.请求出这个序列中最长的上升子序列.请求出这个序列中最长的上升子序列. 上升子序列:对于任意i<j都满足ai<aj的子序列. ...
- [NOIP2002] 提高组 洛谷P1031 均分纸牌
题目描述 有 N 堆纸牌,编号分别为 1,2,…, N.每堆上有若干张,但纸牌总数必为 N 的倍数.可以在任一堆上取若于张纸牌,然后移动. 移牌规则为:在编号为 1 堆上取的纸牌,只能移到编号为 2 ...