C語言【運算符】

来源:https://www.cnblogs.com/wangsiyaoa/archive/2023/11/17/17839686.html
-Advertisement-
Play Games

C++ 指針學習筆記 引入 指針是什麼 指針是一個變數,其值為另一個變數的地址。 指針聲明的一般形式為: type *ptr_name; type 是指針的基類型,ptr_name 是指針的名稱,* 用來指定一個變數是指針 對於一個指針,需要明確四個方面的內容:指針的類型、指針所指向的類型、指針的值 ...


C語言【運算符、分支控制語句】

1、運算符分類
  • 按照操作個數分類:

    一元運算符(一目運算符):只有一個操作數。如 負號 -1。

    二元運算符(二目運算符):有兩個操作數。如 加號 1+2。

    三元運算符(三目運算符):有三個操作數。如 ?: a>b?1:2。

  • 按功能分類:

    算數運算符:正(+)、負(-)、加(+)、減(-)、乘(*)、除(/)、取模(%)、自增(++)、自減(--)。

    賦值運算符:賦值(=)、相加賦值(+=)、相減賦值(-=)、相乘賦值(*=)、相除賦值(/=)、取餘賦值(%=)、左移賦值(<<=)、右移賦值(>>=)、按位與賦值(&=)、按位異或賦值(^=)、按位或賦值(|=)。

    int te = 0;
    // if里是賦值
    if(te = 0){     		// te=0 的結果為所賦的0
    	printf("abcdefg");	// 不會執行
    }
    
    // 連續賦值
    int a = b = c = 6;	// 從右往左賦值,a、b、c都為6
    
    // 相乘賦值+連續賦值
    int a = 2;
    int c; 	// 下麵中間那個c得提前定義。
    int b = c = a*=3;  	// a、b、c都為6
    

    ​ 賦值運算符一般是從右往左運算。運算方向是當表達式中出現多個該運算符時每個運算符的操作順序。

    關係運算符:相等(==)、不等(!=)、小於(<)、大於(>)、小於等於(<=)、大於等於(>=)。

    ​ 關係運算符的結果為0或1

    邏輯運算符:邏輯與(&&)、邏輯或(||)、邏輯非(!)

    ​ 邏輯與(&&)也叫短路與,如果&&前面的表達式為0時,後面的表達式不作運算,直接返回為0;

    ​ 邏輯或(||)也叫短路或,如果||前面的表達式為1時,後面的表達式不作運算,直接返回1。

    ​ 在表達式前加邏輯非時記得給表達式加括弧。

    ​ 邏輯運算符的結果為0或1

    位運算符:按位與(&)、按位或(|)、按位異或(^)、按位取反(~)、按位左移(<<)、按位右移(>>)

    左移n位就相當於乘2的n次方右移n位就相當於除以2的n次方

    int a = 10;
     a >> 3;		// a不發生改變,因為沒有再賦值給a
    
    int b = 10;
    b = b >> 3; 	// b在原來的基礎上縮小了2的3次方。 10 / 3 = 1
    
    int y = -10;
    y = y >> 2;
    printf("%d\n", y);		// -3        
    //   -10 / 4 = -2...-2     把商的-2退為-3, 即 -10 / 4 = -3...2
    

    負整數的除法和右移操作結果並不一樣,如下:

    int z = -10 / 4;
    printf("%d\n", z);	// -2
    

    左移時出現的溢出問題:左移時,會出現結果大過所接收值類型範圍導致溢出。

    // 第一種情況,如果只關心輸出結果,而不關心是不是在類型範圍內,可以在輸出時使用大格式,把超出的看作有效
    int num_max = 0x7fffffff;
    num_max  = num_max<<2;   	// 乘4,已經超過了int能表示的範圍
    printf("%lld", num_max);  	// 輸出時使用 %lld 把超出的範圍也視作有效
    
    // 第二種情況,就是想知道溢出後在有效範圍內為多少,也就是這個數的實際值,可以看作對類型能表示的個數取餘
    int num_max = 0x7fffffff;
    num_max  = num_max<<2;   	// 實際結果8589934588,超了。 8589934588 % int能表示的個數(4294967296) = 4294967292。   num_max類型為有符號int, 4294967292最高位為1,轉換為原碼為-4,所以num_max為-4。在記憶體種這32位里存的就是4294967292的二進位形式。
    printf("%d", num_max);  	//  %d 表示有符號int, 4294967292最高位為1,轉換為原碼為-4,輸出-4
    

     有符號數右移時,對於負數,前面空出來的位全補1;對於正數,前面空出來的位全補0。

    遺留問題:按位異或可以實現交換兩個變數的值,如何實現的?原理是什麼?

2、運算符的優先順序

​ 具體的不作瞭解,使用時不確定就用括弧。

​ 總體來說:一元運算符 > 算數運算符 > 關係運算符 > 邏輯運算符 > 三元運算符 > 賦值運算符

從右到左運算是指同一表達式出現多次同一運算符時,運算的方向。

​ 右到左的運算符有: todo

3、記幾個整型和浮點型之間的運算。
// 整型的除法運算
int num01 = 10;
int num02 = 3;
int num03 = num01 / num02;	// 3
// 浮點型接收整型的運算
float num04 = 10 / 3;	// 斷點調試此處為3, printf用%f輸出時記得補6位小數

問題:上行代碼的num04如果用%f輸出是3.000000,如果用%d輸出呢?我試了試是0。為什麼?

// 浮點型與整型的運算
float num05 = (float)10 / 3;	// 3.33333325
printf("%f\n", num05);		// printf用%f輸出時保留6位小數為3.333333
// 浮點數參與的運算其實是四捨五入的,手動保留小數時也是四捨五入
float num06 = (float)20 / 3; 	//     6.66666651
printf("%f\n", num05);		// 6.666667
4、取餘(%)操作時,餘數的符號跟著被除數(前面的數)的符號。
5、關於自增(++)和 自減(--)

​ 不多解釋,舉個特別的例子。

/**
	i=i++時
	第一步:將i的值放到臨時空間,作為後續運算的依據
	第二步:將i的值+1
	第三步:將臨時空間里存進去的值拿出來賦給i (如果是j=i++時這一步就是賦給j)
*/
int i = 1;
i = i++;
printf("%d\n", i);	 // 1
/**
	i = ++i時
	不多解釋,上面步驟 二、一、三
*/
int i = 1;
i = ++i;
printf("%d\n", i);	// 2

註意:以上這兩種情況在gcc可以編譯通過,在clang編譯器編譯時就會報錯。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、項目背景 公司和第三方合作開發一個感測器項目,想要通過電腦或者手機去控制項目現場的感測器控制情況。現在的最大問題在於,現場的邊緣終端設備接入的公網方式是無線接入,無法獲取固定IP,所以常規的HTTP協議通信就沒法做,現在打算使用MQTT來實現雲平臺和邊緣終端(感測器)之間的雙向通信。 二、術語定 ...
  • 一個有必要實現的需求 因為項目中需要使用canvasTexture(一個threejs3d引擎中的材質類型),繪製大量的圖片,每次使用都會請求大量的oss圖片資源,雖然重覆請求會有磁碟緩存但畢竟這個磁碟緩存時效過短, 這裡需要瞭解一下知識才能正常閱讀。 Transferable objects ht ...
  • 遇到的問題:將長度為40的數組數據賦值<el-table></el-table>,我發現loading沒有效果,後面發現是頁面卡住了,loading直接沒有出現。 經過查詢資料,發現<el-table>會有卡頓的問題,看到有的博主推薦使用一款叫umy-ui的插件,我就試了試,發現卡頓的問題解決了。 ...
  • 由於我司的業務特性,需要 APP 能夠支持即時在無網路的場景下,也能夠正常使用 APP 的功能 那麼,為了讓一個用 web 前端實現的 APP 能夠在無網路的場景下,也能夠正常運行程式,這其中的離線方案就需要實現幾個關鍵點: 代碼的離線、更新 數據的下載、上傳、更新 本篇就想來講一講,我們在離線應用 ...
  • 微服務架構可以更快地推出新產品,幫助產品更輕鬆地擴展,並更好地響應客戶需求。憑藉多種現代數據模型、在任何情況下的容錯性、用於隔離的多租戶功能以及在多個環境中部署的靈活性,Redis Enterprise 使開發人員和運營商能夠針對微服務架構優化他們的數據層。 ...
  • Java解析上傳的zip文件--包含Excel解析與圖片上傳 前言:今天遇到一個需求:上傳一個zip格式的壓縮文件,該zip中包含人員信息的excel以及excel中每行對應的人的圖片,現在需要將該zip壓縮包中所有內容解析導入到資料庫中,包括圖片,並將圖片與excel內容對應。 代碼演示: /** ...
  • 十一、指針和引用(一) 1、指針 1)思考 ​ 在電腦程式中,有一條鐵律那就是萬物皆內粗,而我們知道,記憶體就是一個個小格,存放著高電平或者低電平,也就是0或者1,我們要表達的一切都是通過這種二進位的方式放到記憶體中,當我們讀取、寫入,其實局勢在對應的記憶體空間執行讀或者寫操作 ​ 我們今天就研究研究, ...
  • 反面單例 代碼 import java.util.ArrayList; import java.util.List; /** * @since : 2023/11/17 **/ public class StupidSingleton { private static final StupidSin ...
一周排行
    -Advertisement-
    Play Games
  • 1、預覽地址:http://139.155.137.144:9012 2、qq群:801913255 一、前言 隨著網路的發展,企業對於信息系統數據的保密工作愈發重視,不同身份、角色對於數據的訪問許可權都應該大相徑庭。 列如 1、不同登錄人員對一個數據列表的可見度是不一樣的,如數據列、數據行、數據按鈕 ...
  • 前言 上一篇文章寫瞭如何使用RabbitMQ做個簡單的發送郵件項目,然後評論也是比較多,也是準備去學習一下如何確保RabbitMQ的消息可靠性,但是由於時間原因,先來說說設計模式中的簡單工廠模式吧! 在瞭解簡單工廠模式之前,我們要知道C#是一款面向對象的高級程式語言。它有3大特性,封裝、繼承、多態。 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 介紹 Nodify是一個WPF基於節點的編輯器控制項,其中包含一系列節點、連接和連接器組件,旨在簡化構建基於節點的工具的過程 ...
  • 創建一個webapi項目做測試使用。 創建新控制器,搭建一個基礎框架,包括獲取當天日期、wiki的請求地址等 創建一個Http請求幫助類以及方法,用於獲取指定URL的信息 使用http請求訪問指定url,先運行一下,看看返回的內容。內容如圖右邊所示,實際上是一個Json數據。我們主要解析 大事記 部 ...
  • 最近在不少自媒體上看到有關.NET與C#的資訊與評價,感覺大家對.NET與C#還是不太瞭解,尤其是對2016年6月發佈的跨平臺.NET Core 1.0,更是知之甚少。在考慮一番之後,還是決定寫點東西總結一下,也回顧一下.NET的發展歷史。 首先,你沒看錯,.NET是跨平臺的,可以在Windows、 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 添加節點(nodes) 通過上一篇我們已經創建好了編輯器實例現在我們為編輯器添加一個節點 添加model和viewmode ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...
  • 類型檢查和轉換:當你需要檢查對象是否為特定類型,並且希望在同一時間內將其轉換為那個類型時,模式匹配提供了一種更簡潔的方式來完成這一任務,避免了使用傳統的as和is操作符後還需要進行額外的null檢查。 複雜條件邏輯:在處理複雜的條件邏輯時,特別是涉及到多個條件和類型的情況下,使用模式匹配可以使代碼更 ...
  • 在日常開發中,我們經常需要和文件打交道,特別是桌面開發,有時候就會需要載入大批量的文件,而且可能還會存在部分文件缺失的情況,那麼如何才能快速的判斷文件是否存在呢?如果處理不當的,且文件數量比較多的時候,可能會造成卡頓等情況,進而影響程式的使用體驗。今天就以一個簡單的小例子,簡述兩種不同的判斷文件是否... ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...