java 的原碼、補碼、反碼小總結

先看一個代碼吧:

int h;
return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16);

這個應該很熟悉吧,是 java?里 HashMap?的計算 hash?值的方法.這里有一個運算符 "^",他其實就是使用補碼來運算的.好了,那么我們下面來說說這些吧:

 >原碼。就是當前數字的二進制表現形式,如-1的原碼是1000 0001>反碼正數的反碼就是本身。負數的反碼是二進制保留符號位。剩余位取反,比如-1的反碼是1111 1110>補碼正數的反碼、補碼、原碼都是一樣的,負數的補碼是在其反碼的基礎上+1,比如-1的補碼是1111 1111。正數的原碼、反碼、補碼都相同。負數的反碼是除符合位為1外,其他位全取反,簡單地說,負數求補碼,“反碼加1“。
這句話是不負責任的,因為原碼、反碼和補碼概念中,存在符號位,總結一下,”取反加1“時符號位怎么辦:1)取反時,符號位不參與取反。2)加1時,符號位參與加1。3)特殊補碼,即首位為1,其它位全是0。對于這種形式的補碼,不要去求它的原碼了,求出來也不對,它就表示該類型中的最小負數,比如10000000表示byte類型中的最小負數-128。已知一個數的補碼,求原碼的操作分兩種情況:1)如果補碼的符號位為“0”,表示是一個正數,所以補碼就是該數的原碼.2)如果補碼的符號位為“1”,表示是一個負數,求原碼的操作可以是:符號位為1,其余各位取 反,然后再整個數加1.例如,已知一個補碼為11111001,則原碼是10000111(-7):因為符號位為“1”,表示是一個負數,所以該位不變,仍為“1”;其余7位1111001取反后為0000110;再加1,所以是10000111.java有7種位運算符:與(&),或(|),異或(^),取反(~),左移(<<),有符號右移(>>),無符號右移(>>>)。
這7種位運算符,運算時,符號位都要參與運算。具體的規則如下:&    如果相對應位都是1,則結果為1,否則為0    (A&B),得到12,即0000 1100|    如果相對應位都是0,則結果為0,否則為1    (A | B)得到61,即 0011 1101^    如果相對應位值相同,則結果為0,否則為1    (A ^ B)得到49,即 0011 0001? 按位補運算符翻轉操作數的每一位,即0變成1,1變成0。    (?A)得到-61,即1100 0011<< 按位左移運算符。左操作數按位左移右操作數指定的位數。    A << 2得到240,即 1111 0000>> 按位右移運算符。左操作數按位右移右操作數指定的位數。    A >> 2得到15即 1111>>>按位右移補零操作符。左操作數的值按右操作數指定的位數右移,移動得到的空位以零填充。    A>>>2得到15即0000 1111//1.&
int a = 10,b = 6;
/*** a = 10 > 00000000 00000000 00000000 00001010* b = 6  > 00000000 00000000 00000000 00000110* &* 2 >      00000000 00000000 00000000 00000010*/
System.out.println(Integer.toBinaryString(a));
System.out.println(Integer.toBinaryString(b));
System.out.println(a & b);a = -10;
b = -6;/*** a = -10 > 11111111 11111111 11111111 11110110* b = -6  > 11111111 11111111 11111111 11111010* &* r = -14 > 11111111 11111111 11111111 11110010*///-10
// 原碼 10000000 00000000 00000000 00001010
// 反碼 11111111 11111111 11111111 11110101
// 補碼 11111111 11111111 11111111 11110110//-6
// 原碼 10000000 00000000 00000000 00000110
// 反碼 11111111 11111111 11111111 11111001
// 補碼 11111111 11111111 11111111 11111010// -14
// 原碼 10000000 0000000 00000000 00001110
// 反碼 11111111 1111111 11111111 11110001
// 補碼 11111111 1111111 11111111 11110010

System.out.println("a = " + a + ",補碼是:" + Integer.toBinaryString(a));
System.out.println("b = " + b + " ,補碼是:" + Integer.toBinaryString(b));
System.out.println("a ^ b is:" + (a & b));
System.out.println("結果的補碼是:" + Integer.toBinaryString(-14));

?

轉載于:https://www.cnblogs.com/zhuzi91/p/8818950.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/280611.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/280611.shtml
英文地址,請注明出處:http://en.pswp.cn/news/280611.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Django08:模型層(ORM)--測試腳本/必知的13條/神器的雙下劃線查詢/多表操作

單表操作 django 自帶的sqlite3數據庫對日期格式不是很敏感&#xff0c;處理的時候容易出錯。 測試腳本 測試環境準備&#xff1a;去manage.py 中拷貝錢四行代碼&#xff0c;然后自己手寫兩行。 腳本無論在引用下面&#xff0c;還是單獨開設PY文件都可以。 import os impor…

“互聯網+”促傳統企業三大轉型

2015年是傳統行業互聯網化的元年。國家提出要制定“互聯網”行動計劃后&#xff0c;互聯網旅游、互聯網汽車、互聯網三農、互聯網物流、互聯網醫療等開始起步。同時&#xff0c;面對不確定的移動互聯網時代&#xff0c;互聯網某些技術和模式還在進化、演變之中&#xff0c;每一…

開發高性能ASP.NET應用

本文是“.NET Conf China 2022”上我的一個分享&#xff0c;這里更細化的分享出來。分享分為四個部分&#xff1a;制定指示設計應用正確測試性能優化高性能&#xff1a;不一定是架構出來的&#xff0c;但一定是優化出來的。制定指標-收集首先把項目中的熱路徑API和核心API找出來…

Ethereum-EIPs

What is an EIP? Ethereum Improvement Proposal 以太坊改進建議的文檔 這個文檔向Ethereum社區提供信息&#xff0c;為Ethereum、Ethereum的進程、環境描述一個新特征&#xff0c;該EIP應當為該特征提供一個基本的技術描述和原理原理。該EIP作者有責任在社區和不同意見的文檔…

Django08-1:模型層(ORM)--聚合查詢/分組查詢/F與Q查詢/開啟事務/常用字段及參數/自定義字段/數據庫查詢優化

聚合查詢 單獨使用時&#xff0c;用aggregate 1.只要是跟數據庫相關的模塊 基本都在django.db.models里面 如果沒有應該在django.db里面 2. 聚合查詢通常配合分組使用 from django.db.models import Avg, Sum, Max, Min, Count# 1.所有書的平均價格 resmodels.Book.objects.…

記事本狀態欄不會自動_如何在記事本中同時啟用狀態欄和自動換行

記事本狀態欄不會自動The status bar in Windows’ Notepad displays the current line number and column number of the cursor location. However, if you find that the Status Bar option on the View menu is grayed out, it may be because you have Word Wrap enabled…

洛谷P2587 [ZJOI2008] 泡泡堂

題目傳送門 分析&#xff1a;一道策略游戲題&#xff0c;要求最大期望得分和最小期望得分。首先分析最大&#xff0c;很顯然是可以用一種類似于田忌賽馬的思維來做&#xff0c;將兩隊的實力按照從大到小&#xff08;其實從小到大也可以&#xff09;排序&#xff0c;然后就按照順…

極端高溫導致澳大利亞斷網

&#xfeff;西澳大利亞首府珀斯因惡劣天氣出現了網絡連接問題&#xff0c; 網絡故障不是由于暴風雨或閃電引起的&#xff0c;而是極端高溫。本周一是珀斯有記錄以來第六熱的天&#xff0c;當天最高溫度達到了44.4℃。因為創紀錄的高溫&#xff0c;澳大利亞寬帶 服務商iiNet在當…

推薦一款采用 .NET 編寫的 反編譯到源碼工具 Reko

今天給大家介紹的是一款名叫Reko的開源反編譯工具&#xff0c;該工具采用C#開發&#xff0c;廣大研究人員可利用Reko來對機器碼進行反編譯處理。我們知道.NET 7 有了NativeAOT 的支持&#xff0c;采用NativeAOT 編譯的.NET程序 無法通過ILSpy 之類的傳統工具得到源碼&#xff0…

并行傳輸數據和串行傳輸數據_為什么串行數據傳輸比并行數據傳輸快?

并行傳輸數據和串行傳輸數據SATA hard drive connections are faster than older PATA hard drive connections and the same can be said for external cabling standards, but this is counter-intuitive: why wouldn’t the parallel transmission be faster? SATA硬盤驅動…

得到某月的天數

Calendar timeCalendar.getInstance(); time.clear(); time.set(Calendar.YEAR,2018);//year年 time.set(Calendar.MONTH,1);//Calendar對象默認一月為0,month月 int daytime.getActualMaximum(Calendar.DAY_OF_MONTH);//本月份的天數 System.out.pri…

Django09:圖書管理系統筆記/choices用法/ MTV與MVC模型/多對多三種創建方式

圖書管理系統筆記 redirect括號內可以直接寫url 也可以直接寫別名 但如果別名需要參數&#xff0c;必須使用reverse解析。 choices用法 使用場景&#xff1a;能列舉完全的數據 #使用方法&#xff1a;xxx_choice #1. get.xxx_display #2. 如果超出范圍&#xff0c;則顯示原…

業務處理速度變慢?且看IT如何成為救世主

在日常生活的方方面面&#xff0c;我們似乎都在期待著一種即時的便利。比如&#xff0c;用手機購物、訂餐、繳費、預約掛號等等。而在企業中&#xff0c;時間與效率可不是一種休閑福利&#xff0c;而是一項重要的商業功能。我們有理由期待&#xff0c;當今史無前例的數字革命正…

微軟讓卡塔爾世界杯踏入元宇宙

遵守前一篇公眾號文章里的承諾&#xff0c;昨天盆盆在視頻號里錄制了一段5分鐘左右的短視頻&#xff0c;講了江森自控和微軟Azure&#xff0c;如何幫助卡塔爾世界杯打造基于元宇宙的數字體育館。Part.1歡迎掃碼關注我的視頻號(每天更新元宇宙、云計算和數字化的短視頻)。Part.2…

洛谷——P1305 新二叉樹(新建二叉樹以及遍歷)

題目描述輸入一串二叉樹&#xff0c;用遍歷前序打出。 輸入輸出格式輸入格式&#xff1a; 第一行為二叉樹的節點數n。(n \leq 26n≤26) 后面n行&#xff0c;每一個字母為節點&#xff0c;后兩個字母分別為其左右兒子。 空節點用*表示 輸出格式&#xff1a; 前序排列的二叉樹 輸…

插槽1單通道插槽2雙通道_相機雙存儲卡插槽有什么大不了的?

插槽1單通道插槽2雙通道If you paid any attention to the launch of Canon and Nikon’s first full frame mirrorless cameras—the EOS R, Z6, and Z7— you’d have noticed that some people were pretty unhappy that they only came with a single card slot—an SD slo…

python 垃圾回收詳解

原文&#xff1a;https://zhuanlan.zhihu.com/p/31150408 總綱策略和垃圾回收系統工作內容引用計數詳解標記-清除分代收集循環引用編程應用-常見方法ex 過程詳解使用建議觸發機制參考文獻Python垃圾回收機制--完美講解&#xff08;Python vs Ruby&#xff09;Python垃圾回收機制…

Django10:Ajax介紹/發送數據/SweetAlert

Ajax 異步提交 局部刷新 發送方式 1. 瀏覽器輸入url&#xff0c;按enter get 2.a標簽href屬性 get 3.form表單 get/post 4. ajax get/post ajax 不是編程語言&#xf…

物聯網數據終端演進之道

智能手機的普及在最近幾年掀起了一股取代企業數據終端的風潮&#xff0c;但正如筆者在一年前便提到過 的&#xff0c;“智能手機難以在企業級應用中得以普及”&#xff0c;這種觀點最好的佐證便是時至今日&#xff0c;由于安全性與管理合規的需要&#xff0c;個人計算機用于企業…

mac 不能連接wi-fi_如何阻止Mac自動連接到Wi-Fi網絡

mac 不能連接wi-fiYour Mac automatically reconnects to Wi-Fi networks you’ve previously connected to. Starting with macOS High Sierra, you can now tell your Mac not to automatically connect to certain Wi-FI networks. Your Mac will remember the Wi-Fi networ…