【C語言極簡自學筆記】重講運算符

一、算術操作符

算術操作符描述
+把兩個操作數相加
-第一個操作數減去第二個操作數
*把兩個操作數相乘
/分子除以分母
%取模運算符,整除后的余數

注意:1.除號的兩端都是整數的時候執行的是整數的除法,兩端只要有一個浮點數,就執行浮點數? ? ? ? ? ? ? ? 的除法;
? ? ? ? ? ?2.%取模兩端必須為整數?。

二、移位操作符

1.左移位操作符<<

規則:左邊拋棄,右邊補0

?由于在計算機中存儲的數為二進制的補碼,正數的原碼、反碼、補碼均一致,負數的補碼等于反碼加一

則7的原碼、補碼、反碼為:00000000000000000000000000000111

經過左移一位之后的結果為:000000000000000000000000000001110

即為十進制數14

若操作數為負數

?-7的原碼為:10000000000000000000000000000111

反碼為:11111111111111111111111111111000

補碼為:11111111111111111111111111111001

左移一位后的結果為:11111111111111111111111111110010

原碼為:10000000000000000000000000001110,即十進制數-14

2.右移操作符>>

右移操作符分為兩種①:算術移位:右邊拋棄,左邊補原值符號位

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ②:邏輯移位:右邊拋棄,左邊補0

一般編譯器均為算術移位

-7的補碼為:11111111111111111111111111111001?
右移一位后的結果為:11111111111111111111111111111100
原碼為:10000000000000000000000000000100,即十進制數-4

7的原碼、補碼、反碼為:00000000000000000000000000000111
右移一位后的結果為:?00000000000000000000000000000011,即十進制數3

?三、位操作符

位操作符主要分為三類:

&:按(二進制)位與

|:按(二進制)位或

^:按(二進制)位異或

注意???:操作數均為整數

原理:通過存儲在計算機中的二進制數進行按位操作,若操作數為正數,則直接輸出其對應的數值;若操作數為負數,則求得其對應的原碼所代表的數值后輸出。

int main()
{int a = 3;//a的補碼  00000000000000000000000000000011int b = -5;//b的原碼  10000000000000000000000000000101//b的反碼  11111111111111111111111111111010//b的補碼  11111111111111111111111111111011int c = a & b;printf("c = %d\n",c);//a和b的補碼按位與結果:00000000000000000000000000000011    即十進制數3int d = a | b;printf("d = %d\n", d);//a和b的補碼按位或結果:11111111111111111111111111111011//反碼為:11111111111111111111111111111010//原碼為:10000000000000000000000000000101  即十進制數 -5int e = a ^ b;printf("e = %d\n", e);//a和b的補碼按位異或結果:11111111111111111111111111111000//反碼為:11111111111111111111111111110111//原碼為:10000000000000000000000000001000   即十進制數 -8return 0;
}

四、賦值操作符

運算符描述
=賦值運算符,把右邊操作數的值賦給左邊操作數
+=加且賦值運算符,把右邊操作數加上左邊操作數的結果賦值給左邊操作數
-=減且賦值運算符,把左邊操作數減去右邊操作數的結果賦值給左邊操作數
*=乘且賦值運算符,把右邊操作數乘以左邊操作數的結果賦值給左邊操作數
/=除且賦值運算符,把左邊操作數除以右邊操作數的結果賦值給左邊操作數
%=求模且賦值運算符,求兩個操作數的模賦值給左邊操作數
<<=左移且賦值運算符
>>=右移且賦值運算符
&=按位與且賦值運算符
^=按位異或且賦值運算符
|=按位或且賦值運算符

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

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

相關文章

持續集成 CI/CD-Jenkins持續集成GitLab項目打包docker鏡像推送k8s集群并部署至rancher

Jenkins持續集成GitLab項目 GitLab提交分支后觸發Jenkis任務 之前是通過jar包在shell服務器上進行手動部署&#xff0c;麻煩且耗時。現通過Jenkins進行持續集成實現CI/CD。以test分支為例 提交即部署。 由于是根據自己實際使用過程 具體使用到了 gitlabjenkinsdockerharborra…

Apache Iceberg與Hive集成:非分區表篇

引言 在大數據處理領域&#xff0c;Apache Iceberg憑借其先進的表格式設計&#xff0c;為大規模數據分析帶來了新的可能。當Iceberg與Hive集成時&#xff0c;這種強強聯合為數據管理與分析流程提供了更高的靈活性和效率。本文將聚焦于Iceberg與Hive集成中的非分區表場景&#…

webpack 如何區分開發環境和生產環境

第一種方法: 方法出處&#xff1a;命令行接口&#xff08;CLI&#xff09; | webpack 中文文檔 1.利用webpack.config.js 返回的是個函數&#xff0c;利用函數的參數&#xff0c;來區分環境 具體步驟 1&#xff09; package.json文件&#xff1a;在npm scripts 命令后面追加 …

React組件通信——context(提供者/消費者)

Context 是 React 提供的一種組件間通信方式&#xff0c;主要用于解決跨層級組件 props 傳遞的問題。它允許數據在組件樹中"跨級"傳遞&#xff0c;無需顯式地通過每一層 props 向下傳遞。 一、Context 核心概念 1. 基本組成 React.createContext&#xff1a;創建 C…

“微信短劇小程序開發指南:從架構設計到上線“

1. 引言&#xff1a;短劇市場的機遇與挑戰 近年來&#xff0c;短視頻和微短劇市場呈現爆發式增長&#xff0c;用戶碎片化娛樂需求激增。短劇小程序憑借輕量化、社交傳播快、變現能力強等特點&#xff0c;成為內容創業的新風口。然而&#xff0c;開發一個穩定、流暢且具備商業價…

RPC與RESTful對比:兩種API設計風格的核心差異與實踐選擇

# RPC與RESTful對比&#xff1a;兩種API設計風格的核心差異與實踐選擇 ## 一、架構哲學與設計目標差異 1. **RPC&#xff08;Remote Procedure Call&#xff09;** - **核心思想**&#xff1a;將遠程服務調用偽裝成本地方法調用&#xff08;方法導向&#xff09; - 典型行為…

【pytest進階】pytest之鉤子函數

什么是 hook (鉤子)函數 經常會聽到鉤子函數(hook function)這個概念,最近在看目標檢測開源框架mmdetection,里面也出現大量Hook的編程方式,那到底什么是hook?hook的作用是什么? what is hook ?鉤子hook,顧名思義,可以理解是一個掛鉤,作用是有需要的時候掛一個東西…

深度學習計算——動手學深度學習5

環境&#xff1a;PyCharm python3.8 1. 層和塊 塊&#xff08;block&#xff09;可以描述 單個層、由多個層組成的組件或整個模型本身。 使用塊進行抽象的好處&#xff1a; 可將塊組合成更大的組件(這一過程通常是遞歸) 如 圖5.1.1所示。通過定義代碼來按需生成任意復雜度…

NodeJS的fs模塊的readFile和createReadStream區別以及常見方法

Node.js 本身沒有像 Java 那樣嚴格區分字符流和字節流&#xff0c;區別主要靠編碼&#xff08;encoding&#xff09;來控制數據是以 Buffer&#xff08;二進制字節&#xff09;形式還是字符串&#xff08;字符&#xff09;形式處理。 詳細解釋&#xff1a; 方面JavaNode.js字節…

基于二進制XOR運算的機器人運動軌跡與對稱圖像自動生成算法

原創&#xff1a;項道德&#xff08;daode3056,daode1212&#xff09; 新的算法出現&#xff0c;往往能給某些行業與產業帶來革命與突破。為探索機器人運動軌跡與對稱圖像自動生成算法&#xff0c;本人已經通過18種算法的測試&#xff0c;最終&#xff0c;以二進制的XOR運算為…

Spring AI 項目實戰(七):Spring Boot + Spring AI Tools + DeepSeek 智能工具平臺(附完整源碼)

系列文章 序號文章名稱1Spring AI 項目實戰(一):Spring AI 核心模塊入門2Spring AI 項目實戰(二):Spring Boot + AI + DeepSeek 深度實戰(附完整源碼)3Spring AI 項目實戰(三):Spring Boot + AI + DeepSeek 打造智能客服系統(附完整源碼)4Spring AI 項目實戰(四…

spring-webmvc @RequestHeader 典型用法

典型用法 基礎用法&#xff1a;獲取指定請求頭值 GetMapping("/info") public String getInfo(RequestHeader("User-Agent") String userAgent) {return "User-Agent: " userAgent; }如果請求中包含 User-Agent 請求頭&#xff0c;則其值將被…

Ubuntu:20.04中安裝docker

是的&#xff0c;您列出的命令是完整的安裝步驟&#xff0c;但為了確保100%可靠性和處理可能的問題&#xff0c;我建議進行以下優化和補充&#xff1a; 完整優化的安裝腳本&#xff08;包含錯誤處理和驗證&#xff09; #!/bin/bash# 1. 徹底清理舊版本和配置 sudo apt remove…

大數據實時風控引擎:Spark Streaming、Kafka、Flink與Doris的融合實踐

大數據實時風控引擎&#xff1a;Spark Streaming、Kafka、Flink與Doris的融合實踐 在數字金融、電商交易與在線服務的核心戰場&#xff0c;風險控制能力已成為業務的生命線。傳統批量風控模式在應對瞬息萬變的欺詐攻擊、信用風險時捉襟見肘。本文將深入探討如何利用**Spark St…

【創龍瑞芯微 RK3576 全國產 ARM 八核 2.2GHz 工業開發板-硬件說明書】

前 言 本文主要介紹TL3576-EVM評估板硬件接口資源以及設計注意事項等內容。 RK3576J/RK3576處理器的IO電平標準一般為1.8V、3.3V,上拉電源一般不超過3.3V或1.8V,當外接信號電平與IO電平不匹配時,中間需增加電平轉換芯片或信號隔離芯片。按鍵或接口需考慮ESD設計,ESD器件…

一文吃透ADB,從入門到精通

目錄 一、ADB 簡介1.1 什么是 ADB1.2 ADB 的工作原理1.3 ADB 的安裝與環境配置 二、ADB 基礎命令2.1 設備連接相關命令2.2 應用管理命令2.3 文件傳輸命令 三、ADB 高級命令3.1 ADB Shell 深入探究3.2 日志查看與分析3.3 設備信息獲取3.4 屏幕操作與錄制 四、ADB 常見問題與解決…

PostgreSQL高可用架構設計與實踐指南

# PostgreSQL高可用架構設計與實踐指南 ## 一、高可用性核心訴求 PostgreSQL作為企業級關系型數據庫&#xff0c;高可用設計需要滿足以下關鍵指標&#xff1a; - 故障恢復時間&#xff08;RTO&#xff09;&#xff1a;秒級到分鐘級自動切換能力 - 數據損失容忍度&#xff0…

今天我想清楚了

首先說一聲抱歉&#xff0c;很多天沒有更新了&#xff0c;因為在我這里&#xff0c;我的內心感到迷茫&#xff0c;從來沒有這樣過&#xff0c;不知道為什么自己一直要做的事&#xff0c;進度太慢了&#xff0c;因為我的人生是空虛的&#xff0c;我感覺我做的不夠好&#xff0c;…

代碼隨想錄day3鏈表1

new關鍵字 1.new是一個關鍵字&#xff0c;用于開辟空間&#xff0c;開辟的空間在堆上&#xff0c;而一般聲明的變量存放在棧上&#xff1b; 2.new得到的是一段空間的首地址。所以一般需要用指針來存放這段地址 new int(10);//返回new出來這塊內存的地址int *pnew int(10);//…

taro小程序如何實現新用戶引導功能?

一、需求背景 1、需要實現小程序新功能引導 2、不使用第三方庫&#xff08;第三方組件試了幾個&#xff0c;都是各種兼容性問題&#xff0c;放棄&#xff09; 二、實現步驟 1、寫一個公共的guide組件&#xff0c;代碼如下 components/Guide/index.tsx文件 import React, { …