- 帕斯卡教程
- 帕斯卡 - 主页
- 帕斯卡 - 概述
- Pascal - 环境设置
- 帕斯卡 - 程序结构
- Pascal - 基本语法
- Pascal - 数据类型
- Pascal - 变量类型
- 帕斯卡 - 常数
- 帕斯卡 - 运算符
- 帕斯卡 - 决策
- 帕斯卡 - 循环
- 帕斯卡 - 函数
- 帕斯卡 - 程序
- Pascal - 变量作用域
- 帕斯卡 - 弦乐
- 帕斯卡 - 布尔
- 帕斯卡 - 数组
- 帕斯卡 - 指针
- 帕斯卡 - 记录
- 帕斯卡 - 变体
- 帕斯卡 - 集合
- 帕斯卡 - 文件处理
- 帕斯卡 - 记忆
- 帕斯卡 - 单位
- 帕斯卡 - 日期和时间
- 帕斯卡 - 对象
- 帕斯卡 - 类
- 帕斯卡有用资源
- 帕斯卡 - 快速指南
- 帕斯卡 - 有用的资源
- 帕斯卡 - 讨论
帕斯卡 - 位运算符
Pascal 支持的位运算符如下表所示。假设变量 A 为 60,变量 B 为 13,则 -
操作员 | 描述 | 例子 |
---|---|---|
& | 如果两个操作数中都存在,则二进制 AND 运算符会将一位复制到结果中。 | (A & B) 将给出 12,即 0000 1100 |
| | 如果任一操作数中存在该位,则二元或运算符会复制该位。 | (A | B) 将给出 61,即 0011 1101 |
! | 如果任一操作数中存在该位,则二元或运算符会复制该位。与 | 相同 操作员。 | (A ! B) 将给出 61,即 0011 1101 |
〜 | 二进制补码运算符是一元的,具有“翻转”位的效果。 | (~A ) 将给出 -61,由于是有符号二进制数,因此为 2 的补码形式的 1100 0011。 |
<< | 二进制左移运算符。左操作数的值向左移动右操作数指定的位数。 | A << 2 将给出 240,即 1111 0000 |
>> | 二进制右移运算符。左操作数的值向右移动右操作数指定的位数。 | A >> 2 将得到 15,即 0000 1111 |
请注意,Pascal 的不同实现在按位运算符方面有所不同。然而,我们在这里使用的编译器 Free Pascal 支持以下按位运算符 -
运营商 | 运营 |
---|---|
不是 | 按位非 |
和 | 按位与 |
或者 | 按位或 |
异或 | 按位异或 |
谢尔 | 按位左移 |
什尔 | 按位右移 |
<< | 按位左移 |
>> | 按位右移 |
下面的例子说明了这个概念 -
program beBitwise; var a, b, c: integer; begin a := 60; (* 60 = 0011 1100 *) b := 13; (* 13 = 0000 1101 *) c := 0; c := a and b; (* 12 = 0000 1100 *) writeln('Line 1 - Value of c is ', c ); c := a or b; (* 61 = 0011 1101 *) writeln('Line 2 - Value of c is ', c ); c := not a; (* -61 = 1100 0011 *) writeln('Line 3 - Value of c is ', c ); c := a << 2; (* 240 = 1111 0000 *) writeln('Line 4 - Value of c is ', c ); c := a >> 2; (* 15 = 0000 1111 *) writeln('Line 5 - Value of c is ', c ); end.
当上面的代码被编译并执行时,它会产生以下结果 -
Line 1 - Value of c is 12 Line 2 - Value of c is 61 Line 3 - Value of c is -61 Line 4 - Value of c is 240 Line 5 - Value of c is 15
pascal_operators.htm