FTPUtil 存在内存泄漏的bug?
来源:8-7 后台商品图片的springmvc上传与富文本上传ftp服务器功能开发2
qq_谁动了我的奶酪_03546962
2018-05-29
private boolean uploadFile(String remotePath,List<File> fileList) throws IOException {
boolean uploaded = true;
FileInputStream fis = null;
//连接FTP服务器
if(connectServer(this.ip,this.port,this.user,this.pwd)){
try {
ftpClient.changeWorkingDirectory(remotePath);
ftpClient.setBufferSize(1024);
ftpClient.setControlEncoding("UTF-8");
ftpClient.setFileType(FTPClient.BINARY_FILE_TYPE);
ftpClient.enterLocalPassiveMode();
for(File fileItem : fileList){
fis = new FileInputStream(fileItem);
ftpClient.storeFile(fileItem.getName(),fis);
}
} catch (IOException e) {
logger.error("上传文件异常",e);
uploaded = false;
e.printStackTrace();
} finally {
fis.close();
ftpClient.disconnect();
}
}
return uploaded;
}
private boolean connectServer(String ip,int port,String user,String pwd){
boolean isSuccess = false;
ftpClient = new FTPClient();
try {
ftpClient.connect(ip);
isSuccess = ftpClient.login(user,pwd);
} catch (IOException e) {
logger.error("连接FTP服务器异常",e);
}
return isSuccess;
}如果ftpClient.connect(ip);这句抛出异常,connectServer方法返回的结果是false, 然后ftpClient.disconnect();这句就不会被执行。
而且fis.close();这句没有对fis进行非空判断,fis也有很大概率是null的情况,如果fis.close();这句抛出空指针异常(或者其他异常),那么ftpClient.disconnect();这句也不会被执行了。
不知道我分析的是否有道理~
写回答
3回答
-
你好,同学,这个不会内存泄露,听你的意思是,关闭连接资源的问题。如果更好一点的是,可以把connectserver异常向上抛出即可。因为在upload里面有finally来关闭。
正常来说连接已经失败,这个连接也就会自然被JVM回收。因为不会再使用他,重新上传的时候也会重新去建立一个新的连接~~
012018-06-04 -
慕粉1433416698
2018-10-08
如果是上传多个File的话,finally中只关闭了最后一个fis.close(); 所以还是会内存泄露
00 -
慕神8589343
2018-05-29
ftpClient.connect(ip)都异常了,你还disconnect神马
012018-05-31
相似问题