计算机程序运行时,在内存中存在大量的存储空间,就像一栋酒店大楼可以让旅客用来住宿。不同的存储空间用地址来标示,恰若酒店大楼各个房间的门牌号。C语言中用指针来表示地址。通过指针来操作变量,具有很过优点:
1 在被调函数中通过指针可以改变主调函数中的变量;
2 在被调函数中可以有多个返回值;
指针变量的修饰符为 * ,通过*可以定义一维指针和二维指针。一维指针的格式:类型说明符 * 变量名[数组长度],二维指针格式:类型说明符 (*变量名)[二维数组的列数]。
一维指针中的元素是不同的指针变量,用来处理一维数组;二维指针中的元素是单个指针变量,用来处理二维数组。
下面是几个实例:
//改变主调函数中变量的值
void changeValue(int *a,int *b)
{
*a = 100;
*b = 200;
}
int main(int argc, const char * argv[]) {
int x = 20;
int y = 10;
printf("源数据:x = %d,y = %d\n",x,y);
changeValue(&x,&y);
printf("源数据:x = %d,y = %d\n",x,y);
return 0;
}
#include <stdio.h>
//被调函数有多个返回值
void returnValue(int a ,int b,int *jia,int *jian,int *chen,float *chu)
{
*jia = a + b;
*jian = a - b;
*chen = a * b;
*chu = a/(float)b;
}
int main(int argc, const char * argv[]) {
int a = 100 ,b = 20,sum,sub,mul;
float div;
returnValue(a,b,&sum,&sub,&mul,&div);
printf("a + b = %d\na - b = %d\na * b = %d\na / b = %.2f\n",sum,sub,mul,div);
return 0;
}
#include <stdio.h>
//实现数组的逆序
void reverseArray(int *num,int len)
{
int i = 0,j = len -1;
int temp;
while(i < j)
{
temp = *(num + i);
*(num + i) = *(num + j);
*(num + j) = temp;
i++,j--;
}
}
void printArr(int a[],int len)
{
for(int i = 0;i < len;i++)
{
printf("%d\t",a[i]);
}
printf("\n");
}
int main(int argc, char* argv[])
{
int a[10] = {0,1,2,3,4,5,6,7,8,9};
printf("原数组:\n");
printArr(a,10);
reverseArray(a,10);
printf("逆序数组:\n");
printArr(a,10);
return 0;
}
char * getDay(int n)
{
char *p[7] = {
"星期一",
"星期二",
"星期三",
"星期四",
"星期五",
"星期六",
"星期日"
};
return n > 0 && n < 8? p[n-1]:"输入错误";
}
int main(int argc, const char * argv[]) {
int day = 0;
scanf("%d",&day);
getchar();
char *p = getDay(day);
printf("%s\n",p);
return 0;
}