C语言结构体内含有数组,该结构体作为参数传递时需用指针,否则对数组的修改不会被记录
2016-04-09 11:23
585 查看
在C语言编程时,常常会定义结构体,而且结构体里面常常会有数组,比如如下所示:
typedef struct
{
int data[MAX_HEAP_SIZE];
unsigned int heap_size;
}HeapType;
这是一个堆的数据结构,包含堆的元素(数组)和堆的大小。在建大顶堆时会给建堆的函数传递参数,建堆函数如下:
void Build_Max_Heap(HeapType *heap)
{
unsigned int leaf_boundary = (heap->heap_size - 1) >> 1;
//通过维护堆的方法循环建堆
for(int i = leaf_boundary; i >= 0; i--)
{
Maintain_Heap(heap, i);
}
return;
}
在Maintain_Heap中会对heap里面的数组进行位置交换,如果传递的参数不是HeapType *heap,而是HeapType heap时会发现执行完建堆函数后数组元素没有变动(建堆过程相当于没做)。分析发现如果传递HeapType heap时是按照一个变量传递进去,只是被拷贝到函数中并没有对其中内容进行修改(尽管里面是数组类型也不行,本人亲测)。所以要是想改变结构体中数组的内容,传递参数最好用指针的方式来传递,其中的原理有兴趣的可以看看结构体在内存中的存放形式,这样修改的是对应地址块里面的内容,而不仅仅是拷贝。
typedef struct
{
int data[MAX_HEAP_SIZE];
unsigned int heap_size;
}HeapType;
这是一个堆的数据结构,包含堆的元素(数组)和堆的大小。在建大顶堆时会给建堆的函数传递参数,建堆函数如下:
void Build_Max_Heap(HeapType *heap)
{
unsigned int leaf_boundary = (heap->heap_size - 1) >> 1;
//通过维护堆的方法循环建堆
for(int i = leaf_boundary; i >= 0; i--)
{
Maintain_Heap(heap, i);
}
return;
}
在Maintain_Heap中会对heap里面的数组进行位置交换,如果传递的参数不是HeapType *heap,而是HeapType heap时会发现执行完建堆函数后数组元素没有变动(建堆过程相当于没做)。分析发现如果传递HeapType heap时是按照一个变量传递进去,只是被拷贝到函数中并没有对其中内容进行修改(尽管里面是数组类型也不行,本人亲测)。所以要是想改变结构体中数组的内容,传递参数最好用指针的方式来传递,其中的原理有兴趣的可以看看结构体在内存中的存放形式,这样修改的是对应地址块里面的内容,而不仅仅是拷贝。
相关文章推荐
- 【C语言】编写一个将输入复制到输出的程序,并将其中连续的多个空格用一个空格代替
- CSP考试 2015年03月第3题 节日 C语言实现
- C++中的头文件和原文件
- C++ - STL- vector
- 【C语言】C语言的const与C++的const区别
- 【C语言】总结C语言深度剖析
- 【动态规划】最长公共子序列(并续)
- C++ 访问范围说明符
- C++异常处理机制几种方法
- c++中栈与队列的实现
- C++四种类型转换的关键字及其特点
- c++第3次实验—作业
- IIS7安装PHP-5.3.27教程, Visual C++ 2008(x86,x64)
- 以前用C语言编写的生成随机数的猜数字小游戏
- NOI 193棋盘分割.cpp
- 最小二乘法拟合直线
- C++ STL中Map的按Key排序和按Value排序
- C/C++——strcpy函数的实现
- 三种单例模式的C++实现
- C++定义的时钟类(主要是类的定义、数据成员、成员函数的定义,类对象的定义及对象之间的赋值的简单例子)