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

网站上线做什么网站目录结构

网站上线做什么,网站目录结构,wordpress添加商城,简历设计网Java 的移位运算符有三种&#xff08;引用《Java编程思想&#xff08;Bruce Eckel&#xff0c; 第4版&#xff09;》&#xff09;&#xff1a; “<<” &#xff1a;左移运算符&#xff0c;按照操作符右侧指定的位数将操作符左边的操作数向左移动&#xff08;在低位补0&a…

Java 的移位运算符有三种(引用《Java编程思想(Bruce Eckel, 第4版)》):

  • “<<” :左移运算符,按照操作符右侧指定的位数将操作符左边的操作数向左移动(在低位补0);
  • “>>” :右移运算符,按照操作符右侧指定的位数将操作符左边的操作数向右移动;
    “有符号”右移操作符使用“符号扩展”:
    • 若符号为正,则在高位插入0;
    • 若符号为负,则在高位插入1。
  • “>>>”:“无符号”右移操作符,它使用“符号扩展”:无论正负都在高位插入0。
     
  • 没有无符号左移

 这些解释并没有说清楚原理,这里的移位运算符其实是对补码进行操作。


这里需要先回顾一下原码、反码、补码的概念(以32-bit为例,第一位为符号位):

  • 正数: 正数的反码、补码都等于原码,如3,原码、反码、补码都是 0000 0000 0000 0000 0000 0000 0000 0011;
  • 负数:以-3为例
    • 原码:1000 0000 0000 0000 0000 0000 0000 0011;
    • 反码:1111 1111 1111 1111 1111 1111 1111 1100;(符号位不变,其余位取反)
    • 补码:1111 1111 1111 1111 1111 1111 1111 1101;(符号位不变,其余位取反后+1)

下面是几个例子:

  • 正数 
int a = 3;
System.out.println(a << 1);     // 输出: 6
System.out.println(a >> 1);	    // 输出: 1

正数的补码跟原码一样,所以3左移一位即:
    0000 0000 0000 0000 0000 0000 0000 0011 ==> 0000 0000 0000 0000 0000 0000 0000 0110
    即 3 ==> 6 (10进制);
3右移一位:
    0000 0000 0000 0000 0000 0000 0000 0011 ==> 0000 0000 0000 0000 0000 0000 0000 0001
    即 3 ==> 1 (10进制);

  • 负数:
int b = -3;
System.out.println(b << 1);     // 输出: -6
System.out.println(b >> 1);	    // 输出: -2

-3的补码是 1111 1111 1111 1111 1111 1111 1111 1101;
-3左移一位:
    补码变为:1111 1111 1111 1111 1111 1111 1111 1010;
    对补码再取补,得到对应的原码。
    对应原码:1000 0000 0000 0000 0000 0000 0000 0110;
    即 -3 ==> -6 (10进制);
-3右移一位:
    补码变为:1111 1111 1111 1111 1111 1111 1111 1110;
    对补码再取补,得到对应的原码。
    对应原码:1000 0000 0000 0000 0000 0000 0000 0010;
    即 -3 ==> -2 (10进制);

  • 无符号右移
int a = 3;
int b = -3;
System.out.println(a >>> 1);    // 输出: 1
System.out.println(b >>> 1);	// 输出: 2147483646 

无符号右移其实就是将符号位也当成一个普通的位,因为正数的符号位为0,所以对正数来说,无符号右移跟有符号右移是一样的。而对负数来说,无符号右移是在高位插入0,而有符号右移是在高位插入0。

  • -3无符号右移1位过程:

    • 原码:1000 0000 0000 0000 0000 0000 0000 0011;
    • 补码:1111 1111 1111 1111 1111 1111 1111 1101;
    • 无符号右移:0111 1111 1111 1111 1111 1111 1111 1110;
    • 再求补转原码:0111 1111 1111 1111 1111 1111 1111 1110;
      注意: 此时在转换成10进制时,仍认为最高位为符号位。而右移后最高位为0,即正数,而对正数再求补仍是这个数。

    即 -3 ==> 2147483646 (10进制)。

http://www.hkea.cn/news/161678/

相关文章:

  • 合肥++网站建设磐石网站seo
  • 万网主机怎么上传网站如何在百度上投放广告
  • 做网站时如何给文字做超链接全球疫情最新数据消息
  • 四川省住建厅官方网站3分钟搞定网站seo优化外链建设
  • 做网站阳泉巨量千川广告投放平台
  • 温岭哪里有做网站的如何自制网站
  • 知道创于 wordpress搜索引擎优化宝典
  • 乌兰县wap网站建设公司有效获客的六大渠道
  • 微信网站开发教程视频教程百度一下主页官网
  • 网站开发专业前景关键词挖掘排名
  • 网站开发属于什么职位类别seo查询站长工具
  • wordpress postmetaseoul national university
  • 商务网站的主要存在形式杭州百度快照优化公司
  • 个人备案网站做购物网站可以不班级优化大师免费下载电脑版
  • 贸易网站建设互联网广告代理加盟
  • 深圳网站建设网络公司河北关键词排名推广
  • 在工商网上怎么注册公司seo优化博客
  • 免费的小程序怎么赚钱历下区百度seo
  • 河北石家庄最新疫情最新消息优化防疫政策
  • 一站式做网站哪家强新闻小学生摘抄
  • 江西南昌网站建设公司哪家好谷歌google 官网下载
  • 公司网站用什么开发百度指数怎么用
  • 建站主机 wordpress济南网站万词优化
  • 哈尔滨app开发seo自学网官网
  • 网站答辩ppt怎么做全网关键词云在哪里看
  • 网站建设 视频seo关键词词库
  • 网站应用软件设计成都网站建设技术外包
  • 用哪个软件做网站网址查询域名解析
  • 网站安全优化域名停靠浏览器
  • 我做中医培训去哪个网站找学员谷歌排名算法