java常用命令位于jdk的bin目录下:
javac命令:用于编译java源代码成.class字节码文件
javac Hello.java
java命令:运行字节码文件或者一个jar包:
java test.class
java -jar test.jar
jar命令:jar是Java归档工具命令,用于打包Java类文件和其他相关文件到同一个Jar文件中或者解压缩一个jar包
jar -cvfm test.jar MENIFEST.MF Hello.class Test.class
参数c表示要创建一个新的jar包,v表示创建的过程中在控制台输出创建过程的一些信息,f表示给生成的jar包命名,参数m,表示要定义MENIFEST文件
jar包结构目录如下:
META-INF
Hello.class
Test.class
javadoc命令:javadoc是Java文档生成命令,用于从Java源代码文件中提取注释和生成HTML格式的API文档
javap命令:对字节码文件进行反编译
jps命令:用于列出jvm进程信息
jps [options] [hostid] 常用参数如下: -l:显示完整的包名和应用程序主类名。 -m:显示完整的包名、应用程序主类名和虚拟机的启动参数。 -v:显示虚拟机的启动参数和JVM命令行选项。 -q:只显示进程ID,不显示类名和主类名。
jstack命令:jstack用于生成Java应用程序的线程堆栈跟踪信息,常用来查看每个线程的状态、调用栈及相关信息。用法如下:
jmap命令:jmap命令用于生成Java堆转储文件并查看对象内存占用情况的工具,常用来排查内存泄漏、分析内存占用问题以及分析JVM的垃圾收集器行为,用法如下:
jmap [options] <pid>
常用参数如下:
-heap:显示Java堆内存的详细信息,包括堆大小、使用情况和垃圾收集器的相关信息。
-histo[:live]:显示堆中对象的统计信息,如果指定了live子选项,则只计算活动的对象。
-clstats:打印类加载信息。
-finalizerinfo:显示在F-Queue队列等待Finalizer线程执行finalizer方法的对象。
-dump:<dump-options>:生成堆转储快照,<dump-options>可以指定输出格式和文件路径。
Java命令可以用来排查Cpu、内存飚高问题。以下为Cpu飚高的具体排查步骤:
1、找到进程pid :ps -ef | grep java
2、使用top命令查看cpu/memory占用高的tid:top -Hp pid
3、使用jstack命令生成线程的堆栈信息文件:jstack pid > bak.stack
4、使用printf命令将线程id转换为十六进制:printf "%x\n" tid
5、查看生成的bak.stack堆栈文件,找到十六进制tid对应的内容
6、分析生成的堆栈信息,查找占用CPU过高的线程对应的代码是做什么业务逻辑。在分析堆栈信息时,也可以查看线程状态(如BLOCKED, WAITING, TIMED_WAITING, RUNNABLE),确定线程是在等待资源、在执行同步块还是在进行IO操作。根据这些信息,结合代码逻辑,进行相应的优化。
less bak.stack
android网络:
https://www.cnblogs.com/nan-jing/archive/2012/10/26/2741110.html
android mtp流程: