
前言
運算子
- 前言
- 一.算術運算子
- 1. 基本的算術運算子
- 2.自增運算子和自減運算子
- 二.移位運算子
- 左移位運算子規則:
- 右移運算子的規則:
- 位運算子
- 三. sizeof運算子
- 四.邏輯運算子
- 五.逗號運算式
- 六. 整形提升
- 七.自動型別轉換
一.算術運算子

1. 基本的算術運算子
1.除了% 意外,其他的運算子都可以作用于整數或浮點數
- / 只要有一個運算元為浮點數,那么進行的是浮點數運算,
如果進行除運算的兩個數為是整數,則運算結果為整數,小數部分被舍棄


3.% 作用的兩個數必須為整數,得出的余數也為整數,當參與模的運算的兩個整數的正負號不同時,運算結果的符號與被除數相同,
如

2.自增運算子和自減運算子

前置++或-- 是先把變數+1或-1,再使用
后置++ 或-- 是先使用變數,再+1或-1

二.移位運算子

左移位運算子規則:
a.左邊去除,右邊補0
b.左移n位實際就是把原數乘以2的n次方

右移運算子的規則:
1.無符號數進行右移操作時,高位補0,稱為邏輯右移
2.有符號位進行右移時,高位補符號位(符號為1就補1,為0就補0),稱為算術右移(對于有符號位來說,最左邊為符號位,1表示負數,0表正數)
3.右移就是把左邊的運算元個二進制位全部右移若干位,右移n位,實際是除以2的n次方
算術右移

邏輯右移:

注意:
對于位運算子中,不要移動負數位,這是標準未定義的,例如:
int num=10;
num>>-1;//這是錯誤的
位運算子
位的運算子有

注意:它們的運算元只作用于整數
&(按位與):兩個運算元對應的二進制位都是1時,結果為1

|(按位或):兩個運算元對應的二進制位中有一個是1,結果就為1;
^(按位異或): 兩個運算元對應的二進制位相同,結果就為0,不同為1;

~(取反):運算元每個二進制位都取反,即0變為1,1變為0

面試題:
不能創建臨時變數(第三個變數),實作兩個數的交換,
決議:當兩個相同的數異或為0,0異或一個數為該數的值
如



練習:
撰寫代碼實作:求一個整數存盤在記憶體中的二進制中1的個數,
三. sizeof運算子
sizeof(運算物件)
該運算子是獲得運算物件占用的記憶體空間的位元組數,結果是整數型別,
運算物件可以是資料型別關鍵字,常量,變數,運算式


問:
(1)、(2)兩個地方分別輸出多少?
(3)、(4)兩個地方分別輸出多少?

四.邏輯運算子

! 邏輯反操作

&& 邏輯與,兩邊的的值或運算式為真則為真

|| 邏輯或,兩邊的值或運算式中有一個為真則為真

筆試題




五.逗號運算式
從左到右的順序依次計算各個運算式的值
x=5+3,5-3 //運算式運算后,運算式的值是2,變數x的值為8
x=(5+3,5-3) // 該運算式是賦值運算式,將逗號運算式的結果2賦值給變數x
int a = 1;
int b = 2;
int c = (a>b, a=b+10, a, b=a+1);
c是多少?
答案; 13
六. 整形提升
運算式中的字符和短整型都需要將它轉換為為整形后才能運算,也就是char型別和short int轉換為 int
負數的整形提升
char c1 = -1;
變數c1的二進制位(補碼)中只有8個位元位:
1111111
因為 char 為有符號的 char
所以整形提升的時候,高位補充符號位,即為1
提升之后的結果是:
11111111111111111111111111111111
正數的整形提升
char c2 = 1;
變數c2的二進制位(補碼)中只有8個位元位:
00000001
因為 char 為有符號的 char
所以整形提升的時候,高位補充符號位,即為0
提升之后的結果是:
00000000000000000000000000000001
無符號整形提升,高位補0
我們先來看一道題

答案式: -126

七.自動型別轉換
如果有兩個不同型別的運算元進行雙目運算時,則需要把其中的一個或兩個進行轉換型別
long double >double> float> unsigned long> long>ungsigned int > int
如果存在long double,則需要把另一個變為 long double型別,否則就是double 以此類推 ,如果以上都沒有,則兩個數都轉換為int
轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/280378.html
標籤:其他



