标题:[求助]出现越界错误
只看楼主
autumnleaf
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2006-10-22
 问题点数:0 回复次数:15 
[求助]出现越界错误

//封装一个类型的栈
public class aaa2
{

private int maxsize;
private double element[];
private int top;
public aaa2(int n)
{
maxsize=n;
top=0;
element =new double[n];
}


public double gettop()
{
if(isempty())
{ System.out.println("there is no element.");
return 0.0;
}
else

{ return element[top--];//注意return 一定放在最后

}
}
public void push(double a)
{
if(isfull())
System.out.println("there is full of element");
else
{ top++;
element[top]=a;
}
}
public boolean isfull()
{
return (top==maxsize);

}

public boolean isempty()
{
return (top==0);

}

}


public class aaaa2
{
public static void main(String args[])
{
aaa2 stack=new aaa2(3);
double a,b,c,d,m;
a=1.0;
b=20.2;
c=21.3;
d=25.6;
stack.push(a);
stack.push(b);
stack.push(c);

m=stack.gettop();
System.out.println("m="+m);
}
}


以上是我写地小程序,就是一个栈,然后进栈出栈,可是再编译时没问题,但运行时发现了越界地错误。ArrayIndexOutOfBoundsException,当我去掉 c=21.3; d=25.6;就没有这样的错误了。可是我明明在发生越界时会打印出

("there is full of element");,

怎么会发生这样地情况呢?谢谢大家。请看一下。由于条件有限,没法每天上网看,所以可能无法及时回复大家。

搜索更多相关主题的帖子: element 越界 public double return 
2006-11-28 00:36
しΟν∈→鱈
Rank: 1
等 级:新手上路
威 望:2
帖 子:369
专家分:0
注 册:2006-10-25
得分:0 

你要处理这个错误 话要写异常处理的吧!!


开开心心的过&玩每一天!!!!
2006-11-28 09:18
千里冰封
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:灌水之王
等 级:版主
威 望:155
帖 子:28477
专家分:59
注 册:2006-2-26
得分:0 
top++;
element[top]=a;


问题就出现在这里

你是先自加后赋值的

所以,你element[0]是不会放东西进去的
当你放到第三个的时候,检查的时候还没有满,所以加进去时候就越界了

可惜不是你,陪我到最后
2006-11-28 09:19
angeloc
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:36
帖 子:1353
专家分:0
注 册:2006-11-21
得分:0 

public void push(double a)
{
if(isfull())
System.out.println("there is full of element");
else
{ top++; //这里有错误,造成数组越界
element[top]=a;//可以把这两句位置互换

}
}
public boolean isfull()
{
return (top==maxsize);

}


老牛明知夕阳晚,不用扬鞭自奋蹄; Angelo\'s BLOG
2006-11-28 09:29
しΟν∈→鱈
Rank: 1
等 级:新手上路
威 望:2
帖 子:369
专家分:0
注 册:2006-10-25
得分:0 

楼上的  写到一起不就好了嘛....element[top++]=a


开开心心的过&玩每一天!!!!
2006-11-28 10:04
autumnleaf
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2006-10-22
得分:0 

谢谢大家,我知道了,运行下来时对地,我觉得还有一种改法,//封装一个类型的栈
public class aaa2
{

private int maxsize;
private double element[];
private int top;
public aaa2(int n)
{
maxsize=n;
top=0;
element =new double[n];//改为 element =new double[n+1];
}


public double gettop()
{
if(isempty())
{ System.out.println("there is no element.");
return 0.0;
}
else

{ return element[top--];//注意return 一定放在最后

}
}
public void push(double a)
{
if(isfull())
System.out.println("there is full of element");
else
{ top++;
element[top]=a;
}
}
public boolean isfull()
{
return (top==maxsize);

}

这样运行下来也对地,谢谢啊


2006-11-28 12:30
千里冰封
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:灌水之王
等 级:版主
威 望:155
帖 子:28477
专家分:59
注 册:2006-2-26
得分:0 
你这又是何必呢,

这样改的话,第一个元素永远是空在那里的

可惜不是你,陪我到最后
2006-11-28 12:32
angeloc
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:36
帖 子:1353
专家分:0
注 册:2006-11-21
得分:0 
看来上面的帖子都白给他写了。。。

老牛明知夕阳晚,不用扬鞭自奋蹄; Angelo\'s BLOG
2006-11-28 13:41
しΟν∈→鱈
Rank: 1
等 级:新手上路
威 望:2
帖 子:369
专家分:0
注 册:2006-10-25
得分:0 

开开心心的过&玩每一天!!!!
2006-11-28 14:21
千里冰封
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:灌水之王
等 级:版主
威 望:155
帖 子:28477
专家分:59
注 册:2006-2-26
得分:0 
以下是引用angeloc在2006-11-28 13:41:09的发言:
看来上面的帖子都白给他写了。。。

确实是白给他写了


可惜不是你,陪我到最后
2006-11-28 14:54



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-105797-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.018217 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved