Java_第一次作业一稿修改建议

主函数

1、字符串s可内置于ComeputePoly中,使多项式计算完全封闭 

2、未将超长字符串与简单字符串匹配统一

3、缺少try catch结构

ComputePoly类

1、在将多项式实例化时,字符串分割方法丑陋

Poly类

 Crash报告

在本次作业中出现一次crash报告:

在进行超长字符串判断时,由于开始时未考虑超长字符串会导致正则表达式栈溢出问题,因此采取打补丁的方式进行解决。打补丁时将字符串进行分割,分割采用的正则表达式直接选择pattern(单个多项式正则表达式)进行判断。由于pattern书写格式如下所写:

pattern="[+-]?"+Bracket+"("+"[+-]"+Bracket+"){0,19}";

致使分割字符串s左花括号外不具有正负符号,仍可进入到计算模块,导致ERROR表达式误判为正确,为后续模块crash埋下伏笔。

当我再回看自己的程序时,我发现这个问题并没有被catch出来,我所被crash的bug其实是因为:

对于超长字符串我并没有20项的项数上限判断,即便超出20项也会计算。又因为多项式数组有上限,因此当超出25项时程序便会溢出崩溃。。。。。

 

原文地址:https://www.cnblogs.com/greystone/p/8592665.html