通过Jdk的命令javap可以反编译查看字节码,但是在使用idea的时候一直用命令行去操作不太好操作,而且因为idea会把class码 放在target里面,经常会忘记切换目录.这个时候idea的External Tools就派上用场了. 具体操作如下,先到idea的设置界面 进入Tools >  External Tools中 添加工具,分别设置program,argument等,其中arguments中是javap的参数,具体的参数信息可以去看下help信息 之后在打开的java文件界面右键…
1.synchronized介绍 synchronized是java关键字.JVM规范中,synchronized关键字用于在线程并发执行时,保证同一时刻,只有一个线程可以执行某个代码块或方法:同时还保证了代码在执行完后所修改的数据对其它线程是可见的.总结来说:synchronized解决了并发编程安全问题的原子性,可见性,顺序行.Java中每一个对象都可以作为锁(monitor),这是synchronized实现同步的基础.synchronized作用于每一个对象时,要求占有当前对象的锁要么没…
一个例子 public class TestString{ public static void main(String[] args){ String a = "a"; String b = a+"b"; String c = "ab"; String d = "a" + "b"; System.out.println(c == d); //true!!!! System.out.println(c ==…
2016-07-04 15:56:39 我们都知道: 1.内部类可以直接访问外部类的private字段和方法: 2.非静态内部类持有外部类的引用: 3.外部类可以直接访问内部类的private字段和方法(不管是不是静态内部类): 最近看到一篇文章,大意是讨论这个的,处于好奇,想从字节码的角度研究一下原因,于是有此文. 1.关于javap命令: "The javap command disassembles one or more class files. The output depends o…
一个普通的Java类: package org.ccnt.concurrence; public class VolatileTest { public static volatile int race = 0; public static void increate() { race ++; } private static final int THREAD_COUNT = 20; public static void main(String[] args) { Thread[] thread…
javap命令所有参数如下图所示: javap 命令用于解析类文件.其输出取决于所用的选项.若没有使用选项,javap 将输出传递给它的类的 public 域及方法.javap 将其输出到标准输出设备上. 命令选项 -help 输出 javap 的帮助信息. -l 输出行及局部变量表. -b 确保与 JDK 1.1 javap 的向后兼容性. -public 只显示 public 类及成员. -protected 只显示 protected 和 public 类及成员. -package 只显示…
在Sun公司提供的JDK中,就已经内置了Java字节码文件反编译工具javap.exe(位于JDK安装目录的bin文件夹下). 我们可以在dos窗口中使用javap来反汇编指定的Java字节码文件.在使用javap的相关dos命令之前,你必须确保已经将JDK安装目录\bin添加到环境变量path中. 接着,我们就可以使用javap来反编译指定的Java字节码文件了.在此之前,我们先通过javap的帮助命令javap -help查看javap相关指令的用法. C:\Users\winner_071…
mac环境下Android 反编译 一.需要的工具 apktool:反编译APK文件,得到classes.dex文件,同时也能获取到资源文件以及布局文件. dex2jar:将反编译后的classes.dex文件转化为.jar文件. jd-gui:用于将.jar文件转换成java代码. 二.反编译步骤 第一步:使用apktool工具对APK进行反编译 1. 下载apktool:https://ibotpeaches.github.io/Apktool/install/ 2.把下载好的apktool…
https://zh.wikipedia.org/wiki/自修改代码 自修改代码(Self-modifying code)是指程序在运行期间(Run time)修改自身指令.可能的用途有:病毒利用此方法逃避杀毒软件的查杀,反静态分析,反盗版[1] ,单片机程序升级. 在暂存存储器中执行代码的计算机,可修改内存中的代码段,以往这种方法常被黑客用来制造病毒(参见:EICAR 测试病毒),现今许多操作系统及CPU提供限制程序修改代码段的方法.还可用于程序保护,增加软件破解人员的静态分析难度[2].…