小编Jac*_*uer的帖子

优雅的方式来比较JAR的内容(找到新的类和方法)

是的,互联网说 - "解压缩它们,反编译并将代码与某些工具进行比较(总指令器,WinCompare,meld(linux),等等......)我之所以需要一个工具来自动生成差异报告来自Fodler1和Folder2很简单 - 这些文件夹中有太多的JAR,我需要比较这些文件夹(下一版本的Jars),说一个月一次.所以,我真的不想手动完成!

让我们看看到目前为止我得到了什么:

1)我可以找到每个文件夹中的所有JAR :)

2)我可以从每个JAR获取类列表:

private static void AddAllClassesFromJAR(JarInputStream jarFile,
        ArrayList<String> classes) throws IOException {
    JarEntry jarEntry = null;
    while (true) {
        jarEntry = jarFile.getNextJarEntry();
        if (jarEntry == null) {
            break;
        }
        if (jarEntry.getName().endsWith(".class")) {
            classes.add(jarEntry.getName());
        }
    }
}

    public static List<String> getClasseNamesInPackage(String jarName) {
    ArrayList<String> classes = new ArrayList<String>();
    try {
        JarInputStream jarFile = new JarInputStream(new FileInputStream(jarName));
        AddAllClassesFromJAR(jarFile, classes);
    } catch (Exception e) {
        e.printStackTrace();
    }
        return classes;
    }
Run Code Online (Sandbox Code Playgroud)

3)Java中有反射(Core Java 2第I卷 - 基础,例5-5),所以一旦我知道它的名字,我就可以从一个类中获取方法列表.

为了做到这一点,我需要创建每个类的实例,问题是我如何制作每个JAR文件中获得的每个类的实例?现在我正在加载每个JAR: …

java jar classloader

5
推荐指数
1
解决办法
2106
查看次数

将具有已知编码的文件转换为UTF-8

我需要将文本文件转换为String,最后,我应该将其作为输入参数(类型为InputStream)放到IFile.create(Eclipse)中.寻找示例或如何做但仍然无法弄清楚...需要你的帮助!

只是为了测试,我尝试将原始文本文件转换为使用此代码编码的UTF-8

FileInputStream fis = new FileInputStream(FilePath);
InputStreamReader isr = new InputStreamReader(fis);

Reader in = new BufferedReader(isr);
StringBuffer buffer = new StringBuffer();

int ch;
while ((ch = in.read()) > -1) {
    buffer.append((char)ch);
}
in.close();


FileOutputStream fos = new FileOutputStream(FilePath+".test.txt");
Writer out = new OutputStreamWriter(fos, "UTF8");
out.write(buffer.toString());
out.close();
Run Code Online (Sandbox Code Playgroud)

但即使最终的*.test.txt文件有UTF-8编码,里面的字符也会被破坏.

java eclipse unicode encoding utf-8

4
推荐指数
1
解决办法
2万
查看次数

标签 统计

java ×2

classloader ×1

eclipse ×1

encoding ×1

jar ×1

unicode ×1

utf-8 ×1