哪位高手帮我看下这个程序怎么能通过编译却运行异常?

哪位高手帮我看下这个程序怎么能通过编译却运行异常?,第1张

程序的第113行:oval = new Oval()这里new出来的是class Oval 的构造方法

Oval()

{setSize(200,200)} //这个构造方法如果是这样写肯定是不对的.这根本也没有做什么事情啊?只是set了个Size.这里应该写具体要画出的图.

楼主写一个html,很容易把下面代码嵌入到applet,可以google一下实现,

还有copy自己不知道算不算复制。。。-_-!

--------------------------------------------------------------------

楼主给你一个我的,直接保存成pb.java编译运行,就是你要的画图功能 ,可以参考一下

____________________________________________________________________

import java.applet.*

import java.awt.*

import java.awt.event.*

import java.util.*

import javax.swing.*

import java.awt.geom.*

import java.io.*

class Point implements Serializable

{

int x,y

Color col

int tool

int boarder

Point(int x, int y, Color col, int tool, int boarder)

{

this.x = x

this.y = y

this.col = col

this.tool = tool

this.boarder = boarder

}

}

class paintboard extends Frame implements ActionListener,MouseMotionListener,MouseListener,ItemListener

{

int x = -1, y = -1

int con = 1//画笔大小

int Econ = 5//橡皮大小

int toolFlag = 0//toolFlag:工具标记

//toolFlag工具对应表:

//(0--画笔);(1--橡皮);(2--清除);

//(3--直线);(4--圆);(5--矩形);

Color c = new Color(0,0,0)//画笔颜色

BasicStroke size = new BasicStroke(con,BasicStroke.CAP_BUTT,BasicStroke.JOIN_BEVEL)//画笔粗细

Point cutflag = new Point(-1, -1, c, 6, con)//截断标志

Vector paintInfo = null//点信息向量组

int n = 1

FileInputStream picIn = null

FileOutputStream picOut = null

ObjectInputStream VIn = null

ObjectOutputStream VOut = null

// *工具面板--画笔,直线,圆,矩形,多边形,橡皮,清除*/

Panel toolPanel

Button eraser, drLine,drCircle,drRect

Button clear ,pen

Choice ColChoice,SizeChoice,EraserChoice

Button colchooser

Label 颜色,大小B,大小E

//保存功能

Button openPic,savePic

FileDialog openPicture,savePicture

paintboard(String s)

{

super(s)

addMouseMotionListener(this)

addMouseListener(this)

paintInfo = new Vector()

/*各工具按钮及选择项*/

//颜色选择

ColChoice = new Choice()

ColChoice.add("black")

ColChoice.add("red")

ColChoice.add("blue")

ColChoice.add("green")

ColChoice.addItemListener(this)

//画笔大小选择

SizeChoice = new Choice()

SizeChoice.add("1")

SizeChoice.add("3")

SizeChoice.add("5")

SizeChoice.add("7")

SizeChoice.add("9")

SizeChoice.addItemListener(this)

//橡皮大小选择

EraserChoice = new Choice()

EraserChoice.add("5")

EraserChoice.add("9")

EraserChoice.add("13")

EraserChoice.add("17")

EraserChoice.addItemListener(this)

////////////////////////////////////////////////////

toolPanel = new Panel()

clear = new Button("清除")

eraser = new Button("橡皮")

pen = new Button("画笔")

drLine = new Button("画直线")

drCircle = new Button("画圆形")

drRect = new Button("画矩形")

openPic = new Button("打开图画")

savePic = new Button("保存图画")

colchooser = new Button("显示调色板")

//各组件事件监听

clear.addActionListener(this)

eraser.addActionListener(this)

pen.addActionListener(this)

drLine.addActionListener(this)

drCircle.addActionListener(this)

drRect.addActionListener(this)

openPic.addActionListener(this)

savePic.addActionListener(this)

colchooser.addActionListener(this)

颜色 = new Label("画笔颜色",Label.CENTER)

大小B = new Label("画笔大小",Label.CENTER)

大小E = new Label("橡皮大小",Label.CENTER)

//面板添加组件

toolPanel.add(openPic)

toolPanel.add(savePic)

toolPanel.add(pen)

toolPanel.add(drLine)

toolPanel.add(drCircle)

toolPanel.add(drRect)

toolPanel.add(颜色)toolPanel.add(ColChoice)

toolPanel.add(大小B)toolPanel.add(SizeChoice)

toolPanel.add(colchooser)

toolPanel.add(eraser)

toolPanel.add(大小E)toolPanel.add(EraserChoice)

toolPanel.add(clear)

//工具面板到APPLET面板

add(toolPanel,BorderLayout.NORTH)

setBounds(60,60,900,600)setVisible(true)

validate()

//dialog for save and load

openPicture = new FileDialog(this,"打开图画",FileDialog.LOAD)

openPicture.setVisible(false)

savePicture = new FileDialog(this,"保存图画",FileDialog.SAVE)

savePicture.setVisible(false)

openPicture.addWindowListener(new WindowAdapter()

{

public void windowClosing(WindowEvent e)

{ openPicture.setVisible(false)}

})

savePicture.addWindowListener(new WindowAdapter()

{

public void windowClosing(WindowEvent e)

{ savePicture.setVisible(false)}

})

addWindowListener(new WindowAdapter()

{

public void windowClosing(WindowEvent e)

{ System.exit(0)}

})

}

public void paint(Graphics g)

{

Graphics2D g2d = (Graphics2D)g

Point p1,p2

n = paintInfo.size()

if(toolFlag==2)

g.clearRect(0,0,getSize().width,getSize().height)//清除

for(int i=0i<n i++){

p1 = (Point)paintInfo.elementAt(i)

p2 = (Point)paintInfo.elementAt(i+1)

size = new BasicStroke(p1.boarder,BasicStroke.CAP_BUTT,BasicStroke.JOIN_BEVEL)

g2d.setColor(p1.col)

g2d.setStroke(size)

if(p1.tool==p2.tool)

{

switch(p1.tool)

{

case 0://画笔

Line2D line1 = new Line2D.Double(p1.x, p1.y, p2.x, p2.y)

g2d.draw(line1)

break

case 1://橡皮

g.clearRect(p1.x, p1.y, p1.boarder, p1.boarder)

break

case 3://画直线

Line2D line2 = new Line2D.Double(p1.x, p1.y, p2.x, p2.y)

g2d.draw(line2)

break

case 4://画圆

Ellipse2D ellipse = new Ellipse2D.Double(p1.x, p1.y, Math.abs(p2.x-p1.x) , Math.abs(p2.y-p1.y))

g2d.draw(ellipse)

break

case 5://画矩形

Rectangle2D rect = new Rectangle2D.Double(p1.x, p1.y, Math.abs(p2.x-p1.x) , Math.abs(p2.y-p1.y))

g2d.draw(rect)

break

case 6://截断,跳过

i=i+1

break

default :

}//end switch

}//end if

}//end for

}

public void itemStateChanged(ItemEvent e)

{

if(e.getSource()==ColChoice)//预选颜色

{

String name = ColChoice.getSelectedItem()

if(name=="black")

{c = new Color(0,0,0)}

else if(name=="red")

{c = new Color(255,0,0)}

else if(name=="green")

{c = new Color(0,255,0)}

else if(name=="blue")

{c = new Color(0,0,255)}

}

else if(e.getSource()==SizeChoice)//画笔大小

{

String selected = SizeChoice.getSelectedItem()

if(selected=="1")

{

con = 1

size = new BasicStroke(con,BasicStroke.CAP_BUTT,BasicStroke.JOIN_BEVEL)

}

else if(selected=="3")

{

con = 3

size = new BasicStroke(con,BasicStroke.CAP_BUTT,BasicStroke.JOIN_BEVEL)

}

else if(selected=="5")

{con = 5

size = new BasicStroke(con,BasicStroke.CAP_BUTT,BasicStroke.JOIN_BEVEL)

}

else if(selected=="7")

{con = 7

size = new BasicStroke(con,BasicStroke.CAP_BUTT,BasicStroke.JOIN_BEVEL)

}

else if(selected=="9")

{con = 9

size = new BasicStroke(con,BasicStroke.CAP_BUTT,BasicStroke.JOIN_BEVEL)

}

}

else if(e.getSource()==EraserChoice)//橡皮大小

{

String Esize = EraserChoice.getSelectedItem()

if(Esize=="5")

{ Econ = 5*2}

else if(Esize=="9")

{ Econ = 9*2}

else if(Esize=="13")

{ Econ = 13*2}

else if(Esize=="17")

{ Econ = 17*3}

}

}

public void mouseDragged(MouseEvent e)

{

Point p1

switch(toolFlag){

case 0://画笔

x = (int)e.getX()

y = (int)e.getY()

p1 = new Point(x, y, c, toolFlag, con)

paintInfo.addElement(p1)

repaint()

break

case 1://橡皮

x = (int)e.getX()

y = (int)e.getY()

p1 = new Point(x, y, null, toolFlag, Econ)

paintInfo.addElement(p1)

repaint()

break

default :

}

}

public void mouseMoved(MouseEvent e) {}

public void update(Graphics g)

{

paint(g)

}

public void mousePressed(MouseEvent e)

{

Point p2

switch(toolFlag){

case 3://直线

x = (int)e.getX()

y = (int)e.getY()

p2 = new Point(x, y, c, toolFlag, con)

paintInfo.addElement(p2)

break

case 4: //圆

x = (int)e.getX()

y = (int)e.getY()

p2 = new Point(x, y, c, toolFlag, con)

paintInfo.addElement(p2)

break

case 5: //矩形

x = (int)e.getX()

y = (int)e.getY()

p2 = new Point(x, y, c, toolFlag, con)

paintInfo.addElement(p2)

break

default :

}

}

public void mouseReleased(MouseEvent e)

{

Point p3

switch(toolFlag){

case 0://画笔

paintInfo.addElement(cutflag)

break

case 1: //eraser

paintInfo.addElement(cutflag)

break

case 3://直线

x = (int)e.getX()

y = (int)e.getY()

p3 = new Point(x, y, c, toolFlag, con)

paintInfo.addElement(p3)

paintInfo.addElement(cutflag)

repaint()

break

case 4: //圆

x = (int)e.getX()

y = (int)e.getY()

p3 = new Point(x, y, c, toolFlag, con)

paintInfo.addElement(p3)

paintInfo.addElement(cutflag)

repaint()

break

case 5: //矩形

x = (int)e.getX()

y = (int)e.getY()

p3 = new Point(x, y, c, toolFlag, con)

paintInfo.addElement(p3)

paintInfo.addElement(cutflag)

repaint()

break

default:

}

}

public void mouseEntered(MouseEvent e){}

public void mouseExited(MouseEvent e){}

public void mouseClicked(MouseEvent e){}

public void actionPerformed(ActionEvent e)

{

if(e.getSource()==pen)//画笔

{toolFlag = 0}

if(e.getSource()==eraser)//橡皮

{toolFlag = 1}

if(e.getSource()==clear)//清除

{

toolFlag = 2

paintInfo.removeAllElements()

repaint()

}

if(e.getSource()==drLine)//画线

{toolFlag = 3}

if(e.getSource()==drCircle)//画圆

{toolFlag = 4}

if(e.getSource()==drRect)//画矩形

{toolFlag = 5}

if(e.getSource()==colchooser)//调色板

{

Color newColor = JColorChooser.showDialog(this,"调色板",c)

c = newColor

}

if(e.getSource()==openPic)//打开图画

{

openPicture.setVisible(true)

if(openPicture.getFile()!=null)

{

int tempflag

tempflag = toolFlag

toolFlag = 2

repaint()

try{

paintInfo.removeAllElements()

File filein = new File(openPicture.getDirectory(),openPicture.getFile())

picIn = new FileInputStream(filein)

VIn = new ObjectInputStream(picIn)

paintInfo = (Vector)VIn.readObject()

VIn.close()

repaint()

toolFlag = tempflag

}

catch(ClassNotFoundException IOe2)

{

repaint()

toolFlag = tempflag

System.out.println("can not read object")

}

catch(IOException IOe)

{

repaint()

toolFlag = tempflag

System.out.println("can not read file")

}

}

}

if(e.getSource()==savePic)//保存图画

{

savePicture.setVisible(true)

try{

File fileout = new File(savePicture.getDirectory(),savePicture.getFile())

picOut = new FileOutputStream(fileout)

VOut = new ObjectOutputStream(picOut)

VOut.writeObject(paintInfo)

VOut.close()

}

catch(IOException IOe)

{

System.out.println("can not write object")

}

}

}

}//end paintboard

public class pb

{

public static void main(String args[])

{ new paintboard("画图程序")}

}

这个问题也困扰了我好久,终于解决了。给你个ga.m程序,新建m文件复制进去,再运行程序试试。

%ga.m

function [x,endPop,bPop,traceInfo] = ga(bounds,evalFN,evalOps,startPop,opts,...

termFN,termOps,selectFN,selectOps,xOverFNs,xOverOps,mutFNs,mutOps)

% GA run a genetic algorithm

% function [x,endPop,bPop,traceInfo]=ga(bounds,evalFN,evalOps,startPop,opts,

% termFN,termOps,selectFN,selectOps,

% xOverFNs,xOverOps,mutFNs,mutOps)

%

% Output Arguments:

% x- the best solution found during the course of the run

% endPop - the final population

% bPop - a trace of the best population

% traceInfo- a matrix of best and means of the ga for each generation

%

% Input Arguments:

% bounds - a matrix of upper and lower bounds on the variables

% evalFN - the name of the evaluation .m function

% evalOps - options to pass to the evaluation function ([NULL])

% startPop - a matrix of solutions that can be initialized

% from initialize.m

% opts - [epsilon prob_ops display] change required to consider two

% solutions different, prob_ops 0 if you want to apply the

% genetic operators probabilisticly to each solution, 1 if

% you are supplying a deterministic number of operator

% applications and display is 1 to output progress 0 for

% quiet. ([1e-6 1 0])

% termFN - name of the .m termination function (['maxGenTerm'])

% termOps - options string to be passed to the termination function

% ([100]).

% selectFN - name of the .m selection function (['normGeomSelect'])

% selectOpts - options string to be passed to select after

% select(pop,#,opts) ([0.08])

% xOverFNS - a string containing blank seperated names of Xover.m

% files (['arithXover heuristicXover simpleXover'])

% xOverOps - A matrix of options to pass to Xover.m files with the

% first column being the number of that xOver to perform

% similiarly for mutation ([2 02 32 0])

% mutFNs - a string containing blank seperated names of mutation.m

% files (['boundaryMutation multiNonUnifMutation ...

% nonUnifMutation unifMutation'])

% mutOps - A matrix of options to pass to Xover.m files with the

% first column being the number of that xOver to perform

% similiarly for mutation ([4 0 06 100 34 100 34 0 0])

% Binary and Real-Valued Simulation Evolution for Matlab

% Copyright (C) 1996 C.R. Houck, J.A. Joines, M.G. Kay

%

% C.R. Houck, J.Joines, and M.Kay. A genetic algorithm for function

% optimization: A Matlab implementation. ACM Transactions on Mathmatical

% Software, Submitted 1996.

%

% This program is free softwareyou can redistribute it and/or modify

% it under the terms of the GNU General Public License as published by

% the Free Software Foundationeither version 1, or (at your option)

% any later version.

%

% This program is distributed in the hope that it will be useful,

% but WITHOUT ANY WARRANTYwithout even the implied warranty of

% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the

% GNU General Public License for more details. A copy of the GNU

% General Public License can be obtained from the

% Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.

%%$Log: ga.m,v $

%Revision 1.10 1996/02/02 15:03:00 jjoine

% Fixed the ordering of imput arguments in the comments to match

% the actual order in the ga function.

%

%Revision 1.9 1995/08/28 20:01:07 chouck

% Updated initialization parameters, updated mutation parameters to reflect

% b being the third option to the nonuniform mutations

%

%Revision 1.8 1995/08/10 12:59:49 jjoine

%Started Logfile to keep track of revisions

%

n=nargin

if n<2 | n==6 | n==10 | n==12

disp('Insufficient arguements')

end

if n<3 %Default evalation opts.

evalOps=[]

end

if n<5

opts = [1e-6 1 0]

end

if isempty(opts)

opts = [1e-6 1 0]

end

if any(evalFN<48) %Not using a .m file

if opts(2)==1 %Float ga

e1str=['x=c1c1(xZomeLength)=', evalFN '']

e2str=['x=c2c2(xZomeLength)=', evalFN '']

else %Binary ga

e1str=['x=b2f(endPop(j,:),bounds,bits)endPop(j,xZomeLength)=',...

evalFN '']

end

else %Are using a .m file

if opts(2)==1 %Float ga

e1str=['[c1 c1(xZomeLength)]=' evalFN '(c1,[gen evalOps])']

e2str=['[c2 c2(xZomeLength)]=' evalFN '(c2,[gen evalOps])']

else %Binary ga

e1str=['x=b2f(endPop(j,:),bounds,bits)[x v]=' evalFN ...

'(x,[gen evalOps])endPop(j,:)=[f2b(x,bounds,bits) v]']

end

end

if n<6 %Default termination information

termOps=[100]

termFN='maxGenTerm'

end

if n<12 %Default muatation information

if opts(2)==1 %Float GA

mutFNs=['boundaryMutation multiNonUnifMutation nonUnifMutation unifMutation']

mutOps=[4 0 06 termOps(1) 34 termOps(1) 34 0 0]

else %Binary GA

mutFNs=['binaryMutation']

mutOps=[0.05]

end

end

if n<10 %Default crossover information

if opts(2)==1 %Float GA

xOverFNs=['arithXover heuristicXover simpleXover']

xOverOps=[2 02 32 0]

else %Binary GA

xOverFNs=['simpleXover']

xOverOps=[0.6]

end

end

if n<9 %Default select opts only i.e. roullete wheel.

selectOps=[]

end

if n<8 %Default select info

selectFN=['normGeomSelect']

selectOps=[0.08]

end

if n<6 %Default termination information

termOps=[100]

termFN='maxGenTerm'

end

if n<4 %No starting population passed given

startPop=[]

end

if isempty(startPop) %Generate a population at random

%startPop=zeros(80,size(bounds,1)+1)

startPop=initializega(80,bounds,evalFN,evalOps,opts(1:2))

end

if opts(2)==0 %binary

bits=calcbits(bounds,opts(1))

end

xOverFNs=parse(xOverFNs)

mutFNs=parse(mutFNs)

xZomeLength = size(startPop,2) %Length of the xzome=numVars+fittness

numVar = xZomeLength-1 %Number of variables

popSize = size(startPop,1) %Number of individuals in the pop

endPop = zeros(popSize,xZomeLength)%A secondary population matrix

c1 = zeros(1,xZomeLength) %An individual

c2 = zeros(1,xZomeLength) %An individual

numXOvers= size(xOverFNs,1) %Number of Crossover operators

numMuts = size(mutFNs,1) %Number of Mutation operators

epsilon = opts(1)%Threshold for two fittness to differ

oval = max(startPop(:,xZomeLength))%Best value in start pop

bFoundIn = 1 %Number of times best has changed

done = 0 %Done with simulated evolution

gen = 1 %Current Generation Number

collectTrace = (nargout>3) %Should we collect info every gen

floatGA = opts(2)==1 %Probabilistic application of ops

display = opts(3)%Display progress

while(~done)

%Elitist Model

[bval,bindx] = max(startPop(:,xZomeLength))%Best of current pop

best = startPop(bindx,:)

if collectTrace

traceInfo(gen,1)=gen %current generation

traceInfo(gen,2)=startPop(bindx,xZomeLength) %Best fittness

traceInfo(gen,3)=mean(startPop(:,xZomeLength))%Avg fittness

traceInfo(gen,4)=std(startPop(:,xZomeLength))

end

if ( (abs(bval - oval)>epsilon) | (gen==1)) %If we have a new best sol

if display

fprintf(1,'\n%d %f\n',gen,bval) %Update the display

end

if floatGA

bPop(bFoundIn,:)=[gen startPop(bindx,:)]%Update bPop Matrix

else

bPop(bFoundIn,:)=[gen b2f(startPop(bindx,1:numVar),bounds,bits)...

startPop(bindx,xZomeLength)]

end

bFoundIn=bFoundIn+1 %Update number of changes

oval=bval %Update the best val

else

if display

fprintf(1,'%d ',gen) %Otherwise just update num gen

end

end

endPop = feval(selectFN,startPop,[gen selectOps])%Select

if floatGA %Running with the model where the parameters are numbers of ops

for i=1:numXOvers,

for j=1:xOverOps(i,1),

a = round(rand*(popSize-1)+1) %Pick a parent

b = round(rand*(popSize-1)+1) %Pick another parent

xN=deblank(xOverFNs(i,:)) %Get the name of crossover function

[c1 c2] = feval(xN,endPop(a,:),endPop(b,:),bounds,[gen xOverOps(i,:)])

if c1(1:numVar)==endPop(a,(1:numVar)) %Make sure we created a new

c1(xZomeLength)=endPop(a,xZomeLength)%solution before evaluating

elseif c1(1:numVar)==endPop(b,(1:numVar))

c1(xZomeLength)=endPop(b,xZomeLength)

else

%[c1(xZomeLength) c1] = feval(evalFN,c1,[gen evalOps])

eval(e1str)

end

if c2(1:numVar)==endPop(a,(1:numVar))

c2(xZomeLength)=endPop(a,xZomeLength)

elseif c2(1:numVar)==endPop(b,(1:numVar))

c2(xZomeLength)=endPop(b,xZomeLength)

else

%[c2(xZomeLength) c2] = feval(evalFN,c2,[gen evalOps])

eval(e2str)

end

endPop(a,:)=c1

endPop(b,:)=c2

end

end

for i=1:numMuts,

for j=1:mutOps(i,1),

a = round(rand*(popSize-1)+1)

c1 = feval(deblank(mutFNs(i,:)),endPop(a,:),bounds,[gen mutOps(i,:)])

if c1(1:numVar)==endPop(a,(1:numVar))

c1(xZomeLength)=endPop(a,xZomeLength)

else

%[c1(xZomeLength) c1] = feval(evalFN,c1,[gen evalOps])

eval(e1str)

end

endPop(a,:)=c1

end

end

else %We are running a probabilistic model of genetic operators

for i=1:numXOvers,

xN=deblank(xOverFNs(i,:)) %Get the name of crossover function

cp=find(rand(popSize,1)<xOverOps(i,1)==1)

if rem(size(cp,1),2) cp=cp(1:(size(cp,1)-1))end

cp=reshape(cp,size(cp,1)/2,2)

for j=1:size(cp,1)

a=cp(j,1)b=cp(j,2)

[endPop(a,:) endPop(b,:)] = feval(xN,endPop(a,:),endPop(b,:),...

bounds,[gen xOverOps(i,:)])

end

end

for i=1:numMuts

mN=deblank(mutFNs(i,:))

for j=1:popSize

endPop(j,:) = feval(mN,endPop(j,:),bounds,[gen mutOps(i,:)])

eval(e1str)

end

end

end

gen=gen+1

done=feval(termFN,[gen termOps],bPop,endPop)%See if the ga is done

startPop=endPop %Swap the populations

[bval,bindx] = min(startPop(:,xZomeLength))%Keep the best solution

startPop(bindx,:) = best %replace it with the worst

end

[bval,bindx] = max(startPop(:,xZomeLength))

if display

fprintf(1,'\n%d %f\n',gen,bval)

end

x=startPop(bindx,:)

if opts(2)==0 %binary

x=b2f(x,bounds,bits)

bPop(bFoundIn,:)=[gen b2f(startPop(bindx,1:numVar),bounds,bits)...

startPop(bindx,xZomeLength)]

else

bPop(bFoundIn,:)=[gen startPop(bindx,:)]

end

if collectTrace

traceInfo(gen,1)=gen %current generation

traceInfo(gen,2)=startPop(bindx,xZomeLength)%Best fittness

traceInfo(gen,3)=mean(startPop(:,xZomeLength))%Avg fittness

end


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11275456.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-14
下一篇 2023-05-14

发表评论

登录后才能评论

评论列表(0条)

保存