C语言中数组超出范围,检测数组下标边界是否超出范围解决方案

C语言中数组超出范围,检测数组下标边界是否超出范围解决方案C/C++codetemplateclassArray;templateclassArrayBody{friendclassArray;T*tpBody;intiRows,iColumns,iCurrentRow;ArrayBody(intiRsz,intiCsz){tpBody=newT[iRsz*iCsz];iRows=iRsz;iColumns=iCsz…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

C/C++ codetemplate class Array;

template

class ArrayBody

{

friend class Array;

T* tpBody;

int iRows,iColumns,iCurrentRow;

ArrayBody(int iRsz, int iCsz)

{

tpBody= new T[iRsz*iCsz];

iRows= iRsz; iColumns = iCsz; iCurrentRow = -1;

}

public:

T& operator[](int j)

{

bool row_error,column_error;

row_error=column_error=false;

try

{

if(iCurrentRow <0 || iCurrentRow >= iRows)

row_error = true;

if(j<0 || j >= iColumns)

column_error=false;

if(row_error== true || column_error == true)

throw ‘e’;

}

catch(char)

{

if (row_error == true)

cerr<

if(column_error== true)

cerr<

cout<

}

return tpBody[iCurrentRow*iColumns+j];

}

~ArrayBody(){delete[] tpBody;}

};

template class Array

{

ArrayBody tBody;

public:

ArrayBody & operator [](int i)

{

tBody.iCurrentRow= i;

return tBody;

}

Array(int iRsz, int iCsz):tBody(iRsz,iCsz){}

};

void main()

{

Array a1(10,20);

Array a2(3,5);

int b1;

double b2;

b1 = a1[-5][10];

b1 = a1[10][15];

b1 = a1[1][4];

b2 = a2[2][6];

b2 = a2[10][20];

b2 = a2[1][4];

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/180570.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • bigdecimal除法运算保留两位小数_bigdecimal保留两位小数显示00

    bigdecimal除法运算保留两位小数_bigdecimal保留两位小数显示00**问题:**将两个long类型的数相除后转换为BigDecimal类型并保留两位小数。思路:1.先将long转换为double类型再相除2.相除之后再转换为BigDecimal类型3.最后是设置小数位数,并设置两位小数后面的数的处置方式。代码:longnum1=5L;longnum2=20L;BigDecimalnum=BigDecimal.valueOf((double)num1/num2).setScale(2,BigDecimal.ROUND_HALF_UP);

    2022年9月23日
    0
  • 外网怎么访问内网ip_简述载波侦听多路访问的基本过程

    外网怎么访问内网ip_简述载波侦听多路访问的基本过程SQL Server使用侦听器IP访问时遇到”The target principal name is incorrect. Cannot generate SSPI context”…

    2022年4月20日
    40
  • [51Nod1676 无向图同构]无向图哈希[通俗易懂]

    [51Nod1676无向图同构]无向图哈希分类:DataStructureHash1.题目链接[51Nod1676无向图同构]2.题意描述3.解题思路对某一个东西进行哈希,一般就选取一些特征点,然后尽可能离散化这些特征点。对于无向图中的每一个联通块来说,他的特征点就是顶点的度。显然这样还不够,那么可以加入深度这个特征,只需要对联通块的每一个顶点bfs求一边单源点最短路。利用这两个特

    2022年4月10日
    53
  • c语言数组中插入新数据

    c语言数组中插入新数据数组插入数据 在数组的应用中,我们有时会向数组中插入一个数据,而且不打破原来的排序规律,其实数组中的插入数据,就是数据的比较和移动;如果想要弄懂这些方法最好拿笔比划以下,或者debug一下,了解其中的思想,光看理解的不深;方法一:输入一个数据x,将数组中的数据与x逐一比较,如果大于x,记录下数据的下标,然后此数据下标和其后的数据的下标都加一,相当于都向后挪一位,然后将x赋值给数组的那…

    2022年7月11日
    15
  • 误删数据?如何快速恢复Oracle数据库[通俗易懂]

    误删数据?如何快速恢复Oracle数据库[通俗易懂]误删oracle数据库中的数据,在不考虑全库备份和利用归档日志情况,怎样快速恢复数据呢?下面介绍3种方法。1.利用oracle提供的闪回方法进行数据恢复,适用于delete删除方式首先获取删除数据的时间点:select*fromv$sqlwheresql_textlike’%table_name%’;1根据结果中的sql_text内容,找到delete执行语句对应的删除时间点,执行下面语句查询出删除的数据。select*fromtable_nameasoftim

    2022年9月2日
    1
  • 项目总结笔记系列 wsTax KT Session2 代码分析

    项目总结笔记系列 wsTax KT Session2 代码分析

    2021年9月5日
    42

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号