我觉得你在看引用调用和值调用那一部分。
创新互联建站致力于互联网品牌建设与网络营销,包括网站建设、网站制作、SEO优化、网络推广、整站优化营销策划推广、电子商务、移动互联网营销等。创新互联建站为不同类型的客户提供良好的互联网应用定制及解决方案,创新互联建站核心团队十余年专注互联网开发,积累了丰富的网站经验,为广大企业客户提供一站式企业网站建设服务,在网站建设行业内树立了良好口碑。
首先,其实对于int
a[10],就是在内存中开辟一段存储空间存放十个整型元素。你要明白a不是一个变量,而是一个常量地址,什么地址呢?就是指向这10个元素空间的首地址(第一个元素的地址)。你可以给a赋个值试一试,编译不会通过,因为a是个常量,不是变量。
而对于变量,他就是代表一个值,可以对他进行任意赋值。
如果将数组传递给函数,因为数组名a是常量地址,所以函数形参有了主函数数组的地址,所以被调函数可以通过地址,修改主函数中数组的元素值。
明白吗?
//你看看是不是要这样的效果
#includevector
#include"stdio.h"
//子函数
float yourFunction(float number)
{
return number+5;
}
int main()
{
//个人推荐使用容器代替动态指针数组,代码更安全 简单;
std::vectorfloatarray;
//循环时将函数返回的值放到vector中
for(int i=0;i10;i++)
{
array.push_back(yourFunction(i));
}
//获取数组中的值
for(int i=0;iarray.size();i++)
{
printf("\n%f",array[i]);
}
getchar();
}
方法
有2
将该数组定义为全局变量,即:
int
g_arr;
void
fun()
{...}
void
main()
{...}
2.将该数组作为函数参数传递到自定义函数里,即:
void
fun(int
arr[])
{...}
void
main()
{
int
arr[10];
fun(arr);
}
一、数组可定义为全局变量,函数直接调用。
二、数组可定义为局部变量,再通过参数传递到函数中调用(实参传数组名,表示数组首地址,也可通过指针或数组名+数字来传递数组局部地址)。
三、main函数想要调用函数返回的数组,可用static定义静态变量或malloc定义动态数组(字符串常量也可返回使用,但局部变量,在函数调用结束会被释放,不能作为返回地址使用)。
下面是演示代码:
#include stdio.h
#include string.h
#include malloc.h
char str1[]="我是全局变量数组";
char *fun0(char str2[]);
char *fun1();
char *fun2();
int main()
{
char *str3=NULL,*str4=NULL,*str5=NULL;
char str2[]="我是main函数的局部数组变量";
str3=fun0(str2);
printf("str3:%s,fun函数调用结束,我的地址依然可以使用\n",str3);
str4=fun1();
printf("str4:%s,fun函数调用结束,我的地址依然可以使用\n",str4);
str5=fun2();
printf("str5:%s,fun函数调用结束,函数结束不会自动释放\n",str5);
free(str5);
return 0;
}
char *fun0(char s[])
{
static char str3[]="我是fun函数申明的静态数组变量";
printf("str1:%s,fun函数可以直接调用\n",str1);
printf("str2:%s,fun函数通过参数将我的地址传进来\n",s);
return str3;
}
char *fun1()
{
char *str4="我是fun1函数的字符串常量";
return str4;
}
char *fun2()
{
int len;
char sTemp[]="这是一个临时数组,之后用于给mallc申请的地址传值,传递内容为:(我是fun函数通过mallic申请的数组)";
char *str5=NULL;
len=strlen(sTemp+63);
str5=(char *)malloc(sizeof(char)*len+1);
if(!str5)return NULL;
strcpy(str5,sTemp+63);
str5[len-2]=0;
return str5;
}
将数组传递给函数后,数组就会退化为指针
void fun(int x, int pp[], int *n)
void fun(int x, int *pp, int *n)
// 这两种写法是等价的
pp[j++]=j; // 这句写错了
// 要保存到pp里的是能整除的整数,而不是计数器j,如果这么写,那么pp的值肯定是{0,1,2,3,4,5,...}
// 应该改成
pp[j++] = l; // L才是被整除的整数,要保存的是这个
*n=j; // n作为一个指针,负责传出得到的数字的数量,j是计数器,当所有的计算完毕后,j的值自然是这些数字的数量