《C语言编程魔法书:基于C11标准》——2.8 移位操作

2.8 移位操作

现代处理器的计算单元中一般都会包含移位器。移位器往往能执行算术左移(Arithmetic Shift Left)、算术右移(Arithmetic Shift Right)、逻辑左移(Logical Shift Left)、逻辑右移(Logical Shift Right)、循环右移(Rotational Shift Right)这些操作。
下面我们将分别介绍这些移位操作,这里需要提醒各位的是,移位操作一般总是对整数数据进行操作,并且移入移出的都是二进制比特。然而,不同的处理器架构对移位操作的实现可能会有一些不同。比如,如果对一个32位寄存器做移位操作,倘若指定要移动的比特数超过了31,那么在x86处理器中是将指定的比特移动位数做模32处理(也就是求除以32的余数,比如左移32位相当于左移0位、右移33位相当于右移1位);而在ARM、AVR等处理器中,对一个32位的整数做左移和逻辑右移超出31位的结果都将是零。
2.8.1 算术左移与逻辑左移
由于算术左移与逻辑左移操作基本是相同的,仅仅对标志位的影响有些区别,所以合并在一起讲。左移的操作步骤十分简单,假设我们要左移N位,那么先将整数的每个比特向左移动N位,然后空出的低N位填零。图2-10展示了对一个8位整数分别做左移1位与左移2位的过程。

图2-10中间由小写字母a~h构成的方格图即表示一个8位二进制整数,每个小写字母表示一比特,并且字母a作为最高位比特,字母h作为最低位比特。左移1位后,原来的8位二进制数就变成了bcdefgh0;左移2位后,原来的8位二进制数就变成了cdefgh00。
2.8.2 逻辑右移
逻辑右移的操作步序是:先将整数的每一个比特向右移动N位,然后高N位用零来填补。图2-11展示了一个8位二进制整数分别逻辑右移1位和2位的过程。

图2-11中间由小写字母a~h构成的方格图即表示一个8位二进制整数,每个小写字母表示一位比特,并且字母a作为最高位比特,字母h作为最低位比特。将原始二进制8位数据逻辑右移1位后,二进制数据变为0abcdefg;逻辑右移2位后,二进制数据变为00abcdef。
2.8.3 算术右移
算术右移与逻辑右移类似,只不过移出N位之后,高N位不是用零来填充,而是根据原始整数的最高位,如果原始整数的最高位为1,那么移位后的高N位用1来填充;如果是0,则用0来填充。图2-12展示了一个8位二进制整数分别算术右移1位和2位的过程。

图2-12中间由小写字母a~h构成的方格图,即表示一个8位二进制整数,每个小写字母表示一位比特,并且字母a作为最高位比特,字母h作为最低位比特。将原始8位二进制整数算术右移1位之后,该二进制数变为aabcdefg;将它算术右移2位之后,变为aaabcdef。
2.8.4 循环右移
循环右移的步序是:先将原始二进制整数右移N位,移出的N位依次放入到高N位。图2-13展示了将一个8位二进制整数分别循环右移1位和2位的过程。

图2-13中间由小写字母a~h构成的方格图,即表示一个8位二进制整数,每个小写字母表示一位比特,并且字母a作为最高位比特,字母h作为最低位比特。将原始8位二进制整数循环右移1位之后,该二进制整数变为habcdefg;将它循环右移2位之后,该二进制整数变为ghabcdef。

时间: 2024-11-01 09:05:26

《C语言编程魔法书:基于C11标准》——2.8 移位操作的相关文章

《C语言编程魔法书:基于C11标准》—— 导读

前 言 为什么要写这本书 本人在2001年上了大学本科,读计算机科学与技术专业.在第一年的上半学期,对计算机编程还没什么感觉.但是就在考"C语言程序设计"这门专业课的前一个月,感觉这门课学了那么久几乎什么都不会,可把我急坏了.然后就在这短短一个月的时间里又是看书,又是上机实验,终于考了70多分,算是过关了--不过奇怪的是在考试结束后,就发现自己对编程有了感情.到了大二,我们上"数据结构"所使用的教材是基于C++编程语言的,因为之前没学过C++语言,所以只能自学.而在

《C语言编程魔法书:基于C11标准》——导读

前 言 为什么要写这本书 本人在2001年上了大学本科,读计算机科学与技术专业.在第一年的上半学期,对计算机编程还没什么感觉.但是就在考"C语言程序设计"这门专业课的前一个月,感觉这门课学了那么久几乎什么都不会,可把我急坏了.然后就在这短短一个月的时间里又是看书,又是上机实验,终于考了70多分,算是过关了--不过奇怪的是在考试结束后,就发现自己对编程有了感情.到了大二,我们上"数据结构"所使用的教材是基于C++编程语言的,因为之前没学过C++语言,所以只能自学.而在

《C语言编程魔法书:基于C11标准》——第3章 C语言编程的环境搭建3.1 Windows操作系统下搭建C语言编程环境

第3章 C语言编程的环境搭建 我们在第2章讲述了学习C语言所必需的一些预备知识.本章将给大家介绍常用桌面操作系统下的C语言环境搭建.这里所讲述的C语言编译器以及集成开发环境(IDE)都是可合法免费下载的,本书不鼓励各位使用盗版或破解软件,所以下面会列出下载这些合法免费软件的官方链接,大家把编程环境搭建完之后即可上机实践编程. 3.1 Windows操作系统下搭建C语言编程环境 Windows操作系统下默认不自带任何C语言编译器,大家必须从网上下载自己所需要的C语言编译器.如果各位想通过C语言开发

《C语言编程魔法书:基于C11标准》——第一篇 预备知识篇 第1章 C魔法概览1.1 例说编程语言

第一篇 预备知识篇 第1章 C魔法概览 本章内容主要对C编程语言(以下简称C语言)进行大体介绍,包括它的历史以及C语言标准的演化进程.然后介绍一下C语言编程思想,当前主流C语言编译器以及GNU语法扩展.最后简单介绍一下从用C语言编写程序到编译.构建一个可执行程序的大致过程. 计算机编程语言从对计算机硬件底层的抽象程度进行分类,可分为:机器语言.汇编语言以及高级语言.下面由底层到高层分别介绍这几种类别的编程语言. 1.1 例说编程语言 1)机器语言是直接通过十六进制数表示当前处理器架构的机器指令码

《C语言编程魔法书:基于C11标准》——第一篇 预备知识篇 第1章 C魔法概览 1.1 例说编程语言

第一篇 预备知识篇 第1章 C魔法概览 本章内容主要对C编程语言(以下简称C语言)进行大体介绍,包括它的历史以及C语言标准的演化进程.然后介绍一下C语言编程思想,当前主流C语言编译器以及GNU语法扩展.最后简单介绍一下从用C语言编写程序到编译.构建一个可执行程序的大致过程. 计算机编程语言从对计算机硬件底层的抽象程度进行分类,可分为:机器语言.汇编语言以及高级语言.下面由底层到高层分别介绍这几种类别的编程语言. 1.1 例说编程语言 1)机器语言是直接通过十六进制数表示当前处理器架构的机器指令码

《C语言编程魔法书:基于C11标准》——1.3 主流C语言编译器介绍

1.3 主流C语言编译器介绍 对于当前主流桌面操作系统而言,可使用Visual C++.GCC以及LLVM Clang这三大编译器.其中,Visual C++(简称MSVC)只能用于Windows操作系统:其余两个,除了可用于Windows操作系统之外,主要用于Unix/Linux操作系统.像现在很多版本的Linux都默认使用GCC作为C语言编译器.而像FreeBSD.macOS等系统默认使用LLVM Clang编译器.由于当前LLVM项目主要在Apple的主推下发展的,所以在macOS中,Cl

《C语言编程魔法书:基于C11标准》——1.4 关于GNU规范的语法扩展

1.4 关于GNU规范的语法扩展 GNU是一款能用于构建类Unix操作系统的计算机软件合集,由自由软件之父Richard Stallman开创,于1983年9月27日对外发布.GNU完全由自由软件(free software)构成.GNU语法扩展源自于GCC编译器,在1987年发布1.0版本,称为GNU C Compiler.随后,GCC编译器前端支持了C++.Objective-C/C++.Fortran.Ada.Java以及最近跃升的Go等编程语言,因此现在GCC被称为GNU Compile

《C语言编程魔法书:基于C11标准》——1.2 用C语言编程的基本注意事项

1.2 用C语言编程的基本注意事项 C语言的发明其实基于Unix操作系统.当时在C语言未面世之前,Dennis Ritchie所在的AT&T贝尔实验室用的Unix系统是完全用汇编语言写的.汇编语言的优势是直接面向处理器本身,能直接对底层硬件进行控制,充分发挥处理器的硬件能力.然而,它的缺陷也是显而易见的. 1.汇编语言的不足 首先,不可移植性.每种处理器,其指令集都大相径庭,比如ARM有ARM的指令集架构(ISA),Intel x86有x86的ISA,还有MIPS.Power(原来为PowerP

《C语言编程魔法书:基于C11标准》——3.2 macOS系统下搭建C语言编程环境

3.2 macOS系统下搭建C语言编程环境 macOS系统也不默认自带C语言编译器.然而,用户可以自己去Mac App Store免费下载macOS下的强大开发工具--Xcode.该集成开发工具采用Apple定制版本的Clang编译器,称为Apple LLVM编译器.它自带C.C++.Objective-C以及Apple自己新推出的Swift编程语言编译器,还有一系列功能强大的代码静态分析以及性能剖析工具. 下载完Xcode之后,把它打开.如果是第一次启动,Xcode会自动更新一些资源,完了之后

《C语言编程魔法书:基于C11标准》——2.5 字符编码

2.5 字符编码 我们从2.2节到2.4节讲述的都是数值信息(整数与浮点数),本小节我们将讨论字符信息.在计算机中我们所处理的字符信息,即文本信息(包括数字.字母.文字.标点符号等)是以一种特定编码格式来定义的.为了使世界各国的文本信息能够通用,就需要对字符编码做标准化.我们现在最常用也最基本的字符编码系统是ASCII码(American Standard Code for Information Interchange,美国信息交换标准码).ASCII码定义每个字符仅占一个字节,可表示阿拉伯数