; }
这样就可以动态开辟空间,不用为长度不确定而烦恼了。
#include "stdafx.h"
#include <iostream>
using namespace std;
template <class T>
class MyArray
{
int len;
public:
T *data;
MyArray()
{
data = NULL;
len = 0;
}
~MyArray()
{
delete[] data;
}
T& operator [](int index);
void push(T d);
};
template <class T>
T& MyArray<T>:
perator [](int index)
{
if(index<0||index>(len-1))
{
cout<<"Bad subscript!"<<endl;
exit(1);
}
return data[index];
}
template <class T>
void MyArray<T>::push(T d)
{
T *pdata = data;
data = new T[len + 1];
if(pdata != NULL)
{
for(int i = 0 ; i < len ; i++)
{
data = pdata;
}
delete[] pdata;
}
data[len] = d;
len++;
}
//测试代码
int main(int argc, char* argv[])
{
MyArray<int> a;
a.push(11);
a.push(22);
a.push(33);
a.push(55);
a[0]=44;
cout<<a[0]<<endl<<a[1]<<endl<<a[2]<<endl<<a[3]<<endl;
return 0;
}
使用new动态分配存储空间 2 3 #include<iostream> 4 using std::cout; 5 6 int main() 7 { 8 // 第1种方式 9 int *a=new int;10 *a=1;11 cout<<"使用第一种方式进行动态分配存储空间的结果为:\n"12 <<"*a= "<<*a<<std::endl;13 delete a; // 释放动态存储空间14 // 第2种方式15 int *b=new int(2);16 cout<<"使用第一种方式进行动态分配存储空间的结果为:\n"17 <<"*b= "<<*b<<std::endl;18 delete b; // 释放动态存储空间19 // 第3种方式20 int *c;21 c=new int(3);22 cout<<"使用第一种方式进行动态分配存储空间的结果为:\n"23 <<"*c= "<<*c<<std::endl;24 delete c; // 释放动态存储空间25 26 // 动态创建数组27 float *d=new float [3];28 d[0]=3;29 d[1]=6;30 d[2]=8;31 cout<<"d[0]= "<<d[0]<<std::endl;32 d=d+1; //数组名和指针之间的根本区别33 cout<<"d[0]= "<<d[0]<<std::endl;34 d=d-1;35 cout<<"d[0]= "<<d[0]<<std::endl;36 delete [] d; // 释放动态存储空间37 return 0;38 }
作者: meng00123 时间: 2017-6-20 19:37
模板物超所值!!!!!
作者: cd0010 时间: 2017-6-21 21:33
,值得推荐
作者: 1124789174 时间: 2017-6-22 22:24
家,没一家利索的,虽然是一个小问题,但是困扰我很久,这个卖家分分钟给我搞完,给力不解释。
作者: brt02 时间: 2017-6-23 00:07
业,必须要好评啊,下次还会来的,么么哒!!!!!
作者: tian001 时间: 2017-6-25 14:10
的应该能用吧
作者: 西充 时间: 2017-7-2 07:49
,值得信赖
作者: xiaoyaoyao001 时间: 2017-7-2 20:31
很好,平台好用,操作简单,满意
作者: ctbvip 时间: 2017-7-3 07:52
码,卖家发货也很快,5分好评!
作者: linshihu 时间: 2017-7-13 07:16
效,沟通愉快!不错的店家!!!
作者: zdxhz 时间: 2017-7-15 17:13
,发货速度快,很值
作者: c19900420 时间: 2017-7-18 18:54
很好,值得信赖的店铺
欢迎光临 信息发布软件,b2b软件,广告发布软件 (http://postbbs.com/) |
Powered by Discuz! X3.2 |