Java 线程中的某些代码不重复
正在发生的事情是:我正在尝试创建一个游戏,在这个游戏中,Cannon类的玩家objectof射击敌人的Foeder类和Danger类的对象,这两个类都是敌人类的子类,都是由generate方法生成的,在run方法中调用。线程在另一个类中启动 但是,我从未创建过一个敌人对象。我插入了一些println语句来检查程序是如何运行的,结果是:A获得和B获得永远不会发生,我得到的只是检查1、检查2、检查3,然后是检查4和检查5的无休止循环 此外,玩家对象确实被创建并正确绘制,但只是随机绘制。在不改变任何内容的情况下运行代码的不同尝试中,结果总是在工作和不绘制之间变化Java 线程中的某些代码不重复,java,multithreading,swing,Java,Multithreading,Swing,正在发生的事情是:我正在尝试创建一个游戏,在这个游戏中,Cannon类的玩家objectof射击敌人的Foeder类和Danger类的对象,这两个类都是敌人类的子类,都是由generate方法生成的,在run方法中调用。线程在另一个类中启动 但是,我从未创建过一个敌人对象。我插入了一些println语句来检查程序是如何运行的,结果是:A获得和B获得永远不会发生,我得到的只是检查1、检查2、检查3,然后是检查4和检查5的无休止循环 此外,玩家对象确实被创建并正确绘制,但只是随机绘制。在不改变任何内
我真的很想知道我哪里做错了,非常感谢 whiletrue不包括敌人一代。该条件只能输入一次,因为此时第一次调用run时的timecount是1,而不是0,这意味着永不输入。欢迎使用。考虑POST哇,因为我把一切都在真的,它确实工作,非常感谢!我想我以前对跑步的想法是错误的,认为它总是自动重复。不过,你知道为什么程序有时只能正常运行吗?就像我所做的一样,只需按“运行”按钮,结果就永远不会稳定。@OryolUperi听起来像是您遇到了并发问题。多线程编程并不容易,如果您没有仔细学习教程,代码可能充满了竞争条件和其他bug。
package TheWork;
import java.awt.Color;
import java.awt.Graphics;
import java.awt.event.KeyEvent;
import java.awt.event.KeyListener;
import java.util.Arrays;
import java.util.Random;
import java.util.Timer;
import java.util.TimerTask;
import javax.swing.JPanel;
public class MainPanel extends JPanel implements KeyListener, Runnable
{
private Cannon P1 = Cannon.getPlayer();
private TheirBullet[] bullets = {};
private TheirRocket[] rockets = {};
private Enemy[] enemies = {};
private long timeCount = 0;
private int timeDis = 10;
public void drawCannon(Graphics g)
{
g.setColor(Color.BLUE);
g.fillRect((int)P1.getX() - 20, (int)Cannon.POS_Y, 40, 20);
g.fillRect((int)P1.getX() - 5, (int)Cannon.POS_Y - 5, 2, 20);
g.fillRect((int)P1.getX() + 3, (int)Cannon.POS_Y - 5, 2, 20);
}
public void drawGoodBullet(Graphics g)
{
for(YourBullet temp : P1.bullets)
{
if(temp != null && temp.hit == false)
{
g.setColor(Color.BLUE);
g.drawRect((int)temp.x - 2, (int)temp.y - 2, 4, 4);
}
if(temp.hit == true)
{
P1.bullets.remove(temp);
}
}
}
public void drawBadBullet(Graphics g)
{
for(int i = 0;i < bullets.length;i++)
{
TheirBullet temp = bullets[i];
g.setColor(Color.GREEN);
g.drawRect((int)temp.x - 2, (int)temp.y - 2, 4, 4);
}
for(int i = 0;i < rockets.length;i++)
{
TheirRocket temp = rockets[i];
g.setColor(Color.RED);
g.drawRect((int)temp.x - 1, (int)temp.y - 4, 2, 8);
}
}
public void drawEnemy(Graphics g)
{
for(int i = 0;i < enemies.length;i++)
{
Enemy temp = enemies[i];
if(temp instanceof Fodder)
{
g.setColor(Color.GREEN);
}
else
{
g.setColor(Color.RED);
}
g.fillRect((int)temp.getX() - 10, (int)temp.getY() - 5, 20, 10);
g.fillRect((int)temp.getX()-2, (int)temp.getY(), 4, 10);
}
}
@Override
public void paint(Graphics g)
{
super.paint(g);
drawCannon(g);
drawGoodBullet(g);
drawBadBullet(g);
drawEnemy(g);
}
@Override
public void run()
{
timeCount++;
System.out.println("check 1");
if(timeCount % 300 == 0)
{
Enemy poorThing = generate();
System.out.println("get");
enemies = Arrays.copyOf(enemies, enemies.length + 1);
enemies[enemies.length - 1] = poorThing;
}
System.out.println("check 2");
for(int i = 0;i < enemies.length;i++)
{
Enemy temp = enemies[i];
temp.move();
}
System.out.println("check 3");
while(true)
{
try
{
Thread.sleep(timeDis);
}
catch (InterruptedException e)
{
e.printStackTrace();
}
System.out.println("check 4");
this.repaint();
System.out.println("check 5");
}
}
@Override
public void keyPressed(KeyEvent e)
{
if(e.getKeyCode() == KeyEvent.VK_LEFT && P1.getX() > 20)
{
P1.goLeft();
P1.setWay(-1);
}
else if(e.getKeyCode() == KeyEvent.VK_RIGHT && P1.getX() < 780)
{
P1.goRight();
P1.setWay(1);
}
if(e.getKeyCode() == KeyEvent.VK_SPACE)
{
if(P1.bullets.size() <= 6)
{
P1.shoot();
}
}
this.repaint();
}
@Override
public void keyReleased(KeyEvent arg0) {
// TODO Auto-generated method stub
}
@Override
public void keyTyped(KeyEvent arg0) {
// TODO Auto-generated method stub
}
public static Enemy generate()
{
Random r = new Random();
Random s = new Random();
Random t = new Random();
int chance = r.nextInt(10);
int dirDec = s.nextInt(2);
int tirDec = t.nextInt(5);
if(chance >= 8)
{
System.out.println("A acquired");
return new Danger(dirDec, tirDec);
}
else
{
System.out.println("B acquired");
return new Fodder(dirDec, tirDec);
}
}
}