c++ 十進制、十六進制和BCD的相互轉換,與打印printf,與函數調用


轉載:

https://blog.csdn.net/sjhuangx/article/details/49947179   c++ 十進制、十六進制和BCD的相互轉換

https://blog.csdn.net/u014647208/article/details/53337315  printf

https://www.runoob.com/cplusplus/cpp-functions.html   函數調用

 

 

轉載自:http://www.cppblog.com/tdweng/articles/139022.html

 

 

  1.  
    #include <stdio.h>
  2.  
    #include <string.h>
  3.  
    #include <iostream>
  4.  
    using namespace std;
  5.  
    /////////////////////////////////////////////////////
  6.  
    //
  7.  
    //功能:二進制取反
  8.  
    //
  9.  
    //輸入:const unsigned char *src 二進制數據
  10.  
    // int length 待轉換的二進制數據長度
  11.  
    //
  12.  
    //輸出:unsigned char *dst 取反后的二進制數據
  13.  
    //
  14.  
    //返回:0 success
  15.  
    //
  16.  
    //////////////////////////////////////////////////////
  17.  
    int convert(unsigned char *dst, const unsigned char *src, int length)
  18.  
    {
  19.  
    int i;
  20.  
    for (i = 0; i < length; i++)
  21.  
    {
  22.  
    dst[i] = src[i] ^ 0xFF;
  23.  
    }
  24.  
    return 0;
  25.  
    }
  26.  
    //////////////////////////////////////////////////////////
  27.  
    //
  28.  
    //功能:十六進制轉為十進制
  29.  
    //
  30.  
    //輸入:const unsigned char *hex 待轉換的十六進制數據
  31.  
    // int length 十六進制數據長度
  32.  
    //
  33.  
    //輸出:
  34.  
    //
  35.  
    //返回:int rslt 轉換后的十進制數據
  36.  
    //
  37.  
    //思路:十六進制每個字符位所表示的十進制數的范圍是0 ~255,進制為256
  38.  
    // 左移8位(<<8)等價乘以256
  39.  
    //
  40.  
    /////////////////////////////////////////////////////////
  41.  
    unsigned long HextoDec(const unsigned char *hex, int length)
  42.  
    {
  43.  
    int i;
  44.  
    unsigned long rslt = 0;
  45.  
    for (i = 0; i < length; i++)
  46.  
    {
  47.  
    rslt += ( unsigned long)(hex[i]) << (8 * (length - 1 - i));
  48.  
     
  49.  
    }
  50.  
    return rslt;
  51.  
    }
  52.  
     
  53.  
    /////////////////////////////////////////////////////////
  54.  
    //
  55.  
    //功能:十進制轉十六進制
  56.  
    //
  57.  
    //輸入:int dec 待轉換的十進制數據
  58.  
    // int length 轉換后的十六進制數據長度
  59.  
    //
  60.  
    //輸出:unsigned char *hex 轉換后的十六進制數據
  61.  
    //
  62.  
    //返回:0 success
  63.  
    //
  64.  
    //思路:原理同十六進制轉十進制
  65.  
    //////////////////////////////////////////////////////////
  66.  
    int DectoHex(int dec, unsigned char *hex, int length)
  67.  
    {
  68.  
    int i;
  69.  
    for (i = length - 1; i >= 0; i--)
  70.  
    {
  71.  
    hex[i] = (dec % 256) & 0xFF;
  72.  
    dec /= 256;
  73.  
    }
  74.  
    return 0;
  75.  
    }
  76.  
    /////////////////////////////////////////////////////////
  77.  
    //
  78.  
    //功能:求權
  79.  
    //
  80.  
    //輸入:int base 進制基數
  81.  
    // int times 權級數
  82.  
    //
  83.  
    //輸出:
  84.  
    //
  85.  
    //返回:unsigned long 當前數據位的權
  86.  
    //
  87.  
    //////////////////////////////////////////////////////////
  88.  
    unsigned long power(int base, int times)
  89.  
    {
  90.  
    int i;
  91.  
    unsigned long rslt = 1;
  92.  
    for (i = 0; i < times; i++)
  93.  
    rslt *= base;
  94.  
    return rslt;
  95.  
    }
  96.  
    /////////////////////////////////////////////////////////
  97.  
    //
  98.  
    //功能:BCD轉10進制
  99.  
    //
  100.  
    //輸入:const unsigned char *bcd 待轉換的BCD碼
  101.  
    // int length BCD碼數據長度
  102.  
    //
  103.  
    //輸出:
  104.  
    //
  105.  
    //返回:unsigned long 當前數據位的權
  106.  
    //
  107.  
    //思路:壓縮BCD碼一個字符所表示的十進制數據范圍為0 ~ 99,進制為100
  108.  
    // 先求每個字符所表示的十進制值,然后乘以權
  109.  
    //////////////////////////////////////////////////////////
  110.  
    unsigned long BCDtoDec(const unsigned char *bcd, int length)
  111.  
    {
  112.  
    int i, tmp;
  113.  
    unsigned long dec = 0;
  114.  
    for (i = 0; i < length; i++)
  115.  
    {
  116.  
    tmp = ((bcd[i] >> 4) & 0x0F) * 10 + (bcd[i] & 0x0F);
  117.  
    dec += tmp * power( 100, length - 1 - i);
  118.  
    }
  119.  
    return dec;
  120.  
    }
  121.  
    /////////////////////////////////////////////////////////
  122.  
    //
  123.  
    //功能:十進制轉BCD碼
  124.  
    //
  125.  
    //輸入:int Dec 待轉換的十進制數據
  126.  
    // int length BCD碼數據長度
  127.  
    //
  128.  
    //輸出:unsigned char *Bcd 轉換后的BCD碼
  129.  
    //
  130.  
    //返回:0 success
  131.  
    //
  132.  
    //思路:原理同BCD碼轉十進制
  133.  
    //
  134.  
    //////////////////////////////////////////////////////////
  135.  
    int DectoBCD(int Dec, unsigned char *Bcd, int length)
  136.  
    {
  137.  
    int i;
  138.  
    int temp;
  139.  
    for (i = length - 1; i >= 0; i--)
  140.  
    {
  141.  
    temp = Dec % 100;
  142.  
    Bcd[i] = ((temp / 10) << 4) + ((temp % 10) & 0x0F);
  143.  
    Dec /= 100;
  144.  
    }
  145.  
    return 0;
  146.  
    }
  147.  
    //main函數
  148.  
    int main(int argc, char** argv)
  149.  
    {
  150.  
    //BCD碼轉十進制
  151.  
    unsigned char BCD[3] = { 0x00, 0x53, 0x20 };
  152.  
    int dec_bcd = BCDtoDec(BCD, 3);
  153.  
    cout << "dec_bcd : " << dec_bcd << endl;
  154.  
     
  155.  
    //十進制轉BCD碼
  156.  
    unsigned char tmp_bff[3] = "";
  157.  
    DectoBCD(dec_bcd, tmp_bff, 3);
  158.  
    for (int i = 0; i < 3; ++i)
  159.  
    {
  160.  
    //cout << "tmp_buff[" << i << "]: " << tmp_bff[i] << endl;
  161.  
    printf("tmp_bff[%d] = 0x%02X\n", i, tmp_bff[i]);
  162.  
    }
  163.  
     
  164.  
    cout << endl << endl;
  165.  
    //十六進制轉十進制
  166.  
    unsigned char Hex[3] = { 0x00, 0x53, 0x20 };
  167.  
    int dec_hex = HextoDec(Hex, 3);
  168.  
    cout << "dec_hex: " << dec_hex << endl;
  169.  
     
  170.  
    //十進制轉十六進制
  171.  
    unsigned char hex_bff[3] = "";
  172.  
    DectoHex(dec_hex, hex_bff, 3);
  173.  
    for (int i = 0; i < 3; ++i)
  174.  
    {
  175.  
    printf("hex_bff[%d] = 0x%02X\n", i, hex_bff[i]);
  176.  
    }
  177.  
     
  178.  
    system( "pause");
  179.  
    return 0;
  180.  
    }
  181.  

 

 

 

 

 

 

 

 

int PrintVal = 9;
/*按整型輸出,默認右對齊*/
printf("%d\n",PrintVal);
/*按整型輸出,補齊4位的寬度,補齊位為空格,默認右對齊*/
printf("%4d\n",PrintVal);
/*按整形輸出,補齊4位的寬度,補齊位為0,默認右對齊*/
printf("%04d\n",PrintVal);

/*按16進制輸出,默認右對齊*/
printf("%x\n",PrintVal);
/*按16進制輸出,補齊4位的寬度,補齊位為空格,默認右對齊*/
printf("%4x\n",PrintVal);
/*按照16進制輸出,補齊4位的寬度,補齊位為0,默認右對齊*/
printf("%04x\n",PrintVal);

/*按8進制輸出,默認右對齊*/
printf("%o\n",PrintVal);
/*按8進制輸出,補齊4位的寬度,補齊位為空格,默認右對齊*/
printf("%4o\n",PrintVal);
/*按照8進制輸出,補齊4位的寬度,補齊位為0,默認右對齊*/
printf("%04o\n",PrintVal);
————————————————
版權聲明:本文為CSDN博主「卡圖盧斯」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/u014647208/article/details/53337315

 

 

 

C++ 函數

函數是一組一起執行一個任務的語句。每個 C++ 程序都至少有一個函數,即主函數 main() ,所有簡單的程序都可以定義其他額外的函數。

您可以把代碼划分到不同的函數中。如何划分代碼到不同的函數中是由您來決定的,但在邏輯上,划分通常是根據每個函數執行一個特定的任務來進行的。

函數聲明告訴編譯器函數的名稱、返回類型和參數。函數定義提供了函數的實際主體。

C++ 標准庫提供了大量的程序可以調用的內置函數。例如,函數 strcat() 用來連接兩個字符串,函數 memcpy() 用來復制內存到另一個位置。

函數還有很多叫法,比如方法、子例程或程序,等等。

定義函數

C++ 中的函數定義的一般形式如下:

return_type function_name( parameter list ) { body of the function }

在 C++ 中,函數由一個函數頭和一個函數主體組成。下面列出一個函數的所有組成部分:

  • 返回類型:一個函數可以返回一個值。return_type 是函數返回的值的數據類型。有些函數執行所需的操作而不返回值,在這種情況下,return_type 是關鍵字 void
  • 函數名稱:這是函數的實際名稱。函數名和參數列表一起構成了函數簽名。
  • 參數:參數就像是占位符。當函數被調用時,您向參數傳遞一個值,這個值被稱為實際參數。參數列表包括函數參數的類型、順序、數量。參數是可選的,也就是說,函數可能不包含參數。
  • 函數主體:函數主體包含一組定義函數執行任務的語句。

實例

以下是 max() 函數的源代碼。該函數有兩個參數 num1 和 num2,會返回這兩個數中較大的那個數:

// 函數返回兩個數中較大的那個數 int max(int num1, int num2) { // 局部變量聲明 int result; if (num1 > num2) result = num1; else result = num2; return result; }

函數聲明

函數聲明會告訴編譯器函數名稱及如何調用函數。函數的實際主體可以單獨定義。

函數聲明包括以下幾個部分:

return_type function_name( parameter list );

針對上面定義的函數 max(),以下是函數聲明:

int max(int num1, int num2);

在函數聲明中,參數的名稱並不重要,只有參數的類型是必需的,因此下面也是有效的聲明:

int max(int, int);

當您在一個源文件中定義函數且在另一個文件中調用函數時,函數聲明是必需的。在這種情況下,您應該在調用函數的文件頂部聲明函數。

調用函數

創建 C++ 函數時,會定義函數做什么,然后通過調用函數來完成已定義的任務。

當程序調用函數時,程序控制權會轉移給被調用的函數。被調用的函數執行已定義的任務,當函數的返回語句被執行時,或到達函數的結束括號時,會把程序控制權交還給主程序。

調用函數時,傳遞所需參數,如果函數返回一個值,則可以存儲返回值。例如:

實例

#include <iostream> using namespace std; // 函數聲明 int max(int num1, int num2); int main () { // 局部變量聲明 int a = 100; int b = 200; int ret; // 調用函數來獲取最大值 ret = max(a, b); cout << "Max value is : " << ret << endl; return 0; } // 函數返回兩個數中較大的那個數 int max(int num1, int num2) { // 局部變量聲明 int result; if (num1 > num2) result = num1; else result = num2; return result; }

把 max() 函數和 main() 函數放一塊,編譯源代碼。當運行最后的可執行文件時,會產生下列結果:

Max value is : 200

函數參數

如果函數要使用參數,則必須聲明接受參數值的變量。這些變量稱為函數的形式參數

形式參數就像函數內的其他局部變量,在進入函數時被創建,退出函數時被銷毀。

當調用函數時,有三種向函數傳遞參數的方式:

調用類型 描述
傳值調用 該方法把參數的實際值賦值給函數的形式參數。在這種情況下,修改函數內的形式參數對實際參數沒有影響。
指針調用 該方法把參數的地址賦值給形式參數。在函數內,該地址用於訪問調用中要用到的實際參數。這意味着,修改形式參數會影響實際參數。
引用調用 該方法把參數的引用賦值給形式參數。在函數內,該引用用於訪問調用中要用到的實際參數。這意味着,修改形式參數會影響實際參數。

默認情況下,C++ 使用傳值調用來傳遞參數。一般來說,這意味着函數內的代碼不能改變用於調用函數的參數。之前提到的實例,調用 max() 函數時,使用了相同的方法。

參數的默認值

當您定義一個函數,您可以為參數列表中后邊的每一個參數指定默認值。當調用函數時,如果實際參數的值留空,則使用這個默認值。

這是通過在函數定義中使用賦值運算符來為參數賦值的。調用函數時,如果未傳遞參數的值,則會使用默認值,如果指定了值,則會忽略默認值,使用傳遞的值。請看下面的實例:

實例

#include <iostream> using namespace std; int sum(int a, int b=20) { int result; result = a + b; return (result); } int main () { // 局部變量聲明 int a = 100; int b = 200; int result; // 調用函數來添加值 result = sum(a, b); cout << "Total value is :" << result << endl; // 再次調用函數 result = sum(a); cout << "Total value is :" << result << endl; return 0; }

當上面的代碼被編譯和執行時,它會產生下列結果:

Total value is :300 Total value is :120

Lambda 函數與表達式

C++11 提供了對匿名函數的支持,稱為 Lambda 函數(也叫 Lambda 表達式)。

Lambda 表達式把函數看作對象。Lambda 表達式可以像對象一樣使用,比如可以將它們賦給變量和作為參數傳遞,還可以像函數一樣對其求值。

Lambda 表達式本質上與函數聲明非常類似。Lambda 表達式具體形式如下:

[capture](parameters)->return-type{body}

例如:

[](int x, int y){ return x < y ; }

如果沒有返回值可以表示為:

[capture](parameters){body}

例如:

[]{ ++global_x; }

在一個更為復雜的例子中,返回類型可以被明確的指定如下:

[](int x, int y) -> int { int z = x + y; return z + x; }

本例中,一個臨時的參數 z 被創建用來存儲中間結果。如同一般的函數,z 的值不會保留到下一次該不具名函數再次被調用時。

如果 lambda 函數沒有傳回值(例如 void),其返回類型可被完全忽略。

在Lambda表達式內可以訪問當前作用域的變量,這是Lambda表達式的閉包(Closure)行為。 與JavaScript閉包不同,C++變量傳遞有傳值和傳引用的區別。可以通過前面的[]來指定:

[] // 沒有定義任何變量。使用未定義變量會引發錯誤。 [x, &y] // x以傳值方式傳入(默認),y以引用方式傳入。 [&] // 任何被使用到的外部變量都隱式地以引用方式加以引用。 [=] // 任何被使用到的外部變量都隱式地以傳值方式加以引用。 [&, x] // x顯式地以傳值方式加以引用。其余變量以引用方式加以引用。 [=, &z] // z顯式地以引用方式加以引用。其余變量以傳值方式加以引用。

另外有一點需要注意。對於[=]或[&]的形式,lambda 表達式可以直接使用 this 指針。但是,對於[]的形式,如果要使用 this 指針,必須顯式傳入:

[this]() { this->someFunc(); }();

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM