typedef int int_array[4](转)

本文详细解析了C++中数组定义的方式和typedef关键字的使用,对比了两种定义数组的方法,并解释了为什么不能将typedef关键字的使用方式反转。文章还提到了C++与Java在数组定义上的差异,以及数组定义的细微之处。

转自:http://hi.baidu.com/sword0228/item/f9c0089ed23653da1e42716b

typedef int int_array[4];

int ia[3][4]={1,2,3,4,5,6,7,8,9,0,11,12};
int_array *ip=ia;

int ia[3][4]={1,2,3,4,5,6,7,8,9,0,11,12};
int (*ip)[4]=ia;

上面两段效果是一样的,typedef int int_array[4];这句大体上理解。
想问下为什么不写成typedef int[4] int_array;

C++中定义数组时的格式就是[]在数组名后,但数组的类型其实是数组名前的类型和[]以及数组的大小.

int arr[10],数组的类型是int[10],但C++中书写不能写成int[10] arr;
JAVA之所以受欢迎,在这些细微地方就设计得比较人性化,它允许这个数组定义写成int[10] arr;


typedef int int_array[4];
就算你把它想成名字替换,也是用int_array替换类型int[4]
为什么不能写成typedef int[4] int_array;这只能说,因为编译器已经设计成那样了,没有对错.
你也可以呼吁下一版C++标准允许那样写.

typedef int array[8];     
把int定义为array[8]  
typedef 是类型重定义

typedef int array[8];    
把array定义为有8个整数得数组类型   
array a 就相当于int a[8]

#include"Dynamicarray.h" //初始化 Dynamic_Array* Init_Array() { //申请myArray的内存 Dynamic_Array* myArray = (Dynamic_Array * )malloc(sizeof(Dynamic_Array)); //初始化myArray的各项数据 myArray->size = 0; myArray->capacity = 20; myArray->pAddr = (int*)malloc(sizeof(int) * myArray->capacity); return myArray; } //插入 void PushBack_Array(Dynamic_Array* arr, int value) { if (arr == NULL) { return; } if (arr->size==arr->capacity) { //申请新的空间 int* Newspace = (int*)malloc(sizeof(int) * arr->capacity * 2); //复制新空间 memcpy(Newspace, arr->pAddr, arr->capacity * sizeof(int)); //释放旧空间 free(arr->pAddr); //更新新的数据 arr->capacity = arr->capacity * 2; arr->pAddr = Newspace; //添加新的数据 arr->pAddr[arr->size] = value; arr->size++; } } //根据位置删除 void RemoveByPos_Array(Dynamic_Array* arr, int pos) { if (arr == NULL) { return; } for (int i = pos; i < arr->size - 1; i++) { arr->pAddr[i] = arr->pAddr[i + 1]; } arr->size--; } //根据数据删除 void RemoveByValue_Array(Dynamic_Array* arr, int value) { if (arr == NULL) { return; } int pos = -1; for (int i = 0; i < arr->size; i++) { if (arr->pAddr[i] == value) { pos = i; break; } } //int pos=Find_Array(arr,value); RemoveByPos_Array(arr, pos); } //查找 int Find_Array(Dynamic_Array* arr, int value) { if (arr == NULL) { return -1; } int pos = -1; for (int i = 0; i < arr->size; i++) { if (arr->pAddr[i] == value) { pos = i; break; } } return pos; } //打印 void Print_Array(Dynamic_Array* arr) { if (arr == NULL) { return; } for (int i = 0; i < arr->size; i++) { printf("%d", arr->pAddr[i]); printf("\n"); } } //释放动态数组内存 void FreeSpace_Array(Dynamic_Array* arr) { if (arr == NULL) { return; } if (arr != NULL) { free(arr-> pAddr); } free(arr); } //清空数组 void Clear_Array(Dynamic_Array* arr) { if (arr == NULL) { return; } arr->size = 0; } //获得动态数组容量 int Capacity_Array(Dynamic_Array* arr) { if (arr == NULL) { return -1; } return arr->capacity; } //获得动态数组当前元素个数 int Size_Array(Dynamic_Array* arr) { if (arr == NULL) { return -1; } return arr->size; } //根据位置获得数据 int At_Array(Dynamic_Array* arr, int pos) { return arr-> pAddr[pos]; } #ifndef DYNAMIC_ARRAY_H #define DYNAMIC_ARRAY_H #include<stdio.h> #include<stdlib.h> #include<string> //capacity表示我当前的内存空间一共可以存多少的元素 //size记录当前数组中的具体的元素个数 //动态数组的定义,动态增长数据要放在栈上 typedef struct DYNAMICARRAY { int* pAddr; int size; int capacity; } Dynamic_Array; //写出关于DAYNAMICARRAY的一系列的函数 //初始化 Dynamic_Array* Init_Array(); //插入 void PushBack_Array(Dynamic_Array* arr, int value); //根据位置删除 void RemoveByPos_Array(Dynamic_Array* arr, int pos); //根据数据删除 void RemoveByValue_Array(Dynamic_Array* arr, int value); //查找 int Find_Array(Dynamic_Array* arr, int value); //打印 void Print_Array(Dynamic_Array* arr); //释放动态数组内存 void FreeSpace_Array(Dynamic_Array* arr); //清空数组 void Clear_Array(Dynamic_Array* arr); //获得动态数组容量 int Capacity_Array(Dynamic_Array* arr); //获得动态数组当前数组容量 int Size_Array(Dynamic_Array* arr); //根据位置获得数据 int At_Array(Dynamic_Array* arr,int pos); #endif #include<string.h> #include<stdio.h> #include<stdlib.h> #include"DynamicArray.h" void test01() { Dynamic_Array* myArray = Init_Array(); for (int i = 0; i < 10; i++) { PushBack_Array(myArray, i); } Print_Array(myArray); FreeSpace_Array(myArray); } int main(void) { test01(); system("pause"); return 0; }错哪了,为什么没有输出
最新发布
09-01
C语言实现动态数组代码无法输出结果,可能有以下几种错误原因: ### 内存分配失败 在代码中使用 `malloc` 进行内存分配时,如果内存不足,`malloc` 会返回 `NULL`。若没有对返回值进行检查,后续对 `NULL` 指针的操作会导致程序崩溃,从而无法输出结果。例如在 `inti_data` 函数中: ```c D_array* inti_data(int capacity) { D_array* array = (D_array*)malloc(sizeof(D_array)); // 这里需要检查 array 是否为 NULL if (array == NULL) { return NULL; } array->ptr = (void**)malloc(sizeof(void*) * capacity); // 这里也需要检查 array->ptr 是否为 NULL if (array->ptr == NULL) { free(array); return NULL; } array->capacity = capacity; array->num = 0; return array; } ``` ### 头文件包含问题 如果头文件包含不正确,编译器可能无法找到函数声明,导致链接错误。在 `Dynamic_Array.h` 中定义了函数声明,`动态数组.c` 中包含了该头文件,需要确保头文件路径正确。若头文件路径有误,编译器会提示找不到函数声明的错误,导致程序无法正常编译和运行。 ### 函数实现问题 - **函数未实现**:在 `Dynamic_Array.h` 中声明了多个函数,如 `Init_Array`、`PushBack_Array` 等,但如果这些函数在对应的 `.c` 文件中没有实现,会导致链接错误,程序无法正常运行。 - **函数实现逻辑错误**:函数内部的逻辑错误也可能导致程序无法输出结果。例如,在插入元素时,如果没有正确处理数组容量和元素个数的关系,可能会导致数组越界访问,程序崩溃。 ### 主函数问题 在 `main` 函数中调用的测试函数 `test01` 可能存在问题。如果 `test01` 函数中的某个操作导致程序崩溃,就无法正常输出结果。例如,在 `test01` 函数中,调用 `PopBackByValue_Array` 函数时,如果传入的参数不正确,可能会导致数组越界访问,程序崩溃。 ### 示例代码检查 以下是 `Dynamic_Array.h` 和 `动态数组.c` 的示例代码,可检查代码是否正确实现: #### Dynamic_Array.h ```c #ifndef DYNAMIC_ARRAY_H #define DYNAMIC_ARRAY_H #include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct DYNAMICARRAY { int* pAddr; //存放数据的地址 int size; //当前有多少个元素 int capacity; //容量 } Dynamic_Array; //初始化 Dynamic_Array* Init_Array(); //插入 void PushBack_Array(Dynamic_Array* arr, int value); //删除位置 void Remove_Array(Dynamic_Array* arr, int pos); //根据值删除 void RemoveByValue_Array(Dynamic_Array* arr, int value); //查找 int Find_Array(Dynamic_Array* arr, int value); //打印 void Print_Array(Dynamic_Array* arr); //释放动态数组的内存 void FreeSpace_Array(Dynamic_Array* arr); //清空数组 void Clear_Array(Dynamic_Array* arr); //获得动态数组容量 int Capacity_Array(Dynamic_Array* arr); //获得动态数组元素的个数 int Size_Array(Dynamic_Array* arr); //根据位置获得某个元素的值 int At_Array(Dynamic_Array* arr, int pos); #endif ``` #### 动态数组.c ```c #include "Dynamic_Array.h" // 这里需要实现所有在 Dynamic_Array.h 中声明的函数 void test01() { //初始化 Dynamic_Array* myArray = Init_Array(); printf("数组容量= %d \n", Capacity_Array(myArray)); printf("数组大小= %d \n", Size_Array(myArray)); for (int i = 0; i < 30; i++) { PushBack_Array(myArray, i); } printf("数组容量= %d \n", Capacity_Array(myArray)); printf("数组大小= %d \n", Size_Array(myArray)); Print_Array(myArray); RemoveByValue_Array(myArray, 0); RemoveByValue_Array(myArray, 27); Print_Array(myArray); int pos = Find_Array(myArray, 5); printf("根据5查找到pos:%d,%d\n", pos, At_Array(myArray, pos)); FreeSpace_Array(myArray); } int main() { test01(); system("pause"); return 0; } ```
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值