本人目前在自学c++,在学习结构体时碰到了一个小问题,先来看问题:
案例描述:
设计一个英雄的结构体,包括成员姓名,年龄,性别;创建结构体数组,数组中存放5名英雄。
通过冒泡排序的算法,将数组中的英雄按照年龄进行升序排序,最终打印排序后的结果。
五名英雄信息如下:
{"刘备",23,"男"},
{"关羽",22,"男"},
{"张飞",20,"男"},
{"赵云",21,"男"},
{"貂蝉",19,"女"},
下面是我第一次写的代码,我在sort_hero函数内部计算了传入arr参数的长度
#include<iostream>
using namespace std;
#include<string>
struct hero
{
string name;
int age;
string gender;
};
void sort_hero(hero arr[])
{
cout << "sort_hero" << endl;
int len = sizeof(arr) / sizeof(hero);
cout << "len " << len << endl;
for (int i = 0; i < len - 1; i++)
{
for (int j = 0; j < len - i - 1; j++)
{
if (arr[j].age > arr[j + 1].age)
{
hero a = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = a;
}
}
}
}
void print_heros(hero arr[])
{
cout << "print_heros" << endl;
int len = sizeof(arr) / sizeof(hero);
cout << "len " << len << endl;
for (int i = 0; i < len; i++)
{
cout << "111" <<endl;
cout << "姓名:" << arr[i].name << "年龄" << arr[i].age << "性别" << arr[i].gender << endl;
}
}
int main()
{
struct hero arr[5]
{
{"刘备",23,"男"},
{"关羽",22,"男"},
{"张飞",20,"男"},
{"赵云",21,"男"},
{"貂蝉",19,"女"}
};
sort_hero(arr);
print_heros(arr);
system("pause");
return 0;
}
我这边,函数传参只是传了一个数组名,因为按照我python的理解思路,我可以通过传入这个数组然后算出数组的长度,这样就可以进行循环,然后冒泡排序了,然后其实不然,当我们运行程序,我们输出的len的长度其实是0
那么问题就来了,如何解决,那自然就是将len也当做参数传进去,然后我们再来看看结果
#include<iostream>
using namespace std;
#include<string>
struct hero
{
string name;
int age;
string gender;
};
void sort_hero(hero arr[], int len)
{
cout << "sort_hero" << endl;
cout << "len " << len << endl;
for (int i = 0; i < len - 1; i++)
{
for (int j = 0; j < len - i - 1; j++)
{
if (arr[j].age > arr[j + 1].age)
{
hero a = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = a;
}
}
}
}
void print_heros(hero arr[], int len)
{
cout << "print_heros" << endl;
cout << "len " << len << endl;
for (int i = 0; i < len; i++)
{
cout << "姓名:" << arr[i].name << "年龄" << arr[i].age << "性别" << arr[i].gender << endl;
}
}
int main()
{
struct hero arr[5]
{
{"刘备",23,"男"},
{"关羽",22,"男"},
{"张飞",20,"男"},
{"赵云",21,"男"},
{"貂蝉",19,"女"}
};
int len = sizeof(arr) / sizeof(hero);
sort_hero(arr, len);
print_heros(arr, len);
system("pause");
return 0;
}
那么问题又来了,为啥我一开始传入的arr不好使呢?讲道理如果代码二好使的话,就说明传入的arr是没有问题的,也就是说我可以通过我传入的arr获取到各个英雄,而且还有个问题,我传入的arr,我在函数内操作的不是局部变量么,会什么会影响到我的主函数?
这里面有两个问题:
1.为何方法一不好使?
2.为何主函数中的arr也会改变?
其实只有一个原因,这可以解决上面两个问题的疑惑
那就是:传递数组名是传递数组首元素的地址,我错把python的思想沿用过来了,既然传递的是地址,那函数内计算sizeof(arr)为0,但是如果你在主函数那边使用sizeof(arr),就可以得到数组的大小,因为前者的arr是地址,后者的arr是数组名,而且你改变了函数内的arr,其实是地址上的值改变了,那自然也就变了。