数组下标重载

可以用类定义数组,其实数组的个数就是对象实例化的个数,如下:

#include <iostream>
using namespace std;
class Array{
public:
	Array(int length)
	{
		this->This_length = length;
		this->This_array = new int[This_length];
	}
	void SetArray(int value, int index)
	{
		this->This_array[index] = value;
	}
	Array(Array &oop)
	{
		this->This_length = oop.This_length;
		for (int i = 0; i < This_length; i++)
		{
			this->This_array[i] = oop.This_array[i];
		}
	}
	int operator[](int index)
	{
		if (index>This_length || index < 0)
		{
			cout << "数组越界" << endl;
			return this->This_array[0];
		}
		return this->This_array[index];
	}
private:
	int This_length;
	int *This_array;
};
int main(void)
{
	Array oop(10);
	for (int j = 0; j < 10; j++)
	{
		oop.SetArray(j+1, j);
	}
	for (int i = 0; i < 10; i++)
	{
	
		cout << oop[i] << endl;
	}
	system("pause");
	return 0;
}
在该实例中,定义十个对象,如果不进行数组下标重载,在输出时就必须重新定义一个成员函数:

int GetArray(int index)
	{
		return this->This_array[index];
	}
在主函数中电泳该成员函数,才能访问其内部成员,但是经过数组操作符重载就可想操作数组那样操作对象了

for (int i = 0; i < 10; i++)
	{
	
		cout << oop[i] << endl;
	}





在C++中,通过重载下标运算符`[]`可以让用户自定义类型的对象像访问数组一样操作数据成员。对于二维数组来说,我们通常需要两次使用下标运算符来完成元素的定位。 ### 实现步骤 假设我们需要创建一个类 `Matrix` 来表示二维数组,并支持类似矩阵的操作: #### 示例代码 ```cpp #include <iostream> using namespace std; class Matrix { private: int rows; // 行数 int cols; // 列数 int** data; // 动态分配的二维数组 public: // 构造函数初始化二维数组 Matrix(int r, int c) : rows(r), cols(c) { data = new int*[rows]; for (int i = 0; i < rows; ++i) { data[i] = new int[cols]{}; } } // 拷贝构造函数、析构函数等省略... // 下标运算符的一级重载返回某一行 int* operator[](int rowIndex) { if (rowIndex >= rows || rowIndex < 0) throw out_of_range("Row index is out of range"); return data[rowIndex]; // 返回指向该行的指针 } // 获取列值的常量版本(防止修改) const int* operator[](int rowIndex) const { if (rowIndex >= rows || rowIndex < 0) throw out_of_range("Row index is out of range"); return data[rowIndex]; } ~Matrix() { // 析构函数释放动态内存 for (int i = 0; i < rows; ++i) delete[] data[i]; delete[] data; } void display() { for (int i = 0; i < rows; ++i) { for (int j = 0; j < cols; ++j) { cout << (*this)[i][j] << " "; // 使用operator[] } cout << endl; } } }; int main() { Matrix m(3, 4); m[1][2] = 5; // 调用重载后的 [] 运算符设置值 m.display(); // 显示结果 try { cout << m[10][0]; // 测试越界检查 } catch (const exception& e) { cerr << e.what() << '\n'; // 输出错误信息 } return 0; } ``` --- ### 工作原理解析 1. **一级下标运算符** - 首先我们在类内重载了单个`[]`运算符,它接受一个整型作为索引参数。 - 我们将这一层理解为获取“某一维度”,即指定具体的行号并返回其对应的数据地址(如上例中的`data[rowIndex]`)。 2. **二级下标运算符** - 第一次调用了`matrixObj[index_row][]`, 得到的是指向当前行的一个指针;然后第二次直接对这个指针对应的内容应用普通的 C 数组语法 `[index_col]` 即可最终取得目标位置处存储的数据项。 3. **边界条件检测** - 当然,在实际项目里建议加入必要的异常处理机制以免发生非法存取的问题,比如超出预先设定大小等情况下的报错提示功能就显得尤为重要啦! ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值