define的用法

来源:http://www.cnblogs.com/King-Penguin/archive/2016/01/17/5136645.html
-Advertisement-
Play Games

define的用法小結define的用法只是一種純粹的替換功能,巨集定義的替換是預處理器處理的替換。 一:簡單的巨集定義用法 格式:#define 標識符 替換內容 替換的內容可以是數字,字元,字元串,特殊字元和空格,後面是什麼內容就會替換成什麼內容。 例如: #define N 5 效...


define的用法小結

define的用法只是一種純粹的替換功能,巨集定義的替換是預處理器處理的替換。

 一:簡單的巨集定義用法

  格式:#define 標識符 替換內容

  替換的內容可以是數字,字元,字元串,特殊字元和空格,後面是什麼內容就會替換成什麼內容。

  例如:

  #define  N   5    效果等同於    int  array [5];

  int  array[N];

  同樣效果:

  #define N = 5

  int array[N];       效果等同於    int  array[= 5];

  同樣效果:

  #define N   5;

  int array[N];       效果等同於    int  array[5;];

  常見的一種錯誤:

  #define  pin  int*

  pin  a  , b ;     實際上的效果是    int  *a , b;

  

  #define N 2+2

  void main(void)

  {

    int a = N * N;

    printf("%d\n" , a );

  }

  結果是2+2*2+2=8


 

 二:帶參數的巨集定義的使用

 例子說話:一個求正方形面積的函數

  使用#define的正確寫法應該是:   

#include<stdio.h>
#define area(x)   ((x)*(x))
int main(void)
{
int s = area(3 + 3);
printf("s = %d\n" , s);
return 0;
}

運行結果:(3+3)*(3+3)= 36  是我們想要的結果

  常見問題寫成:

#include<stdio.h>
#define area(x)   x*x
int main(void)
{
int s = area(3 + 3);
printf("s = %d\n" , s);
return 0;
}

運行結果:3 + 3 * 3 + 3 = 15   不是我們想要的結果

這更能體現出前面說的define的巨集定義就是純粹的一種替換,做的是先替換後計算的工作。

防止這種問題的方法:

   要想能夠真正使用好巨集定義,防止出現上面一二兩種常用情況的一些錯誤,一定要記住在思路上先將程式中對巨集的使用全部替換成它所代表的字元串,不要自作主張地添加任何其他符號,完全展開後再進行相應的計算,就不會寫錯運行結果。在編程使用巨集替換時,當字元串中不只一個符號時,加上括弧表現出優先順序,如果是帶參數的巨集定義,則要給巨集體中的每個參數加上括弧,併在整個巨集體上再加一個括弧


 

三:常用作對函數的封裝

例子說話:現在原有一個求兩個數乘積的函數mult  

[Linux@centos-64-min exercise]$ cat mul.c
#include <stdio.h>
int mult(int x , int y )
{
  int result = x * y;
  return result;
}

現在需要不同的兩個功能函數,一個是求正方形面積的函數 square_area和一個求長方形的面積的函數rectangle_area。

可以這樣寫:

[Linux@centos-64-min exercise]$ cat mul.c
#include <stdio.h>
int mult(int x , int y )
{
int result = x * y;
return result;
}
[Linux@centos-64-min exercise]$ cat try.c
#include <stdio.h>
int mult(int x , int y);              /*兩個數字相乘的函數的聲明*/

#define square_area(str , x) mult(x , x)      /*封裝成一個求正方形面積的函數*/
#define rectangle_area(str , x , y) mult(x , y)  /*封裝成一個求長方形面積的函數*/

/*上面那些函數聲明和巨集定義按照比較規範的書寫,本來應該放在一個頭文件裡面的,這裡為了說明問題就簡單放在函數里了*/
int main(void)
{
  int s = 0;
  s = square_area("This is the area of the square" , 3);
  printf("This is the area of the square : s = %d\n" , s);
  s = rectangle_area("This is the area of the rectangle" , 3 ,4);
  printf("This is the area of the rectangle : s = %d\n" , s);
  return 0;
}

運行結果:

[Linux@centos-64-min exercise]$ gcc -o try try.c mul.o
[Linux@centos-64-min exercise]$ ./try
This is the area of the square : s = 9
This is the area of the rectangle : s = 12


 

四:define中的三個特殊符號:#,##,#@

#define Conn(x,y) x##y
#define ToChar(x) #@x
#define ToString(x) #x

x##y表示x連接y,舉例說:
int n = Conn(123,456);   結果就是n=123456;
char* str = Conn("asdf", "adf")結果就是 str = "asdfadf";

#@x,其實就是給x加上單引號,結果返回是一個const char。舉例說:
char a = ToChar(1);結果就是a='1';
做個越界試驗char a = ToChar(123);結果就錯了;
但是如果你的參數超過四個字元,編譯器就給給你報錯了!error C2015: too many characters in constant   :P

#x,表示給x加雙引號
char* str = ToString(123132);就成了str="123132";


 

五:小結#define巨集定義

(1)   方便程式的修改
      使用簡單巨集定義可用巨集代替一個在程式中經常使用的常量,這樣在將該常量改變時,不用對整個程式進行修改,只修改巨集定義的字元串即可,而且當常量比較長時, 我們可以用較短的有意義的標識符來寫程式,這樣更方便一些。

(2)  巨集定義是在預編譯的時候就進行替換。程式中調用子函數執行完之後都必須飯後調用該子函數的現場繼續往下執行,這樣就會出現了函數轉換的消耗。但是使用帶參數的巨集定義就不會出現這個問題,因為它是在預處理階段即進行了巨集展開,在執行時不需要轉換,即在當地執行,但複雜的操作還是要由函數調用來完成,而且巨集定義所占用的目標代碼空間相對較大。所以在使用時要依據具體情況來決定是否使用巨集定義。

 


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

-Advertisement-
Play Games
更多相關文章
  • T-SQL的回車和換行符(SQL)sql server中的回車換行字元是 char(13)+char(10)回車:char(13)換行:char(10)實例1:DECLARE @c NVARCHAR(100)SET @c='2006-01-12|2006-02-13|2006-03-15|2006-...
  • --做測試的時候使用。--缺點:結果集的數量,類型都要一樣。INSERT INTO Student ( StudentID, StudentName, StduentAge, StudentBirthday, StudentGender, StudentPhone, StudentEmail, S....
  • 今天測試密鑰登入linux系統時 出現如下問題:root@compute01:~#ssh [email protected] -p 80 -i alickicxxxxxxx.key@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ ....
  • 一.概述 System V信號量與System V消息隊列不同。它不是用來在進程間傳遞數據。它主要是來同步進程的動作。1.一個信號量是一個由內核維護的整數。其值被限製為大於或等於0。2.可以在信號量上加上或減去一個數量。3.當一個減操作把信號量減到小於...
  • 那麼, 今天的任務呢是在linux上安裝 .net 5 運行時 ok, 先決條件: Ubuntu 14 (openSuse 42和Ubuntu 15都失敗了... 別問我為什麼) 開始安裝: "官方文檔" 安裝 .NET Version Manager (DNVM) 安裝 .NE...
  • [前言]在張銀奎老師的《軟體調試》一書中,詳細地講解了使用記憶體的分支記錄機制——BTS機制(5.3),並且給出了示例工具CpuWhere及其源代碼。但實際運行(VMware XP_SP3 單核)並沒有體現應有的效果,無法讀取到分支記錄。查看了源代碼並沒有發現任何問題,與書中所講一致。既然軟體本身沒有...
  • 最近,有個項目突然接到總部的安全漏洞報告,查看後知道是XSS攻擊。問題描述: 在頁面上有個隱藏域: 當前頁面提交到Controller時,未對action屬性做任何處理,直接又回傳到頁面上 如果此時action被用戶惡意修改為:***""*** 此時當頁面刷新時將執行alert(1),雖然錯...
  • 在插件實例修改3增加一個聯繫人功能配置文件 1 2 3 4 5 6 7 8 9 10 11 12...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...