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
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值