背景:我的任务是编写一个程序,使用链表来跟踪纸牌游戏中的牌(战争)。所以我写了4个程序:card.java,deckofcards.java,hand.java,war.java(driver)。卡持有基本信息。当添加到卡的链接列表时,我使用名为setLast的方法:
nextCard=null;
public card(String a, String b)
{
hand=a;
suit=b;
}
public void setLast(card c)
{
if(nextCard==null)
{
nextCard = c;
}
else
{
nextCard.setLast(c);
}
}
然后在deckofcards.java中:
card deck, dealt;
public deckofcards()
{
rand = new Random();
dealt = new card("0","0"); //null card place holders
first = new card("0","0");
numcards = 52;
shuffle();
}
public card dealCard()
{
card c=new card("0","0");
if(first!= null)
{
c = first;
first = first.nextCard;
c.nextCard = null;
if(dealt.toString().compareTo("00")==0)
{
dealt = c;
}
else
{
dealt.setLast(c);
}
numcards--;
}
else
{
System.out.println("Deck: ran out of cards");
}
return c;
}
所以deckofcards随机生成52个(假设无论如何,但这是一个不同的问题)有序的牌和手将它们交给war.java中的hand.java实例
hand.java:
card cards;
int numcards;
public void getCard(card c)
{
System.out.println("In hand.java,getCard");
if (numcards==0)
{
cards = c;
numcards++;
}
else
{
cards.setLast(c);
}
}
和war.java:
players = new hand[numplayers];
for(int i=0;i<numplayers;i++)
{
players[i] = new hand();
}
deck = new deckofcards();
int i=0;
while(i<52)
{
int ii=0;
if((ii<numplayers)&&(i<52))
{
players[ii].getCard(deck.dealCard());
i++;
ii++;
}
else
{
ii=0;
}
}
输出: 在hand.java中,getCard 在hand.java中,getCard 线程“main”java.lang.StackOverflowError中的异常 在card.setLast(card.java:125) 在card.setLast(card.java:125) 在card.setLast(card.java:125) 在card.setLast(card.java:125) 在card.setLast(card.java:125) 在card.setLast(card.java:125) 在card.setLast(card.java:125) //重复1000次......
当然我只提供了我认为导致问题的代码片段,我可以根据请求提供整个代码。
答案 0 :(得分:0)
您的列表在某处有一个循环,即“A-> B-> C-> D-> B”。您是否有理由使用“空卡占位符”而不是值null?我注意到setLast正在为你的null占位符检查值'null'而不是'00',但是没有看到所有代码,很难分辨出你的列表在哪里循环。