二维数组的动态分配(new)、初始化(memset)和撤销(delete)
来自http://blog.csdn.net/maverick1990/article/details/22829135
一维数组
动态分配,int *array = new int[10]
初始化,memset(array,0,sizeof(int)*10);
撤销,delete[] array
二维数组m行n列
int **d;
d = new int *[];
for(int i =;i<;i++){
d[i] = new int[]
}
先分配一个10单元的数组指针的指针的首地址给**d,然后对其每个首地址进行遍历,
完成一个5单元的数组的动态分配,并把首地址给*d[i],最后完成d[10][5]的动态分配。
怎么初始化二维数组?
void memset(void* dest,int c,size_t count)////
sets buffers to a specified character.
memset只能作用于一个一维数组的void *dest,因此最好的方法就是和二维数组的动态分配,
memset最好用来初始化数组为零,初始化bool数组
结合起来,new一个,memset一个。
例如:
int **d;
d = new int *[];
for(int i = ;i<;i++){
d[i] = new int[];
memset(d[i],,*sizeof(int));///当sizeof一个指针时,返回值为指针本身的大小而不是指针指向区域的大小,
///所以第三个要明确空间大小,不能sizeof(d[i]).
}
如何撤销?
for(int i = 0;i<10;i++){
delete[] a[i];
}
delete[] a;
=========================
来个例子,
class A{
public:
void test_memset(){
///============
int *d;
d = new int[];
memset(d,-,sizeof(int)*);
for(int i = ;i<;i++){
cout<<d[i]<<" ";
}cout<<endl;
delete[] d;
///==============
int **a;
a = new int*[];
for(int i = ;i<;i++){
a[i] = new int[];
memset(a[i],-,sizeof(int)*);
}
for(int i = ;i<;i++){
for(int j = ;j<;j++){
cout<<a[i][j]<<" ";
}cout<<endl;
}
for(int i = ;i<;i++){
delete[] a[i];
}
delete[] a; ///====================
int ***c;
c = new int**[];
for(int i = ;i<;i++){
c[i] = new int*[];
for(int j = ;j<;j++){
c[i][j] = new int[];
memset(c[i][j],-,sizeof(int)*);
}
} for(int i = ;i<;i++){
for(int j = ;j<;j++){
for(int k = ;k<;k++){
cout<<"i-j-k"<<i<<j<<k<<"~"<<c[i][j][k]<<" ";
}cout<<endl;
}cout<<endl<<endl;
}
///=========== for(int i = ;i<;i++){
for(int j = ;j<;j++){
delete[] c[i][j];
}
delete[] c[i];
}
delete[] c;
cout<<"destoryed done!"<<endl;
}
};
二维数组的动态分配(new)、初始化(memset)和撤销(delete)的更多相关文章
- C++二维数组讲解、二维数组的声明和初始化
我们知道,一维空间是一条线,数学中用一条数轴来表达:二维空间是一个平面,数学中用平面坐标系来表达.那么二维数组又是什么样的呢? 线与面 我们用一个下标来描述一维数组中的某个元素,就好像在用数描述一条线 ...
- [zt]C++二维数组讲解、二维数组的声明和初始化
定义: int *pia = new int[10]; // array of 10 uninitialized ints 此 new 表达式分配了一个含有 10 个 int 型元素的数组,并返回指向 ...
- 关于c语言二维数组与指针的个人理解及处理办法。
相信大家在学习C语言时,对一维数组和指针的理解应该是自信的,但是,我在学习过程中,看到网上一些博文,发现即便是参加工作的一些专业编程人员,突然碰到二维数组和指针的问题时,也可能会遇到难以处理的诡异问题 ...
- C指针 指针和数组 二维数组的指针 指针应用
直接到变量名标识的存储单元中读取变量的值--直接寻址 通过其他变量间接找到变量的地址读取变量的值--间接寻址 指针变量存放地址 显示变量的地址 指针变量使用前必须初始化,若不知指向哪,可先指向NULL ...
- JS的二维数组
今天,记录一下JS的二位数组,并附上例题. 一.二维数组的本质:数组中的元素又是数组. 其实,我们都见过这样的二维数组,只不过没在意罢了,例如: var arr = [[1,2,4,6],[2,4,7 ...
- c++用vector创建二维数组
1 vector二维数组的创建和初始化 std::vector <int> vec(10,90); //将10个一维动态数组初始为90std::vector<std::vector& ...
- Java编程基础阶段笔记 day06 二维数组
二维数组 笔记Notes 二维数组 二维数组声明 二维数组静态初始化与二位初始化 二维数组元素赋值与获取 二维数组遍历 二维数组内存解析 打印杨辉三角 Arrays工具类 数组中常见的异常 二维数组 ...
- C#学习笔记04--排序/查找/二维数组/交叉数组
一. 冒泡排序(重点) 思路: 每次比较把较小的放在前面, 大的放到后面; 图解:下图是最坏情况下的排序 ` 冒泡排序m个元素, 就有(m-1)趟排序, 第一趟m-1次, 第二趟 m-2次.... ...
- C++二维数组(指针)做参数
一.问题描述 使用C++编程过程中经常需要使用到二维数组,然而初级程序员在使用过程中经常会出错使程序崩溃.下面就二维指针的定义,初始化,以及二维指针做参数给出简单介绍. 1.二维数组的定义与初始化 在 ...
随机推荐
- pat乙级1045
从左到右扫描时记录扫描到当前下标为止的最大值,如果当前元素大于这个最大值,那么它就大于它左边的所有值.同理,从右到左扫描记录扫描到当前下标为止的最小值,如果当前元素小于这个最大小值,那么它就小于它右边 ...
- JavaScript and Ruby in ABAP
Netweaver里有个mini JavaScript engine CL_JAVA_SCRIPT, 对于Js code的编译和执行都是用system call完成. 只能当玩具用:report SJ ...
- netcat 详解
简介 netcat 是一款调试 TCP/UDP 网络连接的利器,常被称作网络调试的瑞士军刀,可见其功能强大. netcat 在 Linux, Windows 等各大操作系统上都有对应等发行版,以下以 ...
- JS.match方法 正则表达式
match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配. 该方法类似 indexOf() 和 lastIndexOf(),但是它返回指定的值,而不是字符串的位置. <sc ...
- 第八章 熟练dom的几个常用方法
显示“缩略词语” <abbr> 标签指示简称或缩写,比如 <abbr title="World Wide Web Consortium">W3C</a ...
- C#做项目时的一些经验分享
1.对于公用的类型定义,要单独抽取出来,放到单独的DLL中. 2.通过大量定义interface接口,来提高模块化程度,不同功能之间通过实现接口来面向接口编程. 3.如果项目中存在很多非常相似,但是又 ...
- oracle安装报错[INS-30131]执行安装程序验证所需的初始设置失败(无法访问临时位置)解决方法!
最近在电脑上安装oracle12c,安装时,在执行检查环境步骤时候报错: [INS-30131]执行安装程序验证所需的初始设置失败(无法访问临时位置) 最后在网上搜索解决方法,特记录下,以防以后再用到 ...
- "segmentation fault " when "import tensorflow as tf"
https://github.com/tensorflow/tensorflow/issues/2034
- mantis基本配置及邮件服务器配置
邮件服务器配置 在c:\php-5.0.3\php.ini文件中查找smtp,将localhost改为你的发件服务器,如SMTP = smtp.163.com 在php.ini文件中查找sendm ...
- WPF中对XML的读写
XML(可扩展标记语言) 定义:用于标记电子文件使其具有结构性的标记语言,可以用来标记数据.定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言. 写操作: XmlTextWriter wri ...