變數 + 數據類型

来源:https://www.cnblogs.com/Mr-shne/archive/2022/10/04/16716463.html
-Advertisement-
Play Games

變數: 什麼是變數?一個可以存儲數據(存儲的地方在記憶體中),並可以在代碼的運行中,給與數據的改變 註意:變數的聲明必須在最前面 語法:數據類型 變數名稱 = 值; 案例: %d - 輸出一個整數 %.2f - 輸出一個小數(2代表的是小數位,可以改變) %c - 輸出一個字元 %s - 輸出一個字元 ...


變數:

  • 什麼是變數?一個可以存儲數據(存儲的地方在記憶體中),並可以在代碼的運行中,給與數據的改變
  • 註意:變數的聲明必須在最前面
  • 語法:數據類型 變數名稱 = 值;
  • 案例:
  • %d - 輸出一個整數   %.2f - 輸出一個小數(2代表的是小數位,可以改變)
  • %c - 輸出一個字元   %s - 輸出一個字元串
  • //引入頭文件
    #include <stdio.h>
    void main(){
        int num = 1;  //給num變數賦值1
        double score = 2.3;
        char gendr = 'A';
        char name[] = "我是字元串";  
        //註意:改被值的內容,要放到所有變數聲明的後面
         //因為c語言的變數聲明必須在最前面,num = 2已經不是變數聲明
        num = 2; //改變a變數值
    
        printf("num=%d score=%.2f gendr=%c name=%s",num,score,gendr,name);
    
        getchar();//讓視窗停留(cmd視窗)
    
    }
  • 記憶體分析:

    • 不同的變數,改成(不同的數據)  - 畫圖時搞錯  
  • 細節:

    • 變數表示記憶體中的一個存儲區域,(不同的數據類型,占空間也不一樣)
    • 變數必先聲明,後使用
    • 變數名,在同一個作用域不能重名
    • 同一類型,並同一區域的變數,可以不斷變化(不遵守,可能導致數據丟失)  

 數據類型:

  • 什麼是數據類型?用來表示一個數據是什麼類型,併在記憶體中分配對應的類型空間大小,不同的類型分配的記憶體大小也不一樣
  • 有哪些數據類型? - 記下來 
    • 註意:在C語言中沒有字元串類型,用字元數組表示字元串
    • 在不同的系統上,部分的數據類型長度不一樣,如int可能是2或4      
  • 整數類型:

    • 整數類型的作用? 用來存放整數,負整數和正整數都可以,但不同的整數可以存放的值範圍也不同
      • 如:int 在系統上是2個位元組值範圍就是:-32768到32767 (如果超過該值,就會出現越界的問題,導致數據混亂)
      • 如:int在系統上是4個位元組值範圍就是:-214483648到2147483647
    • 為什麼會同樣是int分2個位元組和4個位元組?
      • 因為跟操作系統、系統位數、編譯器有關   
    • C語言的數據類分有符號和無符號?
      • 有符號 sigend int  - 等價於int - C語言預設是帶符號 - 其它數據類型也分有無符號,不止是int類型有
      • 無符號  unsigned int - 值範圍 - 0到65636 - 占2個位元組
      • 區別:
        • 值範圍不同,主要原因底層二進位分析不同       
    • 案例: 
    • #include <stdio.h>
      void main(){    int i = 2147483647;
          signed int j = 2147483648; //越界
          unsigned int q = 999999655351; //越界
          printf("int的位元組數=%d\n",sizeof(int));
          printf("i=%d j=%d q=%d",i,j,q);
      
          getchar();//讓視窗停留(cmd視窗)
      
      }
    • 整數類型細節:
      • C程式中整數說明一般用int型,不夠在使用long或者long long
        • long的輸出是 %ld 
        • long long的輸出是 %lld
      • bit(位):電腦中最小的存儲單位
      • byte(位元組):電腦中基本的存儲單位
      • 1byte=8bit
  • 浮點類型:

    • 浮點數的作用?用來表示一個小數,如:123.1,99.9等
    • 浮點數又分兩個精度?
      • float-單精度:存儲大小(4給位元組),值範圍1.2E-38到3.4E+38,精度是6位小數(是點後面的數)
      • double-雙精度:存儲大小(8個位元組),值範圍2.3E-308到1.7+308,精度是15位小數(是點後面的數)
    • 浮點類型細節:
      • 浮點型常量預設為double型,聲明float型常量時,必須加‘F’或'f'
        • float i = 1.1; - 就算這樣聲明其實也double型,必須是 float i = 1.1f;才是float型
        • 不然會有這麼一句話:“初始化”: 從“double”到“float”截斷
      • 浮點型有兩種表達形式:    
        • 十進位:如:5.12、5.20 
        • 科學計數法:如:5.12e2 、5.12E-2  
      • 通常情況下用double型,因為精度比float高
        • double可以輸出15位小數,float6位,如果超過小數會數據混亂  
      • 輸出浮點型時預設小數保存6位
    • //引入頭文件
      #include <stdio.h>
      void main(){
          float a = 10.1; //“初始化”: 從“double”到“float”截斷
          float a2 = 10.2f;
          double b = 10.2;
          double b2 = .521;//等價於0.521
      
          double c = 5.21e2;//等價5.12*(10^2) = 521
          double c2 = 5.21e-2;//等價5.12*(10^-2)= 5.12/100= 0.0521
      
          printf("b=%.15f b2=%f",b,b2);//輸出預設保存6位小數,.15是15位小數
      
          getchar();
      }
  • 布爾類型:

    • 布爾類型作用? 代表真(true)和假(false),一般使用場景條件控制(if),迴圈控制(while)
    • C語言(C89)沒有定義布爾型,通過0代表假,非0代表真的(負整數也算)
      • 因為是數字表示,非常的不直觀,可以通過巨集定義來完成真假操作
    • C語言(C99)提供了_Bool型,_Bool型仍是整數型,接收0和非0,不是非0的數都會被存儲為1
    • //引入頭文件
      #include <stdio.h>
      //使用巨集定義來完成
      #define BOOL int //定義BOOL為整型
      #define TURE 1 //TURE等價於1
      #define FALSE 0 //FALSE等價於0
      void main(){
      
          int i = 0; //0假,1真,-1真
          BOOL isOK = TURE;  //TURE等價於1
          BOOL OKis = FALSE; //FALSE等價於0
          if(OKis){
              printf("i為true就輸出改語句");
          }
          getchar();
      }
  • 自動類型的轉換:

    • 什麼是自動類型轉換?在C語言程式中進行賦值或運算時,精度小的類型自動轉換為精度大的數據類型

    • 細節:
      • 多個數據類型進行數據轉換時,系統首先自動將所有數據轉換為精度最大的數據類型(int和double進行運算,就轉成double)

      • 精度大的值賦值給比它小的值會造成精度丟失(如:double給float賦值)

      • 兩類型的位元組數不同,轉換成位元組數大的類型,若兩個類型的位元組數相同,且一種由符號,一種無符號,則轉換成無符號類型   

  • 強制轉換:

    • 什麼是強制轉換?把精度高的數據轉換為精度小的數據類型 
    • 語法:數據類型 名稱 = (數據類型) 變數或數據
    • 細節:
      • 高精度轉低精度會照成數據流失
      • 強轉只對只近的的數有效,如果是對多個數據可以用()括弧括起來
      • 強轉不是四捨五入,直接獲取小數點前面的數
    • //引入頭文件
      #include <stdio.h>
      
      void main(){
          double i = 10.99;
          int M = 20;
          int k = (int)i; //強轉
          int num1 = (int)3.5*10 + 6*1.5; //強制轉換隻對最近的有效 - 這就是對3.5發生強轉
          int num2 = (int)(3.5*10 + 6*1.5); // 這對求出來的結果發生強轉
          //k結果10,強轉不是四捨五入,而是直接獲取小數前面的部分
          printf("k=%d i=%f",k,i);//i=10.99,i仍然是double 
          getchar();
      }

       

                                                    

 


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

-Advertisement-
Play Games
更多相關文章
  • 5.MySQL常用函數 5.1合計/統計函數 5.1.1合計函數-count count 返回行的總數 Select count(*)|count (列名) from table_name [WHERE where_definition] 練習 -- 統計一個班級共有幾個學生 SELECT COUN ...
  • 就像在學習之前先要識字,我想在介紹優化 JavaScript 代碼之前,先介紹一下自己對編程語言的理解。故事要從一隻叫做 Theseus 的機械鼠和其發明人克勞德-香農(Claude Shannon)說起。在傳記《A Mind at Play:How Claude Shannon Invented ... ...
  • 在 《基於 vite 創建 vue3 全家桶》一文整合了 *Element Plus*,並將 *Element Plus* 中提供的圖標進行全局註冊,這樣可以很方便的延續 *Element UI* 的風格 —— 通過 *el-icon-xxx* 的方式使用圖標(如果有問題的朋友可以先閱讀前面的文章:... ...
  • 一:創建一個新的工程,項目初始化 npm init -y 二:搭建項目框架 三:編寫main.js文件內容,在index.js中引入,在把index.js引入到index.html中 例: export default()=>{ function computer(){ let h2=documen ...
  • 一、使用webpack優化前端性能方法 ⽤webpack優化前端性能是指優化webpack的輸出結果,讓打包的最終結果在瀏覽器運⾏快速⾼效。 可通過webpack優化前端的手段: 代碼壓縮(刪除多餘的代碼、註釋、簡化代碼的寫法等等⽅式) HTML文件代碼壓縮 使用HTMLWebpackPlugin插 ...
  • 內部類的基本使用 內部類概念 在一個類中定義一個類。舉例:在一個類A的內部定義一個類B,類B就被稱為內部類 我們把一個類放在另一個類的內部定義,稱為內部類(inner class)。 內部類的兩個要點: 內部類提供了更好的封裝。只能讓外部類直接訪問,不允許同一個包中的其他類直接訪問。 內部類可以直接 ...
  • 一、遞歸與迴圈的對比 遞歸會帶來大量的函數調用。這是不好的 在計算環節特別大的前提下,遞歸就是不好的,因為遞歸是先調用,再計算。 在大量計算的前提下可能會造成棧溢出(StackOverFlow) 如下圖: 迴圈是先計算再調用,計算完後會調用的方法會從棧中抹去,最後將結果輸出 能不用遞歸就不用遞歸 小 ...
  • 項目地址: GitHub - apache/skywalking-swck: Apache SkyWalking Cloud on Kubernetes 項目簡介: A bridge project between Apache SkyWalking and Kubernetes. SWCK is ...
一周排行
    -Advertisement-
    Play Games
  • 前言 插件化的需求主要源於對軟體架構靈活性的追求,特別是在開發大型、複雜或需要不斷更新的軟體系統時,插件化可以提高軟體系統的可擴展性、可定製性、隔離性、安全性、可維護性、模塊化、易於升級和更新以及支持第三方開發等方面的能力,從而滿足不斷變化的業務需求和技術挑戰。 一、插件化探索 在WPF中我們想要開 ...
  • 歡迎ReaLTaiizor是一個用戶友好的、以設計為中心的.NET WinForms項目控制項庫,包含廣泛的組件。您可以使用不同的主題選項對項目進行個性化設置,並自定義用戶控制項,以使您的應用程式更加專業。 項目地址:https://github.com/Taiizor/ReaLTaiizor 步驟1: ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • Channel 是乾什麼的 The System.Threading.Channels namespace provides a set of synchronization data structures for passing data between producers and consume ...
  • efcore如何優雅的實現按年分庫按月分表 介紹 本文ShardinfCore版本 本期主角: ShardingCore 一款ef-core下高性能、輕量級針對分表分庫讀寫分離的解決方案,具有零依賴、零學習成本、零業務代碼入侵適配 距離上次發文.net相關的已經有很久了,期間一直在從事java相關的 ...
  • 前言 Spacesniffer 是一個免費的文件掃描工具,通過使用樹狀圖可視化佈局,可以立即瞭解大文件夾的位置,幫助用戶處理找到這些文件夾 當前系統C盤空間 清理後系統C盤空間 下載 Spacesniffer 下載地址:https://spacesniffer.en.softonic.com/dow ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • 一、ReZero簡介 ReZero是一款.NET中間件 : 全網唯一開源界面操作就能生成API , 可以集成到任何.NET6+ API項目,無破壞性,也可讓非.NET用戶使用exe文件 免費開源:MIT最寬鬆協議 , 一直從事開源事業十年,一直堅持開源 1.1 純ReZero開發 適合.Net Co ...
  • 一:背景 1. 講故事 停了一個月沒有更新文章了,主要是忙於寫 C#內功修煉系列的PPT,現在基本上接近尾聲,可以回頭繼續更新這段時間分析dump的一些事故報告,有朋友微信上找到我,說他們的系統出現了大量的http超時,程式不響應處理了,讓我幫忙看下怎麼回事,dump也抓到了。 二:WinDbg分析 ...
  • 開始做項目管理了(本人3年java,來到這邊之後真沒想到...),天天開會溝通整理需求,他們講話的時候忙裡偷閑整理一下常用的方法,其實語言還是有共通性的,基本上看到方法名就大概能猜出來用法。出去打水的時候看到外面太陽好好,真想在外面坐著曬太陽,回來的時候好兄弟三年前送給我的鍵盤D鍵不靈了,在打"等待 ...