一、形参----指针
#include "stdio.h"
#include "stdlib.h"
void func(char *parameter)//char parameter[]
{
printf("parameter = %p, ¶meter = %p\n", parameter, ¶meter);
}
int main(int argc, char *argv[])
{
char str_arr[10];
printf("str_arr = %p, &str_arr = %p\n", str_arr, &str_arr);
func(str_arr);//&str_arr[0]
return 0;
}
运行的结果:
1.指针parameter指向的是str_arr[0]的地址,即&str_arr[0],且数组名str_arr也可以表示首元素的地址。
2.数组名是一个数,没有一块独立的存储空间。指针有独立的空间,parameter可以存储指向str_arr[0]的地址,也可以修改指向,数组名不可以。
3.形参写char *parameter和char parameter[]是一样的,都是指针。
#include "stdio.h"
#include "stdlib.h"
char num = 'A';
void func(char parameter[])//char *parameter
{
parameter = #
}
int main(int argc, char *argv[])
{
char str_arr[10];
str_arr = #
return 0;
}
运行结果:(报错提示)
验证了上面的第二点,数组名没有独立的空间不能指向新的地址,指针有独立的空间,可以存储指向的地址。
二、形参----指针的指针char *argv[]
#include "stdio.h"
#include "stdlib.h"
int main(int argc, char *argv[])
{
char *str_arr[10];//指针数组,数组里每个元素都是指针,指向char类型的地址。
int i;
printf("&argv = %p, argv = %p\n", &argv, argv);//argv是指针,有自己的空间,能存放指向的地址
for(i = 0; i < argc; ++i){
str_arr[i] = argv[i];
printf("argv + %d = %p, &argv[%d] = %p, str_arr[%d] = %p, str_arr[%d]: ",i, argv + i, i, &argv[i], i, str_arr[i], i);
puts(str_arr[i]);
}
return 0;
}
运行结果:
1.&argv和argv(&argv[0])不一样,argv是指针,有自己的空间,能存放指向的地址。
2.形参可类比一级指针,&argv是指针自己的地址,argv是指针,有自己的空间,能存放指向的地址,也就是外边实参parameter传进来的地址。每一跳都是有效的地址,且间隔空间是字节。可以看出传进来的地址是数组首元素的地址。