我这个学期的课程设计被老师分到了一个有关java的课程题目,用JAVA实现排队时延和丢包问题的分析 
我以前根本没有接触过java,只是这几天通过在网上找资料了解了一下,所以不知道自己做的对不对,请大家指导一下,我是这样做的: 
在JCCEATOR中新建一个HTML文件,命名为 QueueSim extends Applet ,这是因为老师给的程序里面类的名字就叫QueueSim extends Applet(不知道我这样想对不对)程序见最后,(很长 
)。然后再建一个叫“ LineSimApplet ”的HTML文件,内容是:<applet code=" LineSimApplet.class" width=800 height=600></applet>。分别COMPILE后EXECUTE,在QueueSim extends Applet文件下显示一个命令提示符窗口一闪而过,而在LineSimApplet文件窗口下显示一个名叫“小程序查看器”的窗口,下面提示:未初始化小程序。 
试过很多次之后都是这样,但是我们有个同学这样做之后程序能运行,能有图形出来。 
请问我在哪个地方出了问题?谢谢! 
老师给我的程序如下:
package queuesim; 
import java.awt.*; 
import java.awt.event.*; 
import java.awt.image.*; 
import java.applet.*; 
import java.util.*; 
////////////////////////////////////////////////////////////////////////////// 
public class QueueSim extends Applet 
////////////////////////////////////////////////////////////////////////////// 
{ 
Button start=new Button("Start"); 
Button reset=new Button("Reset"); 
MyChoice emitRate=new MyChoice(new String[] {"500 packet/s","350 packet/s"}, new double[] {2E-3,3E-3},1); 
MyChoice processorRate=new MyChoice(new String[] {"1000 packet/s","500 packet/s","350 packet/s"}, new double[] {1E-3,2E-3,3E-3},3); 
SimTimer myTimer; 
public void init() 
{ 
try 
{ 
myTimer=new SimTimer(1E-4,1000,this); 
setBackground(Color.white); 
add(new Label("Emission rate",Label.RIGHT)); 
add(emitRate); 
add(new Label("Transmission rate",Label.RIGHT)); 
add(processorRate); 
start.addActionListener(new ActionListener() 
{ 
public void actionPerformed (ActionEvent event) 
{ 
emitRate.setEnabled(false); 
processorRate.setEnabled(false); 
start.setEnabled(false); 
myTimer.launchSim(emitRate.getVal(), processorRate.getVal()); 
} 
}); 
add(start); 
reset.addActionListener(new ActionListener() 
{ 
public void actionPerformed (ActionEvent event) 
{ 
emitRate.setEnabled(true); 
processorRate.setEnabled(true); 
start.setEnabled(true); 
myTimer=new SimTimer(1E-4,1000,QueueSim.this); 
} 
}); 
add(reset); 
} 
catch(Exception e) {} 
} 
public void paint (Graphics g) 
{ 
update(g); // eliminate flashing : update is overriden 
} 
public void update (Graphics g) 
{ 
//work on a offscreen image 
Dimension offDimension = getSize(); 
Image offImage = createImage(offDimension.width, offDimension.height); 
Graphics offGraphics = offImage.getGraphics(); 
myTimer.draw(offGraphics); 
g.drawImage(offImage, 0, 0, this); 
} 
} 
////////////////////////////////////////////////////////////////////////////// 
class SimTimer implements Runnable 
////////////////////////////////////////////////////////////////////////////// 
{ 
private double time; 
private double tic; 
private Line line1; 
private Sender sender1; 
private Dropper dropper1; 
private Queue queue1; 
private Line line2; 
private Processor proc1; 
private Applet target; 
private Thread timerThread; 
public SimTimer(double tick, double length, Applet tgt) 
{ 
line1=new Line(1E-2,new Rectangle(10,60,200,10)); 
sender1=new Sender(1E-3,line1); 
dropper1= new Dropper(.6E-2,new Rectangle(200,70,10,60)); 
queue1=new Queue(10,line1,dropper1,new Rectangle(210,40,100,50)); 
line2=new Line(1E-2,new Rectangle(340,60,200,10)); 
proc1=new Processor(2E-3,queue1,line2,new Rectangle(310,50,30,30)); 
target=tgt; 
time=0; 
tic=tick; 
timerThread=new Thread(this); 
} 
public void launchSim(double emitRate, double processorRate) 
{ 
sender1.setEmitInterval(emitRate); 
proc1.setWrkLength(processorRate); 
timerThread.start(); 
} 
public void run() 
{ 
while (true) 
{ 
dropper1.setTime(time); 
sender1.setTime(time); 
line1.setTime(time); 
queue1.setTime(time); 
proc1.setTime(time); 
line2.setTime(time); 
target.repaint(); 
time+=tic; 
try {timerThread.sleep(50);} catch (Exception e) { }; 
} 
} 
public void draw(Graphics g) 
{ 
dropper1.draw(g); 
line1.draw(g); 
line2.draw(g); 
queue1.draw(g); 
proc1.draw(g); 
g.drawString(TimedClass.timeToString(time),10,110); 
g.drawString(queue1.getDropStat(),10,125); 
} 
} 
////////////////////////////////////////////////////////////////////////////// 
class Packet 
////////////////////////////////////////////////////////////////////////////// 
{ 
static final double emmissionDelay=1E-3; 
double emmissionTime; 
Color color; 
public Packet(double eT, Color c) 
{ 
emmissionTime=eT; 
color=c; 
} 
} 
////////////////////////////////////////////////////////////////////////////// 
class PacketFIFO 
////////////////////////////////////////////////////////////////////////////// 
{ 
private int length; 
private Packet[] content; 
public PacketFIFO() 
{ 
length=0; 
} 
public int getLength() 
{ 
return length; 
} 
public void add(Packet P) 
{ 
if (length==0) 
{ 
content=new Packet[1]; 
content[0]=P; 
} 
else 
{ 
Packet[] temp=new Packet[length+1]; 
for (int i=0;i<length;i++) {temp[i]=content[i];} 
temp[length]=P; 
content=temp; 
} 
length++; 
} 
public void rem() 
{ 
Packet[] temp=new Packet[length-1]; 
for (int i=0;i<length-1;i++) {temp[i]=content[i+1];} 
content=temp; 
length--; 
} 
public Packet getPacket(int index) 
{ 
return content[index]; 
} 
public Packet getFirstPacket() 
{ 
return content[0]; 
} 
} 
////////////////////////////////////////////////////////////////////////////// 
class Sender 
///////////////////////////////////////////////////////////////////////////// 
{ 
final Color packetsColors[]={Color.blue,Color.red,Color.green,Color.gray,Color.magenta,Color.black,Color.pink}; 
private double meanInterval; 
private Line outputLine; 
private double time; 
private double nextEmission; 
private int nextColor; 
private Random randomGenerator; 
public Sender(double meanI, Line outputL) 
{ 
meanInterval=meanI; 
outputLine=outputL; 
randomGenerator=new Random(); 
} 
public void setEmitInterval(double val) {meanInterval=val;} 
public void setTime(double now) 
{ 
time=now; 
update(); 
} 
private void update() 
{ 
if (nextEmission><time) 
{ 
outputLine.emitPacket(time,packetsColors[nextColor]); 
nextColor++; 
if (nextColor>=packetsColors.length){nextColor=0;} 
nextEmission=2*randomGenerator.nextDouble()*(meanInterval-Packet.emmissionDelay)+Packet.emmissionDelay; 
nextEmission+=time; 
} 
} 
} 
////////////////////////////////////////////////////////////////////////////// 
class Line extends TimedClass 
////////////////////////////////////////////////////////////////////////////// 
{ 
private boolean availableArrivedPacket; 
private Packet arrivedPacket; 
protected PacketFIFO packets; 
protected double propDelay; 
public Line(double propD,Rectangle r) 
{ 
packets=new PacketFIFO(); 
propDelay=propD; 
shape=r; 
availableArrivedPacket=false; 
} 
public void emitPacket(double eT, Color c) 
{ 
packets.add(new Packet(eT,c)); 
} 
public void draw(Graphics g) 
{ 
for (int i=0;i<packets.getLength();i++) 
{ 
drawPacket(packets.getPacket(i),g); 
} 
g.setColor(Color.black); 
g.drawRect(shape.x,shape.y,shape.width,shape.height); 
} 
private void drawPacket(Packet P, Graphics g) 
{ 
double x1=((double)shape.x)+(time-P.emmissionTime)*((double)shape.width)/propDelay; 
double x2=x1-(P.emmissionDelay)*((double)shape.width)/propDelay; 
if (x1>((double)(shape.x+shape.width))) x1=(double)(shape.x+shape.width); 
if (x2<((double)(shape.x))) x2=(double)(shape.x); 
g.setColor(P.color); 
g.fillRect((int)x2,shape.y,(int)(x1-x2),shape.height); 
} 
protected void update() 
{ 
if (packets.getLength()>0) 
{ 
Packet fP=packets.getFirstPacket(); 
if (fP.emmissionTime+fP.emmissionDelay+propDelay<time) 
{ 
packets.rem(); 
arrivedPacket=fP; 
availableArrivedPacket=true; 
} 
} 
} 
public boolean getAvailableArrivedPacket() {return availableArrivedPacket;} 
public Packet pickArrivedPacket() 
{ 
availableArrivedPacket=false; 
return arrivedPacket; 
} 
} 
////////////////////////////////////////////////////////////////////////////// 
class Queue extends TimedClass 
////////////////////////////////////////////////////////////////////////////// 
{ 
private int maxSize; 
private int size; 
private int receivedCounter; 
private int droppedCounter; 
private PacketFIFO packets; 
private Line inputLine; 
private Dropper dropper; 
public Queue(int mS,Line inputL,Dropper defDropper,Rectangle r) 
{ 
shape=r; 
maxSize=mS; 
inputLine=inputL; 
packets=new PacketFIFO(); 
dropper=defDropper; 
} 
protected void update() 
{ 
//if a packet is at input then add it to the queue 
if (inputLine.getAvailableArrivedPacket()) 
{ 
addPacket(inputLine.pickArrivedPacket()); 
} 
} 
private void addPacket(Packet P) 
{ 
receivedCounter++; 
//if the queue is full drop packet else queue it 
if (size==maxSize) 
{ 
dropPacket(P); 
} 
else 
{ 
size++; 
packets.add(P); 
} 
} 
private void dropPacket(Packet P) 
{ 
dropper.emitPacket(time,P.color); 
droppedCounter++; 
} 
public void draw(Graphics g) 
{ 
for (int i=0;i<maxSize;i++) 
{ 
int xp=shape.x+shape.width-(i+1)*(shape.width/maxSize); 
int wp=(shape.width/maxSize); 
if (i><(packets.getLength())) 
{ 
g.setColor(packets.getPacket(i).color); 
g.fillRect(xp,shape.y,wp,shape.height); 
} 
g.setColor(Color.black); 
g.drawRect(xp,shape.y,wp,shape.height); 
} 
} 
public boolean getAvailableArrivedPacket() {return (packets.getLength()>0);} 
public Packet pickArrivedPacket() 
{ 
size--; 
Packet fP=packets.getFirstPacket(); 
packets.rem(); 
return fP; 
} 
public String getDropStat() {return Integer.toString(droppedCounter)+" packets dropped out of "+Integer.toString(receivedCounter);} 
} 
////////////////////////////////////////////////////////////////////////////// 
class Processor extends TimedClass 
////////////////////////////////////////////////////////////////////////////// 
{ 
private boolean busy; 
private double workLength; 
private double curWorkStart; 
private Line outputLine; 
private Queue inputQueue; 
private Packet curPacket; 
public Processor(double wrkLength, Queue inputQ, Line outputL,Rectangle r) 
{ 
workLength=wrkLength; 
inputQueue=inputQ; 
outputLine=outputL; 
shape=r; 
busy=false; 
} 
public void setWrkLength(double wrkl) {workLength=wrkl;} 
protected void update() 
{ //if there is a packet and the job is done then emit it 
if ((busy)&&(workDone())) 
{ 
outputLine.emitPacket(time, curPacket.color); 
busy=false; 
} 
if ((!(busy))&&(inputQueue.getAvailableArrivedPacket())) 
{ 
busy=true; 
curWorkStart=time; 
curPacket=inputQueue.pickArrivedPacket(); 
} 
} 
private boolean workDone(){ 
return (curWorkStart+workLength<=time); 
} 
public void draw(Graphics g) 
{ 
if (busy) 
{ 
g.setColor(curPacket.color); 
g.fillRect(shape.x,shape.y,shape.width,shape.height); 
} 
g.setColor(Color.black); 
g.drawRect(shape.x,shape.y,shape.width,shape.height); 
} 
} 
class Dropper extends Line 
{ 
public Dropper(double propD,Rectangle r){super(propD,r);} 
public void draw(Graphics g) 
{ 
for (int i=0;i<packets.getLength();i++) 
{ 
drawPacket(packets.getPacket(i),g); 
} 
} 
private void drawPacket(Packet P, Graphics g) 
{ 
double y1=((double)shape.y)+(time-P.emmissionTime)*((double)shape.height)/propDelay; 
double y2=y1-(P.emmissionDelay)*((double)shape.height)/propDelay; 
if (y1>((double)(shape.y+shape.height))) y1=(double)(shape.y+shape.height); 
if (y2<((double)(shape.y))) y2=(double)(shape.y); 
g.setColor(P.color); 
g.fillRect(shape.x,(int)y2,shape.width,(int)(y1-y2)); 
} 
} 
////////////////////////////////////////////////////////////////////////////// 
abstract class TimedClass 
////////////////////////////////////////////////////////////////////////////// 
{ 
protected Rectangle shape; 
protected double time; 
public void setTime(double now) 
{ 
time=now; 
update(); 
} 
protected abstract void update(); 
public abstract void draw(Graphics g); 
static String timeToString(double now) 
{ 
String res=Double.toString(now*1000); 
int dot=res.indexOf('.'); 
String inte=res.substring(0,dot); 
return inte+" msec"; 
} 
} 
////////////////////////////////////////////////////////////////////////////// 
class MyChoice extends Choice 
////////////////////////////////////////////////////////////////////////////// 
{ 
private double vals[]; 
public MyChoice(String items[], double values[], int defaultValue) 
{ 
for (int i=0; i<items.length;i++) {super.addItem(items[i]);} 
vals=values; 
super.select(defaultValue-1); 
} 
public double getVal() {return vals[super.getSelectedIndex()];} 
}>

 
											





