2.11-12 滴水new-delete-vector(动态数组编写)
去长沙玩了几天,没学
1.new 与 delete

通过调用分析了解到new在堆区开辟数据 delete就是释放数据
案例
#include<stdio.h>
#include <malloc.h>
class ae
{
public:
~ae()
{
printf("释放中");
};
private:
};
int main(int argc, char* argv[])
{
ae* a1 = new ae[10];
delete[] a1;
}
2.12
vector(动态数组编写)

案例2
.c文件
#include<stdio.h>
#include"a.h"
void test1()
{
Vector<int >* pvector = new Vector<int>(5);
pvector->push_back(3);
pvector->push_back(5);
pvector->insert(1, 9);
int a = 0;
pvector->at(8,&a);
printf("取出来的是%d", a);
delete pvector;
}
int main()
{
test1();
return 0;
}
.h 文件
#include<Windows.h>
#define SUCCESS 1 // 成功
#define MALLOC_ERROR -2 // 申请内存失败
#define INDEX_ERROR -3 // 错误的索引号
template <class T_ELE>
class Vector
{
public:
Vector();
Vector(DWORD dwSize);
~Vector();
public:
DWORD at(DWORD dwIndex, OUT T_ELE* pEle);
DWORD push_back(T_ELE Element);
VOID pop_back();///存储数据
DWORD insert(DWORD dwIndex, T_ELE Element);
DWORD capacity();
VOID clear();
BOOL empty();
VOID erase(DWORD dwIndex);
DWORD size();
private:
BOOL expand();
private:
DWORD m_dwIndex;///实时长度
DWORD m_dwIncrement;//增加长度
DWORD m_dwLen;//长度
DWORD m_dwInitSize;//大小
T_ELE* m_pVector;//地址
};
template <class T_ELE>
Vector<T_ELE>::Vector()
:m_dwInitSize(100), m_dwIncrement(5)
{
//1.创建长度为m_dwInitSize个T_ELE对象
m_pVector = new T_ELE[m_dwInitSize];
printf("%x\n", m_pVector);
//2.将新创建的空间初始化
memset(m_pVector, 0, m_dwInitSize * sizeof(T_ELE));
//3.设置其他值
m_dwLen = 100;
m_dwIndex = 0;
//// 返回
}
template <class T_ELE>
Vector<T_ELE>::Vector(DWORD dwSize)
:m_dwIncrement(5)
{
//1.创建长度为m_dwInitSize个T_ELE对象
m_pVector = new T_ELE[dwSize];
printf("%x\n", m_pVector);
//2.将新创建的空间初始化
memset(m_pVector, 0, dwSize * sizeof(T_ELE));
//3.设置其他值
m_dwLen = dwSize;
m_dwIndex = 0;
//// 返回
}
template <class T_ELE>
Vector<T_ELE>::~Vector()
{
printf("释放成功");
delete[] m_pVector;
m_pVector = NULL;
}
template <class T_ELE>
BOOL Vector<T_ELE>::expand()
{
T_ELE* m_ptemp = NULL;//地址
///增加以后的长度
// 1. 计算增加后的长度
DWORD dwTemplen = m_dwLen + m_dwIncrement;
// 2. 申请空间
m_ptemp = new T_ELE[dwTemplen];
// 3. 将数据复制到新的空间
memcpy(m_ptemp, m_pVector, sizeof(T_ELE) * m_dwLen);
// 4. 释放原来空间
delete[] m_pVector;
m_pVector = m_ptemp;
m_ptemp = NULL;
// 5. 为各种属性赋值
m_dwLen = dwTemplen;
return true;
}
template <class T_ELE>
DWORD Vector<T_ELE>::push_back(T_ELE Element)
{
//1.判断是否需要增容,如果需要就调用增容的函数
//索引与最大
if (m_dwIndex >= m_dwLen)
{
expand();
}
//2.将新的元素复制到容器的下一个位置
memcpy(&m_pVector[m_dwIndex], &Element, sizeof(T_ELE));
//3.修改属性值
m_dwIndex++;
return SUCCESS;
}
template <class T_ELE>
DWORD Vector<T_ELE>::insert(DWORD dwIndex, T_ELE Element)
{
//1.判断是否需要增容,如果需要就调用增容的函数
if (m_dwIndex >= m_dwLen)
{
expand();
}
//2.判断索引是否在合理区间
if (dwIndex <0 || dwIndex > m_dwLen)
{
printf("输入错误");
}
//3.将dwIndex之后的元素后移
// 1 2 3 5 4 5 6 7 8
//4.将Element元素复制到dwIndex位置
for (int i = m_dwIndex; i >dwIndex; i--)
{
memcpy(&m_pVector[i], &m_pVector[i-1], sizeof(T_ELE));
}
memcpy(&m_pVector[dwIndex], &Element, sizeof(T_ELE));
//5.修改属性值
m_dwIndex++;
return SUCCESS;
}
template <class T_ELE>
DWORD Vector<T_ELE>::at(DWORD dwIndex, T_ELE* pEle)
{
//判断索引是否在合理区间
if (dwIndex <0 || dwIndex > m_dwLen-1)
{
printf("输入错误 取出来的是乱码:\n");
}
//将dwIndex的值复制到pEle指定的内存
memcpy(pEle, &m_pVector[dwIndex], sizeof(T_ELE));
return SUCCESS;
}
//其他函数。。自己实现
2.11-12 滴水new-delete-vector(动态数组编写)的更多相关文章
- C++ vector动态数组
#include<vector>头文件 vector类称作向量类 百度百科的解释:https://baike.baidu.com/item/vector/3330482 我喜欢把知识点拿出 ...
- C++向量 vector动态数组
需要包含头文件, #include <vector> using namespace std; vector 容器与数组相比其优点在于它能够根据需要随时自动调整自身的大小以便容下所 ...
- Vector(动态数组)怎么用咧↓↓↓
定义方式:vector<int> a; //二维vector<int>a[100] 在末尾压入容器:a.push_back(x);//二维 a[i].push_back(x) ...
- vector动态数组
vector是STL模板库中的序列式容器,利用它可以有效地避免空间的浪费. 创建vector容器 vector< int >v:vector< char >:vector< ...
- vc++简单的vector动态数组实现
#ifndef __MYVECTOR__ #define __MYVECTOR__ #include <Windows.h> #define SUCCESS 1 // 成功 #define ...
- 八连通(vector动态数组法)
题目和一般的八连通一样,但行数和列数未定,相乘对于1e6,直接开a[1e6][1e6]的数组肯定会爆内存.用二维的动态vector就能很好的解决这个问题 #include<bits/stdc++ ...
- C++ Vector 动态数组
Vectors 包含着一系列连续存储的元素,其行为和数组类似.访问Vector中的任意元素或从末尾添加元素都可以在常量级时间复杂度内完成,而查找特定值的元素所处的位置或是在Vector中插入元素则是线 ...
- C++泛化动态数组
泛化动态数组 动态数组的核心思想是在存储数据时动态的管理数组元素占用的内存,通过调用动态数组的类方法来对数组中的数据进行增删改查操作.最初我们为数组申请10个元素的空间,放我们不断向数组中添加数据时, ...
- C++ Primer : 第十二章 : 动态内存之动态数组
动态数组的分配和释放 new和数组 C++语言和标准库提供了一次分配一个对象数组的方法,定义了另一种new表达式语法.我们需要在类型名后跟一对方括号,在其中指明要分配的对象的数目. int* arr ...
- c++ 动态内存 动态数组
动态内存-动态数组 习题12.23 //连接字符串到动态数组 char *c = new char[20](); char a[] = "hello "; char b[] = & ...
随机推荐
- 随笔——安卓手机调试微信网页,x5错误页
如果打开debugx5.qq.com提示您使用的不是x5内核 那么先打开debugmm.qq.com/?forcex5=true 再打开http://debugtbs.qq.com 将进入下面这个页面 ...
- 聊聊如何让办公网络直连Kubernetes集群PodIP/ClusterIP/Service DNS等
想象一下,如果您日常使用的研发测试Kubernetes集群,能够有以下效果: 在办公网络下直接访问Pod IP 在办公网络下直接访问Service Cluster IP 在办公网络下直接访问集群内部域 ...
- python关于error: invalid command 'bdist_wheel报错的解决
看了很多解决办法,大部分在扯去下载一个 .whl 源文件然后在pip 安装,经过我亲自测试执行完这句即可解决! pip3 install wheel
- easyUI ajax拼接样式失效
重新渲染: $.parser.parse()
- [.NET学习] EFCore学习之旅 -3 一些其他的迁移命令
1.Update-DataBase xxx 概述:将数据库回滚到某个版本. 1.首先创建一个表 Dog 2.生成迁移 Add-Migration CreateDogTable 并更新到数据库 Upd ...
- hexo-通过-metaweblog-api-同步各大博客网站
闲聊 不多逼逼了.上干货 如何写一篇文章同步到多个博客网站 最近通过hexo 建立了博客网站,发现流量少的可怜,那把文章发到各个博客网站呢,我又懒那通过一番研究 终于搞定了通过MetaWebLog A ...
- 【RocketMQ】主从同步实现原理
主从同步的实现逻辑主要在HAService中,在DefaultMessageStore的构造函数中,对HAService进行了实例化,并在start方法中,启动了HAService: public c ...
- 【精选】前端JS面试题35个
1.问:什么是匿名函数?作用是什么? 答:没有名字的函数就是匿名函数,作用有三,把函数当作变量赋值,把函数当作参数(回调函数),把函数当作另一个函数的返回值(闭包) ...
- virtualenv 配置(windows)
1.在线安装 virtualenv pip install virtualenv 2.离线安装 下载virtualenv包,解压并进入setup.py所在文件夹中 python setup.py in ...
- 重学c#系列——元组 [三十一]
前言 元组并不是c# 7.0的东西,早之前就有,叫做tuple.7.0加了valuetuple. 来看下元组吧,主要一些注意的地方. 正文 为什么在7.0 之前,元组用的不多呢? 因为tuple 在代 ...