array.h

#ifndef _ARRAY_H_
#define _ARRAY_H_ #include <stdexcept> using namespace std; template
< typename T, int N >
class Array
{
T m_array[N];
public:
int length() const;
bool set(int index, T value);
bool get(int index, T& value);
T& operator[] (int index);
T operator[] (int index) const;
virtual ~Array();
}; template
< typename T, int N >
int Array<T, N>::length() const
{
return N;
} template
< typename T, int N >
bool Array<T, N>::set(int index, T value)
{
bool ret = ( <= index) && (index < N); if( ret )
{
m_array[index] = value;
} return ret;
} template
< typename T, int N >
bool Array<T, N>::get(int index, T& value)
{
bool ret = ( <= index) && (index < N); if( ret )
{
value = m_array[index];
} return ret;
} template
< typename T, int N >
T& Array<T, N>::operator[] (int index)
{
if( ( <= index) && (index < N) )
{
return m_array[index];
}
else
{
throw out_of_range("T& Array<T, N>::operator[] (int index)");
}
} template
< typename T, int N >
T Array<T, N>::operator[] (int index) const
{
if( ( <= index) && (index < N) )
{
return m_array[index];
}
else
{
throw out_of_range("T Array<T, N>::operator[] (int index) const");
}
} template
< typename T, int N >
Array<T, N>::~Array()
{ } #endif

HeapArray.h

#ifndef _HEAPARRAY_H_
#define _HEAPARRAY_H_ #include <stdexcept> using namespace std; template
< typename T >
class HeapArray
{
private:
int m_length;
T* m_pointer; HeapArray(int len);
HeapArray(const HeapArray<T>& obj);
bool construct();
public:
static HeapArray<T>* NewInstance(int length);
int length() const;
bool get(int index, T& value);
bool set(int index ,T value);
T& operator [] (int index);
T operator [] (int index) const;
HeapArray<T>& self();
const HeapArray<T>& self() const;
~HeapArray();
}; template
< typename T >
HeapArray<T>::HeapArray(int len)
{
m_length = len;
} template
< typename T >
bool HeapArray<T>::construct()
{
m_pointer = new T[m_length]; return m_pointer != NULL;
} template
< typename T >
HeapArray<T>* HeapArray<T>::NewInstance(int length)
{
HeapArray<T>* ret = new HeapArray<T>(length); if( !(ret && ret->construct()) )
{
delete ret;
ret = ;
} return ret;
} template
< typename T >
int HeapArray<T>::length() const
{
return m_length;
} template
< typename T >
bool HeapArray<T>::get(int index, T& value)
{
bool ret = ( <= index) && (index < length()); if( ret )
{
value = m_pointer[index];
} return ret;
} template
< typename T >
bool HeapArray<T>::set(int index, T value)
{
bool ret = ( <= index) && (index < length()); if( ret )
{
m_pointer[index] = value;
} return ret;
} template
< typename T >
T& HeapArray<T>::operator [] (int index)
{
if( ( <= index) && (index < length()) )
{
return m_pointer[index];
}
else
{
throw out_of_range("T& HeapArray<T>::operator [] (int index)");
}
} template
< typename T >
T HeapArray<T>::operator [] (int index) const
{
if( ( <= index) && (index < length()) )
{
return m_pointer[index];
}
else
{
throw out_of_range("T HeapArray<T>::operator [] (int index) const");
}
} template
< typename T >
HeapArray<T>& HeapArray<T>::self()
{
return *this;
} template
< typename T >
const HeapArray<T>& HeapArray<T>::self() const
{
return *this;
} template
< typename T >
HeapArray<T>::~HeapArray()
{
delete[]m_pointer;
} #endif
#include <iostream>
#include <string>
#include "Array.h"
#include "HeapArray.h" using namespace std; void TestArray()
{
Array<int, > a; for(int i=; i<a.length(); i++)
{
a[i] = i;
} for(int i=; i<a.length(); i++)
{
cout << a[i] << endl;
}
} void TestHeapArray()
{
HeapArray<double>* pa = HeapArray<double>::NewInstance(); if( pa != NULL )
{
HeapArray<double>& array = pa->self(); for(int i=; i<array.length(); i++)
{
array[i] = i;
} for(int i=; i<array.length(); i++)
{
cout << array[i] << endl;
}
} delete pa;
} int main(int argc, char *argv[])
{ try
{
TestArray(); cout << endl; TestHeapArray();
}
catch(...)
{
cout << "Exception" << endl;
} return ;
}

最新文章

  1. android XML布局 属性与运用
  2. For循环案例---九九乘法表
  3. sql 存储过程 分页
  4. Struct2提交表单数据到Acion
  5. 利用if else 求已发奖金总数
  6. DelphiXe5中的双向绑定(使用使用TBindScope和TBindExpression,并覆盖AfterConstruction函数)
  7. Java面试通关要点汇总集
  8. ORACLE ERP各模块会计分录
  9. keras用法
  10. CTF资料
  11. 实训任务01:安装Hadoop
  12. Asp.Net项目与TCP服务端交互
  13. spring boot 启动脚本
  14. 在linux下面解压用的zxpf是什么意思,它跟zxvf有啥区别
  15. 不修改模板的前提下修改VisualState中的某些值
  16. PAT 1013 数素数
  17. graphite custom functions
  18. 【代码笔记】iOS-JQIndicatorViewDemo
  19. 合格PHP工程师的知识结构
  20. Notepad++怎么使用正则替换

热门文章

  1. Linux系统学习 四、网络基础—互联网概述,互联网接入方式
  2. Python函数名做参数,闭包,装饰器
  3. JavaScript-----6.流程控制:分支
  4. 201871010116-祁英红《面向对象程序设计(java)》第十四周学习总结
  5. GAN网络原理介绍和代码
  6. Numpy 随机序列 shuffle &amp; permutation
  7. ViewTool Hollong BLE Sniffer Support Linux OS Introduction
  8. Leetcode练习题 Palindrome Number
  9. SpringBoot系列之配置文件加载位置
  10. 实现简易JDBC框架