当前位置: 首页 > news >正文

c语言移位操作

应该先看看C语言是指所有的位二进制算术位计算。即使输入的是十进制的数,在存储器存储为二进制形式。 
“<<”使用方法: 
的格式是:a<<m,a和m式,要求m>=0。 
功能:将整型数a按二进制位向左移动m位,高位移出后,低位补0。 
“>>”使用方法: 
格式是:a>>m,a和m必须是整型表达式。要求m>=0。

功能:将整型数a按二进制位向右移动m位,低位移出后,高位补0

 
  

  

C语言中的移位操作。内容不多。只是有些地方你不注意,就疏忽了。
闲话少说,先做两个小题先。
(1)unsigned char x=3;
x<<1是多少?x>>1是多少?
(2)char x=3;
x<<1是多少?x>>1是多少?
(3)char x=-3;
x<<1是多少?x>>1是多少?

3写成二进制数是00000011。-3写成二进制数是(补码)11111101。
程序运行的时候。操作的是数值的编码表示。也就是数值在内存中的二进制表示。比方说,
程序取-3的时候,就去取11111101。

(1)对无符号数3来说。x<<1往左移一位,最左边的位移掉了。最右边的移进来的位补零。变成
00000110,所以结果是6。x>>1往右边移一位。因为是无符号数,所以逻辑右移,最右边一位移掉,
最左边移进来的位补零。变成00000001,所以结果是1。


(2)对于有符号数3来说,x<<1往左移一位。最左边的位移掉了,最右边的移进来的位补零。变成
00000110,所以结果是6。x>>1往右边移一位,因为是有符号数,可能发生逻辑右移,也可能发生算术右移
,这一点。C标准并没有明白地指定是使用逻辑右移还是算术右移。

但大多数的机器都使用算术右移,变成
00000001,所以结果还是1。

可是请注意,这仅仅是说大多数的机器是这种,你敢保证自己
不会碰到特殊情况吗?
(3)对于有符号数-3来说。x<<1往左移一位,最左边的位移掉了,最右边的移进来的位补零。

变成
11111010,结果是-6。

往右移一位,因为是有符号数。可能发生逻辑右移,也可能发生算术右移。
大多数机器使用算术右移。变成11111110,结果是-2。

总结:左移时总是移位和补零。右移时无符号数是移位和补零,此时称为逻辑右移;
而有符号数大多数情况下是移位和补最左边的位(也就是补最高有效位),移几位就补几位,此时称为算术右移。

附打印内存中字节编码的代码:
void print_char(char x)
{
  unsigned char * bp=(unsigned char *)&x;
  int size=sizeof(x);
  for(int i=0; i<size; i++)
       printf("%.2x", bp[i]);
  printf("/n");
}
这种做法可以自己练习。

从报价:http://blog.chinaunix.net/u1/33888/showart_334911.html

相关文章:

  • HDU-6069 Counting Divisors - 2017 Multi-University Training Contest - Team 4(分解质因子区间筛法)
  • HDU-6073 Matching In Multiplication - 2017 Multi-University Training Contest - Team 4(拓扑+连通块处理)
  • 我的Java开发学习之旅------Java经典排序算法之插入排序
  • POJ-3352 Road Construction(边双连通分量+缩点)
  • 445port入侵详细解释
  • UVALive-5013 Similarity(二分图最大权匹配)
  • Cisco ASA-ASA 8.2-L2L ***
  • HDU-3440 House Man(差分约束系统)
  • 怎么安装docker registry
  • HDU-3666 THE MATRIX PROBLEM(差分约束系统判断存在与否+特殊剪枝)
  • Thinkphp学习04
  • HDU-4315 Climbing the Hill(阶梯博弈变形)
  • HDU-5724 Chess(SG函数+状压)
  • Randy Shoup与Andrew Phillips对微服务方面问题的解答
  • HDU-4109 Instrction Arrangement(差分约束系统+增加源点技巧)
  • [译] 怎样写一个基础的编译器
  • 【RocksDB】TransactionDB源码分析
  • ABAP的include关键字,Java的import, C的include和C4C ABSL 的import比较
  • axios 和 cookie 的那些事
  • cookie和session
  • django开发-定时任务的使用
  • es6(二):字符串的扩展
  • ES6简单总结(搭配简单的讲解和小案例)
  • HTML5新特性总结
  • iOS动画编程-View动画[ 1 ] 基础View动画
  • JavaScript学习总结——原型
  • ReactNative开发常用的三方模块
  • vue+element后台管理系统,从后端获取路由表,并正常渲染
  • 百度地图API标注+时间轴组件
  • 关于 Linux 进程的 UID、EUID、GID 和 EGID
  • 技术胖1-4季视频复习— (看视频笔记)
  • 前嗅ForeSpider中数据浏览界面介绍
  • 数据结构java版之冒泡排序及优化
  • 中文输入法与React文本输入框的问题与解决方案
  • 【云吞铺子】性能抖动剖析(二)
  • 不要一棍子打翻所有黑盒模型,其实可以让它们发挥作用 ...
  • ​用户画像从0到100的构建思路
  • #{}和${}的区别是什么 -- java面试
  • #pragma once与条件编译
  • $.ajax()参数及用法
  • (c语言版)滑动窗口 给定一个字符串,只包含字母和数字,按要求找出字符串中的最长(连续)子串的长度
  • (NO.00004)iOS实现打砖块游戏(十二):伸缩自如,我是如意金箍棒(上)!
  • (附源码)计算机毕业设计ssm基于Internet快递柜管理系统
  • (论文阅读32/100)Flowing convnets for human pose estimation in videos
  • (三) prometheus + grafana + alertmanager 配置Redis监控
  • .equal()和==的区别 怎样判断字符串为空问题: Illegal invoke-super to void nio.file.AccessDeniedException
  • .NET CF命令行调试器MDbg入门(一)
  • .NET 使用 XPath 来读写 XML 文件
  • .NET/C# 在代码中测量代码执行耗时的建议(比较系统性能计数器和系统时间)
  • .NET开源快速、强大、免费的电子表格组件
  • .net使用excel的cells对象没有value方法——学习.net的Excel工作表问题
  • .net专家(高海东的专栏)
  • :O)修改linux硬件时间
  • @data注解_SpringBoot 使用WebSocket打造在线聊天室(基于注解)
  • @RequestMapping处理请求异常