gpt4 book ai didi

java - 我的 Swing 类中有太多嵌套类

转载 作者:行者123 更新时间:2023-11-29 06:17:00 25 4
gpt4 key购买 nike

我需要使用这些嵌套类,因为嵌套类可以使用嵌套类中的变量。我如何将这些类移动到 something.java 以简化我的代码并且该类仍然具有 gui 类的控制权,例如 Jlabel?

这是展示重要部分的清理版本

public class GUI {

public GUI(){

VitaminDEngineStarter vdes = new VitaminDEngineStarter();
Registry registry = null;
try {
registry = LocateRegistry.getRegistry();
} catch (RemoteException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}

try {
vd = (VitaminD)registry.lookup(VitaminD.SERVICE_NAME);
} catch(Exception e) {
e.printStackTrace();
}



SMS a = new SMS(5);
try {
arduino.connect("COM3");
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("connecting:"+ a.connect());
System.out.println("connected? :" + a.checkConnect());
System.out.println("signal: "+a.checkSignal());
System.out.println("deliver report :" + a.DeliveryReportOn());
SMS.Read read = a.new Read(arduino);


}

class ShowSense implements Runnable {


@Override
public void run() {
String[] temp;
String light = "";
String temperature = "";
String hum = "";
String sens = "";
boolean humanact = false;

// TODO Auto-generated method stub
while (true){
try {
humanact = vd.gethumanActivity();
} catch (RemoteException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
sens = arduino.getSensor();
temp = sens.split(",");
light = temp[1];
temperature = temp[0];
hum = temp[2];

LightIntensity.setText(light);
Temperature.setText(temperature);
humidity.setText(hum);


if (humanact){
personActivity.setText("in place");
}
else{
personActivity.setText("absent");
}

}
}

}

private JPanel getInputs() {
if (Inputs == null) {
personActivity = new JLabel();
personActivity.setBounds(new Rectangle(114, 137, 77, 27));
personActivity.setText("");
personActivityLabel = new JLabel();
personActivityLabel.setBounds(new Rectangle(7, 137, 99, 25));
personActivityLabel.setText("Person Activity:");
humidity = new JLabel();
humidity.setBounds(new Rectangle(106, 91, 84, 27));
humidity.setText("");
humidityLabel = new JLabel();
humidityLabel.setBounds(new Rectangle(6, 92, 88, 26));
humidityLabel.setText("Humidity:");
Temperature = new JLabel();
Temperature.setBounds(new Rectangle(101, 50, 89, 30));
Temperature.setText("");
TemperatureLabel = new JLabel();
TemperatureLabel.setBounds(new Rectangle(4, 50, 91, 30));
TemperatureLabel.setText("Temperature:");
LightIntensity = new JLabel();
LightIntensity.setBounds(new Rectangle(110, 6, 84, 34));
lightLabel = new JLabel();
lightLabel.setBounds(new Rectangle(5, 5, 97, 34));
lightLabel.setText("Light Intensity:");
Inputs = new JPanel();
Inputs.setLayout(null);
Inputs.setBounds(new Rectangle(14, 63, 200, 183));
Inputs.add(lightLabel, null);
Inputs.add(LightIntensity, null);
Inputs.add(TemperatureLabel, null);
Inputs.add(Temperature, null);
Inputs.add(humidityLabel, null);
Inputs.add(humidity, null);
Inputs.add(personActivityLabel, null);
Inputs.add(personActivity, null);
th.start();
}
return Inputs;
}

class autopilotthread implements Runnable{

/** The temp. */
private String[] temp;

/** The lightintensty. */
private double lightintensty ;

/** The temperature. */
private double temperature ;

/** The hum. */
private double hum ;

/** The sens. */
private String sens = null;

/** The humanact. */
private double humanact;

/** The result. */
private boolean [] result = {false , false};

/** The fan. */
private boolean fan =false;

/** The light. */
private boolean light = false;

/** The pstop. */
boolean pstop = false;

/* (non-Javadoc)
* @see java.lang.Runnable#run()
*/
@Override
public void run() {
System.out.println("thread start!");
while(true){
System.out.println("thread loop!");
try {
if(vd.gethumanActivity()){
humanact = 250;
}else{
humanact = 0;
}
} catch (RemoteException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
sens = arduino.getSensor();
temp = sens.split(",");
lightintensty = Double.parseDouble(temp[1]);
temperature = Double.parseDouble(temp[0]);
hum = Double.parseDouble(temp[2]);
double [] out ={humanact ,lightintensty , hum, Time.now(),temperature };
System.out.println(""+out[0]+" "+out[1]+" "+out[2]+" "+out[3]+" "+out[4]);
result = Matlab.output(out);
light = result[1];
fan = result[0];
System.out.println("light:" + light);
System.out.println("fan:" + fan );
if(light){
try {X10.lightsOn();}
catch (IOException e) {e.printStackTrace();}

}else{
try {X10.lightsOff();}
catch (IOException e) {e.printStackTrace();}

}

if(fan){
try {X10.fanOn();}
catch (IOException e) {e.printStackTrace();}

}else{
try {X10.fanOff();}
catch (IOException e) {e.printStackTrace();}

}



try {TimeUnit.SECONDS.sleep(10);}
catch (InterruptedException e) {e.printStackTrace();}

if (pstop){
break;
}
}
System.out.println("thread stop!");

}

}

class Pilotmouse implements MouseListener{

/** The p thread. */
autopilotthread pThread = null;

/** The pt. */
Thread pt = null;

/**
* Instantiates a new pilotmouse.
*/
Pilotmouse(){

}

/* (non-Javadoc)
* @see java.awt.event.MouseListener#mouseClicked(java.awt.event.MouseEvent)
*/
@Override
public void mouseClicked(MouseEvent arg0) {
// TODO Auto-generated method stub

}

/* (non-Javadoc)
* @see java.awt.event.MouseListener#mouseEntered(java.awt.event.MouseEvent)
*/
@Override
public void mouseEntered(MouseEvent arg0) {
// TODO Auto-generated method stub

}

/* (non-Javadoc)
* @see java.awt.event.MouseListener#mouseExited(java.awt.event.MouseEvent)
*/
@Override
public void mouseExited(MouseEvent arg0) {
// TODO Auto-generated method stub

}

/* (non-Javadoc)
* @see java.awt.event.MouseListener#mousePressed(java.awt.event.MouseEvent)
*/
@Override
public void mousePressed(MouseEvent arg0) {
// TODO Auto-generated method stub

}

/* (non-Javadoc)
* @see java.awt.event.MouseListener#mouseReleased(java.awt.event.MouseEvent)
*/
@Override
public void mouseReleased(java.awt.event.MouseEvent e) {
if ((autopilotlable.getText().equalsIgnoreCase("off"))){
autopilotlable.setText("on");
pThread = new autopilotthread();
pt = new Thread(pThread);
pt.start();

} else if ((autopilotlable.getText().equalsIgnoreCase("on"))){
autopilotlable.setText("off");
pThread.pstop = true;
}
}

}


private JButton getAutopilot() {


if (autopilot == null) {
autopilot = new JButton();
autopilot.setBounds(new Rectangle(18, 14, 112, 28));
autopilot.setText("Auto Pilot");

autopilot.addMouseListener(new Pilotmouse());
}
return autopilot;
}


public static void main(String[] args) {
SwingUtilities.invokeLater(new Runnable() {
public void run() {
GUI application = new GUI();
application.getJFrame().setVisible(true);
}
});

}

}

最佳答案

正如 Jochen 提到的,您可以使用 Eclipse 重构工具。但这并不能解决设计问题。

通常:

  • GUI 知道 14 个类和行为作为大调解员……有没有可能将逻辑分组到更高级别类并让 GUI 使用它们?
  • 您的代码混合了对象构造与逻辑。尝试移动那些 Action 去不同的地方
  • 不要在里面启动线程构造函数!
  • 修改逻辑的用法声明。例如。 : 而(真){ ...如果 (pstop){ 休息; }
  • X10 是第 3 方类还是您自己的?如果是你的,请尝试删除全局状态(例如使用 X10 的单个实例和状态的实例变量改变。不是静态的)

最重要的建议:请尝试首先使用(例如)junit 和 mockito 为该功能编写单元测试,好的设计自然会出现。相信我!

编辑:

Good talk about JMM

Good book about concurrency .

编辑:

The Clean Code Talks - "Global State and Singletons"

关于java - 我的 Swing 类中有太多嵌套类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4731645/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com