所以我有一个用循环构造的类。在构造函数中,我有两个while循环,它们构成了圆圈的“网格”。它应该是一个围巾上课,但我称之为链甲,因为这听起来更酷。无论如何,我们应该能够用不同的(客户)类改变围巾的颜色。我显然需要添加一个mutator方法来改变颜色。幸运的是,在objectdraw中有一个名为setColor()的mutator。它工作正常,除非我尝试将其添加到此类时它只更改网格中的最后一个圆。我知道为什么会这样,但我不知道如何解决它。我已经评论过我们在课堂上一直使用的“典型”变种器。
编辑:抱歉混淆的人...这只是一个类,我有一个客户端调用一个新的ChainMail(),然后对它执行.setColor()但它只更改最后一个framedoval而不是所有他们这就是问题import objectdraw.*;
import java.awt.*;
public class ChainMail {
private FramedOval link;
public ChainMail(int rows,int links,
Location p,Color rgb,
DrawingCanvas c) {
double numRows = 0;
// create the number of rows specified
while (numRows < rows) {
double numLinks = 0;
// create the number of links specified
while (numLinks < links) {
link = new FramedOval(p,12,12,c);
link.setColor(rgb);
// update the position
p.translate(8,0);
numLinks++;
}
// move position back to front col and down one row
p.translate(-8*links,8);
numRows++;
}
}
public ChainMail(int rows,int links,Location p,DrawingCanvas c) {
this(rows,links,p,Color.BLACK,c);
}
/* this doesn't work, only changes last circle
* public void setColor(Color c) {
* link.setColor(c);
* }
*/
}
答案 0 :(得分:2)
如果你把它移到课堂上(如注释代码所示)那么你从哪里调用这个函数?我认为这是有所作为的。假设您正在执行以下操作:
此方案将给出您报告的结果,即只有最后圈出的颜色。 有两种方法可以解决这个问题:
答案 1 :(得分:1)
我说你因为这样做而把它们扔掉了:
while (numLinks < links) {
link = new FramedOval(p,12,12,c);
link.setColor(rgb);
// update the position
p.translate(8,0);
numLinks++;
}
但是你在哪里使用你创建的FramedOval做了什么?每次你创建一个新的FramedOval对象并有链接引用它时,先前的引用会丢失并且可能是垃圾收集;它被丢弃了,没有意义。
通常你会做类似的事情:
List<FramedOval> framedOvalList = new LinkedList<FramedOval>(); // or ArrayList
while (numLinks < links) {
link = new FramedOval(p,12,12,c);
link.setColor(rgb);
// *** here add the created object to some collection
framedOvalList.add(link);
// update the position
p.translate(8,0);
numLinks++;
}
但是我没有看到你做任何类似的事情。