Я хочу продемонстрировать с помощью нескольких строк кода, что в Java, что для сравнения двух строк ( String
), вы должны использовать equals ()
вместо оператора ==
.
Вот что я попробовал:
public static void main(String Args[]) {
String s1 = "Hello";
String s2 = "Hello";
if (s1 == s2)
System.out.println("same strings");
else
System.out.println("different strings");
}
Я ожидал этого вывода: разные строки
, потому что с test s1 == s2
Я фактически сравниваю две ссылки (т.е.
Файл destDir = ....; ImaginaryZipUtility.unzipAllTo (zipFile, destdir); Я не могу быть первым, кто сделает это из ...
Я хотел бы сделать что-то подобное в моей программе:
File zipFile = .....;
File destDir = ....;
ImaginaryZipUtility.unzipAllTo(zipFile, destdir);
Я не могу быть первым, кто сделал это из программы. Где я могу найти полезный метод, как указано выше? Я пытался взглянуть на Apache Commons-IO, но ничего там. Итак, где мне искать?
Кажется, с помощью библиотеки TrueZip можно делать то, что я хочу: https://truezip.dev.java.net/manual-6.html#Copying
Это не идеальная ситуация, так как библиотека довольно большая и с большим объемом, чем мне нужно (а также с некоторые специфические и запутанные детали, такие как организация вокруг подклассов java.io.File, которые также называются File для использования в классах, которые обычно также обрабатывают экземпляры java.io.File!).
По крайней мере, мне не нужно быть в ситуации, когда большинство строк кода в классе не связаны с ответственностью класса, или поддерживать в проекте сложный служебный класс, не связанный с целью модуля.
Я думаю, что это типичный пример основной причины, по которой опытные разработчики переходят с Java на Ruby. Несмотря на обилие библиотек в java, слишком многие из них плохо спроектированы, так что простые операции становятся такими же трудными для выполнения, как и более специализированные. Кажется, что они написаны снизу вверх экспертами в области технологий, которые больше хотят раскрыть все детали и возможности, чем упростить повседневные задачи. Люди Apache Commons заслуживают чести за создание библиотек, которые освобождают ваш класс от строк кода, особенно циклов и условных выражений, которые не связаны с бизнес-целью класса.
Очень старый код, который мне удалось откопать
package com.den.frontend;
import java.util.*;
import java.util.zip.*;
import java.io.*;
public class ZIPUtility
{
public static final int BUFFER_SIZE = 2048;
//This function converts the zip file into uncompressed files which are placed in the
//destination directory
//destination directory should be created first
public static boolean unzipFiles(String srcDirectory, String srcFile, String destDirectory)
{
try
{
//first make sure that all the arguments are valid and not null
if(srcDirectory == null)
{
System.out.println(1);
return false;
}
if(srcFile == null)
{
System.out.println(2);
return false;
}
if(destDirectory == null)
{
System.out.println(3);
return false;
}
if(srcDirectory.equals(""))
{
System.out.println(4);
return false;
}
if(srcFile.equals(""))
{
System.out.println(5);
return false;
}
if(destDirectory.equals(""))
{
System.out.println(6);
return false;
}
//now make sure that these directories exist
File sourceDirectory = new File(srcDirectory);
File sourceFile = new File(srcDirectory + File.separator + srcFile);
File destinationDirectory = new File(destDirectory);
// Prevent "Zip Slip" vulnerability https://snyk.io/research/zip-slip-vulnerability
String canonicalDestinationFile = sourceFile.getCanonicalPath();
if (!canonicalDestinationFile.startsWith(destinationDirectory.getCanonicalPath() + File.separator)) {
throw new Exception("Entry is outside of the target dir: " + e.getName());
}
if(!sourceDirectory.exists())
{
System.out.println(7);
return false;
}
if(!sourceFile.exists())
{
System.out.println(sourceFile);
return false;
}
if(!destinationDirectory.exists())
{
System.out.println(9);
return false;
}
//now start with unzip process
BufferedOutputStream dest = null;
FileInputStream fis = new FileInputStream(sourceFile);
ZipInputStream zis = new ZipInputStream(new BufferedInputStream(fis));
ZipEntry entry = null;
while((entry = zis.getNextEntry()) != null)
{
String outputFilename = destDirectory + File.separator + entry.getName();
System.out.println("Extracting file: " + entry.getName());
createDirIfNeeded(destDirectory, entry);
int count;
byte data[] = new byte[BUFFER_SIZE];
//write the file to the disk
FileOutputStream fos = new FileOutputStream(outputFilename);
dest = new BufferedOutputStream(fos, BUFFER_SIZE);
while((count = zis.read(data, 0, BUFFER_SIZE)) != -1)
{
dest.write(data, 0, count);
}
//close the output streams
dest.flush();
dest.close();
}
//we are done with all the files
//close the zip file
zis.close();
}
catch(Exception e)
{
e.printStackTrace();
return false;
}
return true;
}
private static void createDirIfNeeded(String destDirectory, ZipEntry entry)
{
String name = entry.getName();
if(name.contains("/"))
{
System.out.println("directory will need to be created");
int index = name.lastIndexOf("/");
String dirSequence = name.substring(0, index);
File newDirs = new File(destDirectory + File.separator + dirSequence);
//create the directory
newDirs.mkdirs();
}
}
}