delphi.位操作
位操作网上有很多介绍,请上网google/baidu,比如:
http://blog.csdn.net/g_spider/article/details/5750665
http://blog.csdn.net/morewindows/article/details/7354571
。。。
位操作C/C++或Delphi/pascal,其实都类似,只不过语言表达方式不同而已。
位操作 c/c++ delphi/pascal
与 & and
或 | or
非 ! not
异或 ^ xor
左移 << shl
右移 >> shr
要注意的是:D里面的位操作(与或非)与逻辑操作的关键字是相同的,所以平时没注意的话,可能就搞错了。
下面,介绍一下俺平时的位操作,其它的技巧,请自行查资料:
一:标志位:and or not
置标志位有值: v := v or flag;
置标志位无值: v := v and not flag;
检查是否有标志位有值:if (v and flag) = flag then 有值 else 无值.
其中:
1: v = Integer/Int64,即一个32或64位的数字(非浮点型)
2: flag 必须是2的N次方,(请用16进制8421助记),即:
$1, $2, $4, $8,
$10, $20, $40, $80
$100, $200, $400, $800
...
$10000000, $20000000, $40000000, $80000000
都是类似16进制,且,如果有"N个位"进行置位值,则flag = $1 or $2,这样类似表示。
然后,看到这些,如果经常看Windows.pas的常量定义,就会发现,很多常量,就是这样定义的。
为的就是,这个标志位进行取值,赋值,检查值。
具体为啥这样定义,请自行用计算器(二进制模式),进行and or not操作,慢慢摸:D
3: if (v and flag) = flag then 有值 else 无值.
一般这种写法,我会省略为:
if (v and flag) <> 0 then 某值的标志位有值;
if (v and flag) = 0 then 某值的标志位无值;
然后,可以写成多标志位:
const Masks = flag1 or flag2 or flag3....;
置多标志:x := v or Masks;
取值多标志:x := v and not Masks;
检查多标志:if x and Masks <> 0 then ...
二:字节对齐:
字节对齐---对一个值,进行:不足则补足。如:
给出一个数:X,要对它进行对4补齐,则:
1:x = 5时,需要得到align(x) = 8,就是说8是x对4的补齐后的数字。
2:x = 16时,已经补齐,则align(x) = 16,即保持原值。
请注意:对齐数,必定为2的N次方。
上面的逻辑,写成代码就是:
x := 5;
a := 4;
x := (x + (a - 1)) and not (a - 1);
这样,经过上述一行,and not 操作,x就与a对齐了。
我一般这样简写:
x := (x + a - 1) and -a;
三:乘除法
用位移可以有限的代替乘除,因为只针对于被乘除数是2的N次方,如:
x * 2 ==> x shl 1
x * 4 ==> x shl 2
x div 8 ==> x shr 3
x div 16 ==> x shr 4
请看被乘除数:2,4, 8, 16,相当于2的1,2,3,4次方.
四:掩码相关
取一个字节中的前4位:v := v and $0F;
取一个字节中的后4位:v := v shr $04;
那前3位,就是将前三位(以二进制数看)作掩码,然后进行and:flag = $01 or $02 or $04; v := v and flag;
后3位,就自己想了。
五:根据三+四的法子,可以很方便的,使用and进行求模操作
求模操作在使用hash取索引值是:mod: index := abs(key mod len);
也可以这样:
1:len = 2的N次方。
2:index := key and (len - 1);
得到某数的余数:x := a mod b;
如果b是2的N次方,则可以:x := a and (b - 1);
六:一些小技巧:
1: 检查某值是否为2的N次方:if (v and (v - 1)) = 0 then writeln('v是2的N次方');
2: 检测某值是否偶数:if (v and 1) = 0 then writeln('v是偶数'); // 等同于:if v mod 2 = 0
3: 想到再加吧,有些也不常用,或者请到上面链接查看一些更详细的技巧。
水平有限,如有雷同,就是盗链,:D
2014.11.02 by qsl
delphi.位操作的更多相关文章
- DELPHI判断是否64位操作系统
function IsWin64: Boolean;var Kernel32Handle: THandle; IsWow64Process: function(Handle: Windows.TH ...
- 转:Delphi 6 实用函数
来自: daocaoren0824, 时间: -- ::, ID: 再给你一份 程序员实用函数 {▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎▎} {▎ ▎} {▎ 大 ...
- 【Delphi内联汇编学习1】Delphi与汇编
我一直认为Delphi功能与C++相比毫不逊色,提供了丰富的控件和类.全部API以及嵌入的汇编.最近小弟在把C版的Huffman压缩改用Delphi写时,顺便“研究”了一下Delphi的位操作和嵌入式 ...
- delphi与汇编
我一直认为Delphi功能与C++相比毫不逊色,提供了丰富的控件和类.全部API以及嵌入的汇编.最近小弟在把C版的Huffman压缩改用Delphi写时,顺便“研究”了一下Delphi的位操作和嵌入式 ...
- Windows API方式直接调用C#的DLL,支持多音字转拼音、Gzip解压缩、公式计算(VBA、C++、VB、Delphi甚至java都可以)
原始链接 https://www.cnblogs.com/Charltsing/p/DllExport.html 这两年,我在VBA应用方面一直有几大痛点:1.多音字转拼音:2.64位下的GZIP解压 ...
- C#调用Delphi DLL获取字符串(C# IntPtr 与 string互转 )
前因后果 调用一门锁的dll实现读取酒店IC卡数据,直接用Readme里的方法出错. 函数声明: 一.读卡函数 ************************ Delphi 调用 ****** ...
- 学习笔记:7z在delphi的应用
最近做个发邮件的功能,需要将日志文件通过邮件发送回来用于分析,但是日志文件可能会超级大,测算下来一天可能会有800M的大小.所以压缩是不可避免了,delphi中的默认压缩算法整了半天不太好使,就看了看 ...
- delphi连接sql存储过程
针对返回结果为参数的 一. 先建立自己的存储过程 ALTER PROCEDURE [dbo].[REName] ) AS BEGIN select ROW_NUMBER() over(order by ...
- delphi 2010与delphi XE破解版的冲突
在系统中同时安装了Dephi 2010LITE版与Delphi XE lite后,总是会有一个有问题 是因为两者都是读取C:\ProgramData\Embarcadero目录下的license文件, ...
随机推荐
- CodeForces 239A. Triangle
Link: http://codeforces.com/contest/407/problem/A 给定直角三角形的2个直角边a,b.求在直角坐标系中,是否存在对应的直角三角形,使得三个定点都在整点 ...
- UNITY更新到5后设置的动画无法播放了怎么办
点击对应的animator,将 apply root motion 这个选项的勾去掉就可以了,纠结了很久最后在UNITY官方论坛找到的答案
- Codeforces Round #173 (Div. 2)
A. Bit++ 模拟. B. Painting Eggs 贪心,每个物品给使差值较小的那个人,根据题目的约数条件,可证明贪心的正确性. C. XOR and OR \(,,00 \to 00,01 ...
- wiseinstall 制做安装包小记
好久没写博客了..昨天未来的自己给自己托了个梦,说以后你肯定会忘了你今天白天是怎么制做安装包的,所以又来记录了..希望以后可以保持这个好习惯. 程序安装完后,可执行程序是 Wise32.exe 第一步 ...
- clang编译器简介
本文部分内容引用: 中文维基百科. 结构化编译器前端--clang介绍. 什么是clang编译器? clang是LLVM编译器工具集的一个用于编译C.C++.Objective-C的前端.LLVM项目 ...
- 利用IIS管理器模拟CDN
CDN(Content Delivery Network,内容分发网络).其含义,在百度百科上是这么写的:CDN 是构建在数据网络上的一种分布式的内容分发网.CDN 的作用是采用流媒体服务器集群技术, ...
- PCB的过孔
在走多层板时,经常需要打过孔,那么过孔是怎么分类的呢?且往下看. (1)通孔:这种孔穿过整个线路板,可以用于内部互连或者作为元件的安装定位孔(用于连接层:生成钻孔文件,在PCB上打孔并在孔内电镀:通常 ...
- Bash命令积累
复制本目录下除掉所有的.png文件外的所有其他文件到某个目录下: mv -f !(*.png) ./src/ 除掉所有的.png文件外其余的文件,全部删掉 rm -f !(*.png) 本目录下,不显 ...
- iso 培训笔记
protocol协议 + 类方法- 实例方法:继承()方法 <> [] 方法调用 .属性:参数mvc storyboard 资源文件info.plist 权限viewcontroller ...
- CentOS 6主机上的RStudio Server安装步骤
1. 安装EPEL库 yum -y install epel-release 2. 安装R yum install R 3. 安装OpenSSL yum install openssl098e 4. ...