博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
基于C/C++的二维动态数组构建
阅读量:4214 次
发布时间:2019-05-26

本文共 1288 字,大约阅读时间需要 4 分钟。

基于C/C++的二维动态数组构建

本文对c/c++中构建二维动态数组的方法进行了总结,主要使用了malloc,calloc,new三种函数。二维动态数组相当于每个元素为一个指针的一维数组,这个一维数组就是行;每个指针又指向一个存储空间,这个存储空间就是每一列。再通过使用malloc,calloc,new等函数为每个元素动态分配空间,就实现了二维动态数组。

1.基于malloc的二维动态数组构建

malloc函数的原型声明为

void *malloc(unsigned int size);
malloc申请了size大小的存储空间,返回了一个指向该空间的通用指针(通用指针即为可以指向任何基类型)。由于malloc本身没有确定存储的数据类型,所以在使用的时候需要进行强制类型转换,即(char *)
char **p是定义了一个二级指针,即p是一个指针,它指向的存储空间存放了一个指向char类型的指针。
先给行数组分配内存
char **p=(char **)malloc(sizeof(char *)*size)
数组中的元素类型是二级指针p,即char **p。
分配到的内存长度则为行数size乘以每个元素的大小。这里的元素是指针,即元素长度为地址长度。*是乘还是解引用运算符由编译器自己判别。

#include "stdafx.h"#include "stdlib.h"int main(){
int row,column; int i,j; printf("please enter the row and column\n"); scanf_s("%d %d",&row,&column); char **p=(char**)malloc(sizeof(char*)*row); //构造二维数组 for(i=0;i

在这里插入图片描述

2.基于calloc的二维动态数组构建

calloc的函数原型声明

void *calloc (unsigned int num,unsigned int size);

#include "stdafx.h"#include "stdlib.h"int main(){
int row,column; int i,j; char **p; scanf_s("%d %d",&row,&column); //建立二维数组 p=(char**)calloc(row,sizeof(char*)); for(i=0;i

在这里插入图片描述

3.基于new的二维动态数组构建

#include "stdafx.h"#include 
using namespace std; int main(){
int row,column; int i,j; cout<<"please enter row and column"<
>row>>column; //定义二维数组 char **p; p=new char*[row]; for(i=0;i

在这里插入图片描述

转载地址:http://xndmi.baihongyu.com/

你可能感兴趣的文章
JVM垃圾回收相关知识笔记
查看>>
第一次炒股小记
查看>>
《redis in action》redis发布订阅
查看>>
《redis in action》sort排序命令
查看>>
《redis in action》redis事务
查看>>
《redis in action》key的自动过期
查看>>
《redis in action》redis持久化简介
查看>>
Oracle RAC Failover 详解
查看>>
批处理 自动修改 IP 地址
查看>>
Oracle RAC LoadBalance
查看>>
v$sql,v$sqlarea,v$sqltext 和 v$sql_plan 说明
查看>>
ORA-31623 When Submitting a Datapump Job [ID 308388.1]
查看>>
Oracle SYSAUX 表空间 说明
查看>>
RAC 安装patch 后启动实例 报错 ORA-00439 feature not enabled- Real Application Clusters 解决方法
查看>>
On RAC, expdp Removes the Service Name [ID 1269319.1]
查看>>
Important Changes to Oracle Database Patch Sets Starting With 11.2.0.2 [ID 1189783.1]
查看>>
Oracle alert log ALTER SYSTEM SET service_names='','SYS$SYS.KUPC$C_...' SCOPE=MEMORY SID='' 说明
查看>>
Oracle latch:library cache 导致 数据库挂起 故障
查看>>
Openfiler 配置 NFS 示例
查看>>
Oracle 11.2.0.1 RAC GRID 无法启动 : Oracle High Availability Services startup failed
查看>>