修改
对不起拼写错误和拼写错误,我不想把我的代码放在这里,所以我试着用一个新的代码来表达我的问题。
这是我正在使用的实际代码,我刚刚删除了它的一些部分,因为它们与我的问题无关,我想,否则只要问我,我也会把它放在这里。
下面是实际的代码:
public class Dados {
private String sta;
private String ap;
private int startTime;
private int endTime;
private int repetitionSTA;
private int pingPong;
private int tt_previous;
private int tt_next;
private int id;
public Dados(int id, int startTime, int endTime, String ap, String sta, int repetitionSTA, int ttprevious, int ttnext, int ppong)
{
this.sta = sta;
this.ap = ap;
this.startTime = startTime;
this.endTime=endTime;
this.pingPong = ppong;
this.tt_next = ttnext;
this.tt_previous = ttprevious;
this.id = id;
this.repetitionSTA = repetitionSTA;
}
// SET
public void setPingPong()
{
this.pingPong = 1;
}
//GET
public int getPingPong()
{
return this.pingPong;
}
}
//从现在开始的另一个课
public class Queries extends LigarBD{
String dbtime = null;
int id = 1;
TreeMap<Integer, ArrayList> tmValores = new TreeMap<>();
ArrayList<Dados> listaObjectos = new ArrayList<>();
ArrayList<Dados> listaObjectos2 = new ArrayList<>();
public ArrayList getUniqueStations(String server)
{
ArrayList<String> listaSTA = new ArrayList<>();
String query = "SELECT distinct calling_station_id FROM java_logs;";
try
{
super.ligar(server);
Statement s = super.getConexao().createStatement();
ResultSet rs = s.executeQuery(query);
while (rs.next())
{
listaSTA.add(rs.getString(1));
}
rs.close();
s.close();
super.desligar(super.getConexao());
}
catch (Exception e)
{
JOptionPane.showMessageDialog(null, "Error at listing all unique stations. Reason -> "+e.getMessage());
System.out.println("Error at listing all unique stations. Reason -> "+e.toString());
}
return listaSTA;
}
public ArrayList getStationData(String mac, String server)
{
try
{
super.ligar(server);
Statement s = getConexao().createStatement();
ResultSet rs = s.executeQuery("SELECT timestamp-acct_session_time, timestamp, called_station_id, calling_station_id "
+ "FROM java_logs where calling_station_id = '"+mac+"';"); // retirar STA da query *******************
//System.out.println("Executing the Query on+"+server+" - UniqueSTA - Query number: 1?");
int repetitionSTA=1;
while (rs.next())
{
Dados d = new Dados(id, rs.getInt(1), rs.getInt(2), rs.getString(3), rs.getString(4), repetitionSTA, 0, 0, 0);
listaObjectos2.add(d);
repetitionSTA++;
id++;
}
rs.close();
s.close();
super.desligar(super.getConexao());
}
catch (Exception e)
{
JOptionPane.showMessageDialog(null,"Error at Select Query. Reason -> "+e.getMessage());
}
return listaObjectos2;
}
}
另一堂课:
public class Pingpong {
ArrayList<Dados> dadosArray = new ArrayList<>();
Queries q = new Queries();
TreeMap<Integer, ArrayList> mapa = new TreeMap<>();
ArrayList<Dados> arrayDeDados = new ArrayList<>();
public ArrayList detectPingPongArray(int threshold_access_session_time, int threshold_transition_time, ArrayList<Dados> dadosSTA)
{
dadosArray=dadosSTA;
for(int i = 1; i<arrayDeDados.size()-1; i++)
{
dadosArray.get(i).setPingPong();
}
return dadosArray;
}
}
这是我逐个打印每个对象的地方:
ArrayList<Dados> dadosSTA = new ArrayList<>();
ArrayList<Dados> dataForPPong = new ArrayList();
ArrayList uniqueSTA = q.getUniqueStations("localserver");
for(int i = 0; i<uniqueSTA.size(); i++)
{
dadosSTA = q.getStationData(uniqueSTA.get(i).toString(), "localserver");
dataForPPong = p.detectPingPongArray(5, 3, dadosSTA);
}
for(int i=0; i<dataForPPong.size(); i++)
{
System.out.println("ID: "+dataForPPong.get(i).getId()+" STA: "+dataForPPong.get(i).getStation()
+ " PingPong: "+dataForPPong.get(i).getPingPong());
}
所以我期待它将所有对象中pingPong的值更改为1,但事实并非如此。
我认为问题在于从方法detectPingPongArray返回,但我不知道错误在哪里。
任何人都可以在这里查明问题吗?
答案 0 :(得分:3)
我会说你的代码中有一些不好的做法,例如忽略ArrayList
中的泛型,但让我们谈谈。
在我看来,您的问题在于以下方法:
public ArrayList detectPingPongArray(
int threshold_access_session_time,
int threshold_transition_time,
ArrayList<Dados> dadosSTA
) {
dadosArray=dadosSTA;
for(int i = 1; i<arrayDeDados.size()-1; i++) {
dadosArray.get(i).setPingPong();
}
return dadosArray;
}
这是您的代码,只是使用不同的格式来适应答案。
该方法会收到ArrayList<Dados> dadosSTA
,您可以将其分配给dadosArray
您返回此相同的变量,并且您希望对其执行修改。
但是,你正在迭代arrayDeDados
的大小,一个不同的 ArrayList<Dados>
,并且从你给我们的那个开始,也是为空列表。
ArrayList<Dados> arrayDeDados = new ArrayList<>();
因此,由于空列表的size()
为零,因此不执行迭代,并且永远不会调用setPingPong()
。
根据要求,我还要为未来添加一些提示。
虽然不一定是一种不好的做法,更多的是个人偏好,但我不会用葡萄牙语(在这种情况下似乎是这样)或任何英语以外的语言来命名我的类/变量。在这种情况下,它可以使代码对其他人更具可读性。
public class Queries extends LigarBD
我不确定在数据库上执行查询的类应扩展连接到数据库的类。相反,使用连接到数据库的类似乎更合适。
您可以通过代码中的某些模式轻松看到这一点,例如super.ligar()
,super.getConexao()
,super.desligar()
,您可以在与我们共享的两种方法中执行此操作。您似乎对使用LigarBD
提供的界面感兴趣,而不是对其进行扩展或添加功能。您可以通过声明类型为LigarBD
的实例变量并相应地使用它来更改此项。
public ArrayList detectPingPongArray
在这里,您丢弃与ArrayList
相关的通用信息。
如果您知道您将返回ArrayList<Dados>
,并且您希望此方法的调用者也知道这一点,则应按以下方式声明该方法:
public ArrayList<Dados> detectPingPongArray
这样,来电者将需要ArrayList<Dados>
,而不是ArrayList
的某些内容(可能会引入不安全的演员/操作)。
我也不确定这是否是故意的,但我在你的代码中发现了一些相当奇怪的东西。
ArrayList<Dados> dadosSTA = new ArrayList<>();
ArrayList<Dados> dataForPPong = new ArrayList();
ArrayList uniqueSTA = q.getUniqueStations("localserver");
for(int i = 0; i<uniqueSTA.size(); i++)
{
dadosSTA = q.getStationData(uniqueSTA.get(i).toString(), "localserver");
dataForPPong = p.detectPingPongArray(5, 3, dadosSTA);
}
for(int i=0; i<dataForPPong.size(); i++)
{
System.out.println("ID: "+dataForPPong.get(i).getId()+" STA: "+dataForPPong.get(i).getStation()
+ " PingPong: "+dataForPPong.get(i).getPingPong());
}
第一个for
循环只是为变量分配新值,对它们不执行任何操作并不断覆盖它们。
您可能希望此循环还包含第二个循环,以便为分配给ArrayList
的每个dataForPPong
有效地打印所有值。或者您将来会在此循环中添加其他内容,但我想指出这可能是未来的错误来源。