php二進位負數,php負數轉正數

本文目錄一覽:

php 的位運算總結

php的位運算很少會用到,但是用處很大,

在有些演算法中會用到,在許可權管理中也會經常用到,

對於理解計算機的世界也會有一定的幫助,所以得把這些重要但不常用的東西總結一下記錄一下。

提到位運算,避不開的是二進位。

因為位運算是直接在內存做操作和運算,相較與直接拿兩個變數做運算符肯定是更快的。

很多地方把二進位這玩意說得很晦澀,現在來以最簡單的方式來總結一下,當然只算 int 範圍內的數算了,超過了這個範疇程序員還不如拿這時間去學點別的。

說完以上總結,再來解釋下什麼是二進位,網上大把,

但只要記住,int範圍內的數也就是我們大部分需要用到的數,都可以用二進位來表示。

我們生活中用到的計數方式為十進位,由個數位滿10進1,

然後再開始重新計算,等十位滿9再加一時,百位加一,十位歸零。

二進位則只有兩個數字來表示就是0和1,滿2進1。

由32個位組成,雖然只有32個位但已滿足了我們正常的需求了

比如說1轉換為2進位原碼,由於1是正數所以符號位為0,

原碼反碼補碼都一個樣。

1的原碼:00000000 00000000 00000000 00000001

因手懶,太多0太丑用+拼接,’0* 8’代表8個0

2的原碼:0* 8 0* 8 0* 8 0* 6 + 1 0,既然是二進位,

滿2就得進1,最低位歸0,向前加一。

再來解釋下負數的原碼反碼和補碼,就開始講php的位運算了。

二進位複習完畢。下面開始講講php的位運算。

php一共有六種位運算,一種一種來講。

可以這麼理解,兩個數的補碼放在一起比較每個位(一共32個位),

可以得出另外一個數,這個數字的組成由比較的兩位數字生成,

如果兩個數的每個位數上的數字都等於1的話,

那得到的那個數的補碼的同位為1,否則為0。

聽著繞口,其實很簡單,覺得還是比官網上的更容易讓新手看懂

下面舉例子:

首先來求-1和7的補碼。7的原碼就是補碼。

兩個補碼都有了下面開始運算:

按照上面的說法, 每個位都有一樣則 $a 的同等位則為1,剛好-1的補碼和7的補碼前面都不一樣,就最後三位一樣,所以剛好求得的 $a 的補碼的最後三位是1而其他的都是0 ,剛好這個補碼為正數,正好就是7。

其實就是和按位與相反,只要有1個為1,那就為1,如果都不為1,那就為0。

$a = -1|7 ;得出來的 $a 補碼為32個1,但此時不能說 $a 就是-1,因為這只是補碼,要轉成原碼再轉成十進位數,補碼-1,然後再翻轉,再轉出來,得到的其實也還是-1。

就是將這個數的補碼全部翻轉過來,包括符號位,0變1,1變0

取反的結果一定是整數變負數負數變正數,取正數的反時,

記得一定要從補碼一步步轉到原碼再轉成十進位數才是答案。

兩個數的補碼比較,同等位上的兩數比較

,不一樣時,則答案的補碼的同位則為1,否則為0。

往左移符號位被擠走右邊0補充,往右移動,符號位不動,

高位以符號位補充。二進位世界裡往左移動其實是相當於乘以了2,

右移相當於除以了2。

不吹牛逼的說,這應該是互聯網上最容易理解的php位運算的解釋和二進位的解釋了。

原文鏈接: php的位運算總結-PHP

PHP 負數值得問題

在計算機中,負數以其正值的補碼形式表達。

什麼叫補碼呢?這得從原碼,反碼說起。

 

原碼:一個整數,按照絕對值大小轉換成的二進位數,稱為原碼。

比如 00000000 00000000 00000000 00000101 是 5的 原碼。

 

反碼:將二進位數按位取反,所得的新二進位數稱為原二進位數的反碼。

取反操作指:原為1,得0;原為0,得1。(1變0; 0變1)

比如:將00000000 00000000 00000000 00000101每一位取反,得11111111 11111111 11111111 11111010。

稱:11111111 11111111 11111111 11111010 是 00000000 00000000 00000000 00000101 的反碼。

反碼是相互的,所以也可稱:

11111111 11111111 11111111 11111010 和 00000000 00000000 00000000 00000101 互為反碼。

 

補碼:反碼加1稱為補碼。

也就是說,要得到一個數的補碼,先得到反碼,然後將反碼加上1,所得數稱為補碼。

比如:00000000 00000000 00000000 00000101 的反碼是:11111111 11111111 11111111 11111010。

那麼,補碼為:

11111111 11111111 11111111 11111010 + 1 = 11111111 11111111 11111111 11111011

所以,-5 在計算機中表達為:11111111 11111111 11111111 11111011

二進位中的負數怎麼表示?

在二進位碼中,採用最高位是符號位的方法來區分正負數,正數的符號位為0、負數的符號位為1。剩下的就是這個數的絕對值部分。通過將負數轉為二進位原碼,再求其原百碼的反碼,最後求得的補碼即負數的二進位表示結果。

比如整數-1。先取1的原碼:00000000 00000000 00000000 00000001,得反碼: 11111111 11111111 11111111 11111110,最後得補碼: 11111111 11111111 11111111 11111111,即-1在計算機里用二進位表示結果

擴展資料:

二進位代碼語言程序員既要駕馭程序設計的全局又要深入每一個局部直到實現的細節,即使智力超群的程序員也常常會顧此失彼,屢出差錯,因而所編出的程序可靠性差,且開發周期長。

由於用二進位代碼語言進行程序設計的思維和表達方式與人們的習慣大相徑庭,只有經過較長時間職業訓練的程序員才能勝任,使得程序設計曲高和寡。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/258686.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-15 12:50
下一篇 2024-12-15 12:50

相關推薦

  • Python列表中負數的個數

    Python列表是一個有序的集合,可以存儲多個不同類型的元素。而負數是指小於0的整數。在Python列表中,我們想要找到負數的個數,可以通過以下幾個方面進行實現。 一、使用循環遍歷…

    編程 2025-04-29
  • PHP和Python哪個好找工作?

    PHP和Python都是非常流行的編程語言,它們被廣泛應用於不同領域的開發中。但是,在考慮擇業方向的時候,很多人都會有一個問題:PHP和Python哪個好找工作?這篇文章將從多個方…

    編程 2025-04-29
  • PHP怎麼接幣

    想要在自己的網站或應用中接受比特幣等加密貨幣的支付,就需要對該加密貨幣擁有一定的了解,並使用對應的API進行開發。本文將從多個方面詳細闡述如何使用PHP接受加密貨幣的支付。 一、環…

    編程 2025-04-29
  • 使用PHP foreach遍歷有相同屬性的值

    本篇文章將介紹如何使用PHP foreach遍歷具有相同屬性的值,並給出相應的代碼示例。 一、基礎概念 在講解如何使用PHP foreach遍歷有相同屬性的值之前,我們需要先了解幾…

    編程 2025-04-28
  • PHP獲取301跳轉後的地址

    本文將為大家介紹如何使用PHP獲取301跳轉後的地址。301重定向是什麼呢?當我們訪問一個網頁A,但是它已經被遷移到了另一個地址B,此時若伺服器端做了301重定向,那麼你的瀏覽器在…

    編程 2025-04-27
  • PHP登錄頁面代碼實現

    本文將從多個方面詳細闡述如何使用PHP編寫一個簡單的登錄頁面。 1. PHP登錄頁面基本架構 在PHP登錄頁面中,需要包含HTML表單,用戶在表單中輸入賬號密碼等信息,提交表單後服…

    編程 2025-04-27
  • PHP與Python的比較

    本文將會對PHP與Python進行比較和對比分析,包括語法特性、優缺點等方面。幫助讀者更好地理解和使用這兩種語言。 一、語法特性 PHP語法特性: <?php // 簡單的P…

    編程 2025-04-27
  • PHP版本管理工具phpenv詳解

    在PHP項目開發過程中,我們可能需要用到不同版本的PHP環境來試驗不同的功能或避免不同版本的兼容性問題。或者我們需要在同一台伺服器上同時運行多個不同版本的PHP語言。但是每次手動安…

    編程 2025-04-24
  • PHP數組去重詳解

    一、array_unique函數 array_unique是php中常用的數組去重函數,它基於值來判斷元素是否重複,具體使用方法如下: $array = array(‘a’, ‘b…

    編程 2025-04-24
  • PHP導出Excel文件

    一、PHP導出Excel文件列寬調整 當我們使用PHP導出Excel文件時,有時需要調整單元格的列寬。可以使用PHPExcel類庫中的setWidth方法來設置單元格的列寬。下面是…

    編程 2025-04-24

發表回復

登錄後才能評論