我编写了一个小游戏,其目标是管理商场。我的问题是动画。
实际上,我的同事创建了扩展Animateur
并实现Thread
的课程Runnable
。
在我的框架中,我声明并初始化此类,按下按钮,我需要执行run()
。
动画包括来自商场一侧的人,买东西并离开另一边。
要开始天,我需要调用run()
方法。
第一天,在推动之后,一切都很完美:我看到了所有人。但是,当我第二次按下相同的按钮,开始新的一天,任何工作,我被卡住了。
我无法玩,因为我无法开始新的一天 - 再次执行run()
课程中的Animateur
。
有人可以帮助我或给我一些想法来解决这个问题吗? :(
package myMall;
import java.util.ArrayList;
import java.util.List;
import javax.swing.JOptionPane;
public class Animateur extends Thread implements Runnable {
private int giorno = 1;
private int giornoAttuale=1;
private int delay = 30;
private int nbVisiteurs =0;
private int k=0;
private double gainmoyen;
public MonMall m;
public List<Integer> w = new ArrayList<Integer>();
public List<Integer> e = new ArrayList<Integer>();
public int [] r = new int[6];
public Animateur(MonMall k) {
this.m = k;
m.setGainmoyen((int)this.gainmoyen);
m.setVisitestructure(this.r);
}
public void setAvance(){
this.giornoAttuale++;
}
public void run() {
while (m.isSimulation()) {
if(giorno<=giornoAttuale){
k = k + 30;
if (k < 10000) {
Client c = new Client(1000, 0, 0, 0);
m.listeTemps.add(k);
if (m.GenereClient(0.05)) {
m.Clients.add(c);
m.ajouterVisiteur(c);
//System.out.println(entreesec(c));
m.destination.add(m.entreesec(c));
nbVisiteurs++;
m.listeVisiteursentres.add(nbVisiteurs);
}else{w.add(nbVisiteurs);}
}
for (int i = 0; i < m.Clients.size(); i++) { //generaliser a Visiteurs
Client a = m.Clients.get(i);
a.move();
//System.out.println(m.getBudget());
if ((a.getLigne() == 10) && (a.getColonne() == 18)) {
m.Clients.remove(i);
m.Visiteurs.remove(a);
}
if (!m.destination.isEmpty()) {
Element b = m.destination.get(i);
if (a.getLigne() == b.getLigne() && a.getColonne() == b.getColonne() - 1) {
b.entreereelle(a);
m.setBudget(m.getBudget() + b.getGain());
this.gainmoyen+=m.getBudget();
//b.sortie(a);//una estructura nunca se llena
//System.out.println(m.getBudget());
} else if (a.getLigne() == b.getLigne() && a.getColonne() == b.getColonne() + 1) {
b.entreereelle(a);
m.setBudget(m.getBudget() + b.getGain());
//b.sortie(a);
//System.out.println(m.getBudget());
}
}
}
if (m.Clients.isEmpty() && k > 12000) {// Pb con el numer o de clientes entrados pero solucionable
m.setSimulation(false);
//m.setListeTemps(e);
//m.setListeVisiteursentres(w);
this.e= m.listeTemps;
this.w= m.listeVisiteursentres;
this.gainmoyen=this.gainmoyen/this.nbVisiteurs;
for(Element e: m.destination){
if(e instanceof Clinique ){
r[0]++;
}else if (e instanceof CommerceGeneral){
r[1]++;
}else if (e instanceof CommerceSpecifique){
r[2]++;
}else if (e instanceof Fun){
r[3]++;
}else if (e instanceof Restauration){
r[4]++;
}else if (e instanceof Gym){
r[5]++;
}
}
System.out.println(m.isSimulation());
(new JOptionPane()).showMessageDialog(null, "Journee finie", "Fin!", JOptionPane.INFORMATION_MESSAGE);
try {
Thread.sleep(this.delay);
}catch (InterruptedException e) {
}
}
//m.notifyFin(); //NO FUNCIONA¿?
}
giorno++;
}
}
}
我试图破坏创建的线程并在点击时初始化一个新线程,但它没有工作
修改
感谢您answer。要使用执行程序服务,我只需要实现此类来代替Runnable
?
答案 0 :(得分:4)
不要扩展Thread。相反,我会使用ExecutorService。您可以多次提交任意数量的Runnables。例如
您可以创建像
这样的执行程序服务ExecutorService es = Executors.newSingleThreadExecutor();
您可以提交类似
的任务Runnable myRunnable = new MyRunnable();
es.submit(myRunnable);
并再次提交
es.submit(myRunnable);
答案 1 :(得分:1)
!!!确定它有效,问题是int k。 我必须在动作执行按钮中将其设为0以重新启动运行 谢谢大家!!!:D