c++ 十进制、十六进制和BCD的相互转换,与打印printf,与函数调用 C++ 函数

转载:

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 ", 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 ", i, hex_bff[i]);
  176.  
    }
  177.  
     
  178.  
    system("pause");
  179.  
    return 0;
  180.  
    }

int PrintVal = 9;
/*按整型输出,默认右对齐*/
printf("%d ",PrintVal);
/*按整型输出,补齐4位的宽度,补齐位为空格,默认右对齐*/
printf("%4d ",PrintVal);
/*按整形输出,补齐4位的宽度,补齐位为0,默认右对齐*/
printf("%04d ",PrintVal);

/*按16进制输出,默认右对齐*/
printf("%x ",PrintVal);
/*按16进制输出,补齐4位的宽度,补齐位为空格,默认右对齐*/
printf("%4x ",PrintVal);
/*按照16进制输出,补齐4位的宽度,补齐位为0,默认右对齐*/
printf("%04x ",PrintVal);

/*按8进制输出,默认右对齐*/
printf("%o ",PrintVal);
/*按8进制输出,补齐4位的宽度,补齐位为空格,默认右对齐*/
printf("%4o ",PrintVal);
/*按照8进制输出,补齐4位的宽度,补齐位为0,默认右对齐*/
printf("%04o ",PrintVal);
————————————————
版权声明:本文为CSDN博主「卡图卢斯」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/u014647208/article/details/53337315

函数是一组一起执行一个任务的语句。每个 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(); }();