溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

c#位運(yùn)算的基本概念與計算過程

發(fā)布時間:2021-08-25 17:10:19 來源:億速云 閱讀:195 作者:chen 欄目:大數(shù)據(jù)

本篇內(nèi)容主要講解“c#位運(yùn)算的基本概念與計算過程”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“c#位運(yùn)算的基本概念與計算過程”吧!

前言

一些非?;A(chǔ)的東西,在實際工作中沒有用到、很少用到。一旦遇到,又不知所云。最近遇到一個問題,把一個int16(short) 、兩個bool變量整合成一個int32(int),當(dāng)聽到這個要求時,我第一反應(yīng)是不是需求弄錯了,后來才發(fā)現(xiàn)是自己才疏學(xué)淺,這里就需要位運(yùn)算相關(guān)的概念。
這里補(bǔ)充一下這幾個基本概念
位、字節(jié)、字符(英文字母)、漢字、KB、MB、GB、TB的關(guān)系
1.位:bit,也叫比特位,是計算機(jī)表示數(shù)據(jù)最小的單位,用二進(jìn)制0和1來存儲
2.字節(jié):byte,1byte(1B)=8b,一個字節(jié)=8位
3.字符:char,1char=2byte=16b,1個字符=2個字節(jié)=16位
4.KB,1KB=1024byte(1024B)
5.MB,1MB=1014KB
6.GB,1GB=1024MB
7TB,1TB=1024GB
一個漢字占兩個字節(jié),也就是16位,一篇1000字的文章,大概就是16*1000 個二進(jìn)制的0或1 。
一個10M的短視頻,也就是10M=1024KB*10=1024字節(jié)*10*10=1024位*8*10*10
大概就是919200個二進(jìn)制的0和1了
short 是16位,int是32位,long是64位

1.什么是位運(yùn)算

在掌握位運(yùn)算之前,應(yīng)該清楚什么是位運(yùn)算?什么樣的數(shù)據(jù)類型可以進(jìn)行位運(yùn)算?云運(yùn)算的結(jié)果是什么?
1.位運(yùn)算的對象是int 、char 類型,簡而言之就是對二進(jìn)制的1101(13)進(jìn)行運(yùn)算
2.位運(yùn)算的結(jié)果是整型

符號意義運(yùn)算對象類型運(yùn)算結(jié)果類型示例
~邏輯非運(yùn)算整型、char整型~a
&邏輯與運(yùn)算a&b
|邏輯或運(yùn)算a|b
<<位左移運(yùn)算a<<2
>>位右移運(yùn)算a>>2

2.位邏輯與運(yùn)算

&與運(yùn)算是將兩個運(yùn)算對象按位于進(jìn)行與運(yùn)算。
規(guī)則是:
1&1=1
0&1=0
0&0=0
如圖:
c#位運(yùn)算的基本概念與計算過程
15的二進(jìn)制是0000 1111
20的二進(jìn)制是0001 0100
15&20的結(jié)果就是0000 0100 即結(jié)果是4

3.位邏輯或運(yùn)算

c#位運(yùn)算的基本概念與計算過程
|位邏輯或運(yùn)算是將兩個運(yùn)算對象按位進(jìn)行或運(yùn)算,運(yùn)算的規(guī)則是
1|1=1
1|0=1
0|0=0
如15|20的結(jié)果計算結(jié)果就是31 即二進(jìn)制0001 1111
0000 1111(15的二進(jìn)制) | 0001 0100(20的二進(jìn)制)= 0001 1111結(jié)果是31

4.位邏輯異或運(yùn)算

c#位運(yùn)算的基本概念與計算過程
^ 位邏輯異或運(yùn)算 是將兩個運(yùn)算對象按位進(jìn)行異或運(yùn)算,規(guī)則是:
1異或1等于0
1異或0等于1
0異或0等于0
即:相同得0,相異得1。
0000 1111 ^ 0001 0100= 0001 1011結(jié)果是27

5.位邏輯左移運(yùn)算

c#位運(yùn)算的基本概念與計算過程
位邏輯左移運(yùn)算是將按位向左邊移動若干位,左移后空出的部分為0
比如15的二進(jìn)制0000 1111 左移8位就是1111 0000 0000(15<<8)結(jié)果是3840
左移3位(15<<3)就是0111 1000結(jié)果是120
左移就是相當(dāng)于乘,左移1位就是相當(dāng)于乘以2的1次方,左移3位就是相當(dāng)于乘以2的3次方,左移8位就是相當(dāng)于乘以2的8次方
a<<1 =a乘以2的1次方
a<<2 =a乘以2的2次方
a<<3 =a乘以2的3次方

6.位邏輯右移運(yùn)算

c#位運(yùn)算的基本概念與計算過程
位邏輯右移運(yùn)算是將按位向右邊移動若干位,右移后空出的部分為0
比如0000 1111(15)左移3位(15<<3)就是0000 0001(1)
右移相當(dāng)于整除,右移1位相當(dāng)于除以2的1次方,右移2相當(dāng)于除以2的2次方。
a>>1 = a整除2的1次方
a>>2 = a整除2的2次方
a>>3 = a整除2的3次方

7.位運(yùn)算的作用

如將一個月的簽到記錄保存到1個int類型中、權(quán)限設(shè)置、將4個short合并成一個long類型,16個bool類型合并成1個short。
如這個問題所示
需求:C# 用兩個short,一個int32拼成一個long型
要求:現(xiàn)在有兩個short和一個int,需要拼成一個long型,高16位用short,中間32位用int,最低16位用另外一個short
https://bbs.csdn.net/topics/392202825?page=1
做法就是:
((long)shortA << 48 )+ ((long)intA << 16)+ shortB=longResult
講解:
高16位的shortA先左移48,那么longResult 64位的最左邊16位(高16位)就是shortA
中間32位intA 就是先將intA左移16位,那么這個longResult的中間32位就是intA
低16位就是最后剩下的16位用shortB。
那么疑問來了可以通過longResult返推出shortA,shortB,intA。當(dāng)然是不能這是直接相加。
返回不應(yīng)該用這種組合字符串的方式
((long)shortA << 48 ) 16位二進(jìn)制0或1的字符串
((long)intA << 16) 32位二進(jìn)制0或1的字符串
shortB 16位二進(jìn)制0或1的字符串
將這三個字符串拼接成64位二進(jìn)制字符串,再將這個64位二進(jìn)制字符串轉(zhuǎn)成一個long。

到此,相信大家對“c#位運(yùn)算的基本概念與計算過程”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI