
1 humpy Sep 28, 2021 方法签名不同啊 |
2 wangxn Sep 28, 2021 via Android C++不能这样,指不定 Java 可以。 |
4 tsanie Sep 28, 2021 这么神奇的嘛,那在这个类或其子类中调用 b()到底执行哪个方法? /doge |
5 mxT52CRuqR6o5 Sep 28, 2021 android java 是不是和原版 java 有点区别? |
6 BQsummer Sep 28, 2021 artifactId 和 version 是啥 |
7 ipwx Sep 28, 2021 盲猜字节码层面可能有些不一样(我不懂 java ) |
8 ligiggy Sep 28, 2021 我也不懂 java,但是有没有一种可能,我是说有没有一种可能,synchronized 这个用法会被编译器优化 |
9 yazinnnn Sep 28, 2021 gav 坐标发一下看看 |
10 wangsilence Sep 28, 2021 我本地试了 编译不通过啊 |
11 hsiafan Sep 28, 2021 JVM 里方法签名是包含返回值类型的,返回值类型不同,方法签名不同,可以同时存在。不能存在不同返回值类型的相同 Java 方法是 Java 语言层面的限制,也即 javac 编译的限制。直接操作字节码可以写出这样方法,是完全合法的。 |
12 kop1989 OP @xiaxiaocao #11 学习了,能不能大概说说这样做的意义和场景? |
13 nonoyang Sep 28, 2021 如果编译通过,直接调用 PushMessageHandler.b(),忽略返回值,你觉得代码能知道该调用哪个? |
15 evi1j Sep 28, 2021 via Android java 泛型的桥接模式也有这种情况,javap 之后就会看到有签名相同的方法 |
16 maokabc Sep 28, 2021 via Android 不是返回值不同吗?一个方法签名()V,一个()Z,java 层面不能这样写,字节码可以。 再说了内部类有时生成一些方法名和方法签名完全一样的方法,就访问控制符多了 bridge 之类,之前做安卓的加固遇到过,怕出问题就没把 bridge 这类方法转为 native 。 |
17 secondwtq Sep 28, 2021 有点像 C++ 的 name mangling |
18 leaves615 Sep 28, 2021 字节码混淆(压缩)过的 jar 。 不能直接反编译过来用的。 下一个问题。 |