C语言基础知识(42)
数组作为函数参数
数组可以由整个数组当作函数的参数,也可以由数组中的某个元素当作函数的参数:
整个数组当作函数参数,即把数组名称传入函数中
数组中的元素当作函数参数,即把数组中的参数传入函数中
数组作为函数参数时注意以下事项:
数组名作为函数实参传递时,函数定义处作为接收参数的数组类型形参既可以指定长度也可以不指定长度。
数组元素作为函数实参传递时,数组元素类型必须与形参数据类型一致。
字符串与数组
C语言中,是没有办法直接定义字符串数据类型的,但是我们可以使用数组来定义我们所要的字符串。一般有以下两种格式:
char 字符串名称[长度] = “字符串值”;
char 字符串名称[长度] = {‘字符1’,‘字符2’,…,‘字符n’,’\0’};
注意:
[]中的长度是可以省略不写的;
采用第2种方式的时候最后一个元素必须是’\0’,’\0’表示字符串的结束标志;
采用第2种方式的时候在数组中不能写中文。
在输出字符串的时候要使用:printf(“%s”,字符数组名字);或者puts(字符数组名字);
编写一个 C 程序来检查系统的字节顺序
下面使用 C语言来编写程序检查系统的字节顺序。
方法一:
#include<stdio.h>#include<stdlib.h>#include<inttypes.h>intmain(void){
uint32_t u32RawData;
uint8_t *pu8CheckData;
u32RawData =0x11223344;//Assign data
pu8CheckData =(uint8_t *)&u32RawData;//Type castif(*pu8CheckData ==0x44)//check the value of lower address{printf("little-endian");}elseif(*pu8CheckData ==0x11)//check the value of lower address{printf("big-endian");}return0;}C
方法二:
#include<stdio.h>#include<stdlib.h>#include<inttypes.h>typedefunion{
uint32_t u32RawData;// integer variable
uint8_t au8DataBuff[4];//array of character} RawData;intmain(void){
RawData uCheckEndianess;
uCheckEndianess.u32RawData =0x11223344;//assign the value//check the array first index valueif(uCheckEndianess.au8DataBuff[0]==0x44){printf("little-endian");}//check the array first index valueelseif(uCheckEndianess.au8DataBuff[0]==0x11){printf("big-endian");}return0;}
mtianyan:字符串函数
常用的字符串函数如下(strlen,strcmp,strcpy,strcat,atoi)
使用字符串函数注意以下事项:
strlen()获取字符串的长度,在字符串长度中是不包括‘\0’而且汉字和字母的长度是不一样的
strcmp()在比较的时候会把字符串先转换成ASCII码再进行比较,返回的结果为0表示s1和s2的ASCII码相等,返回结果为1表示s1比s2的ASCII码大,返回结果为-1表示s1比s2的ASCII码小
strcpy()拷贝之后会覆盖原来字符串且不能对字符串常量进行拷贝
strcat在使用时s1与s2指的内存空间不能重叠,且s1要有足够的空间来容纳要复制的字符串
如何在C中将little-endian转换为big-endian(反之亦然)
下面下面是编写 C 程序来将 little-endian 转换为 big-endian(反之亦然)。
方法一:
#include<stdio.h>#include<stdlib.h>#include<inttypes.h>//Function to change the endianess
uint32_t ChangeEndianness(uint32_t u32Value){
uint32_t u32Result =0;
u32Result |=(u32Value &0x000000FF)<<24;
u32Result |=(u32Value &0x0000FF00)<<8;
u32Result |=(u32Value &0x00FF0000)>>8;
u32Result |=(u32Value &0xFF000000)>>24;return u32Result;}intmain(){
uint32_t u32CheckData =0x11223344;
uint32_t u32ResultData =0;
u32ResultData =ChangeEndianness(u32CheckData);//swap the dataprintf("0x%x\n",u32ResultData);
u32CheckData = u32ResultData;
u32ResultData =ChangeEndianness(u32CheckData);//again swap the dataprintf("0x%x\n",u32ResultData);return0;}C
输出结果如下:
0x44332211
0x11223344
方法二:
还可以制作宏来将数据从一个字节序交换到另一个字节序。
#include<stdio.h>#include<stdlib.h>#include<inttypes.h>//Macro to swap the byte#define ChangeEndianness(A) ((((uint32_t)(A) & 0xff000000) >> 24) | (((uint32_t)(A) & 0x00ff0000) >> 8) | \
(((uint32_t)(A) & 0x0000ff00) << 8) | (((uint32_t)(A) & 0x000000ff) << 24))intmain(){
uint32_t u32CheckData =0x11223344;
uint32_t u32ResultData =0;
u32ResultData =ChangeEndianness(u32CheckData);printf("0x%x\n",u32ResultData);
u32CheckData = u32ResultData;
u32ResultData =ChangeEndianness(u32CheckData);printf("0x%x\n",u32ResultData);return0;}
多维数组
多维数组的定义格式是:
数据类型 数组名称[常量表达式1][常量表达式2]…[常量表达式n];
定义了一个名称为num,数据类型为int的二维数组。其中第一个[3]表示第一维下标的长度,就像购物时分类存放的购物;第二个[3]表示第二维下标的长度,就像每个购物袋中的元素。
多维数组的初始化与一维数组的初始化类似也是分两种:
数据类型 数组名称[常量表达式1][常量表达式2]…[常量表达式n] = {{值1,…,值n},{值1,…,值n},…,{值1,…,值n}};
数据类型 数组名称[常量表达式1][常量表达式2]…[常量表达式n]; 数组名称[下标1][下标2]…[下标n] = 值;
多维数组初始化要注意以下事项:
采用第一种始化时数组声明必须指定列的维数。mtianyan: 因为系统会根据数组中元素的总个数来分配空间,当知道元素总个数以及列的维数后,会直接计算出行的维数;
采用第二种初始化时数组声明必须同时指定行和列的维数。
二维数组定义的时候,可以不指定行的数量,但是必须指定列的数量