- 浏览: 206805 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (124)
- 一段耗CPU的随机生成字符串的代码,why? (1)
- 生活如何才能不匆忙? (1)
- Null Object设计模式 (1)
- 珍爱生命,远离java (1)
- Oracle强杀进程,解决表锁死等问题 (1)
- java发送消息到RTX提醒 (1)
- 以HTTP形式获取图片流并写入另一个图片 (1)
- struts2获取Session和request方法 (1)
- 洛克菲勒.第一封:起点不决定终点 (1)
- tomcat的OutOfMemoryError解决方法 (1)
- REST和SOAP:谁更好,或者都好? (1)
- 35款免费的Javascript、Flash Web图表组件 (1)
- 盘点:三十五个非主流开源数据库 (1)
- Lucene并发连接实现 - ConcurrentLuceneConnection (1)
- 能大大提升工作效率和时间效率的9个重要习惯 (1)
- 读周鸿祎的《乔布斯的拿来主义》后感 (1)
- 表变量与临时表的优缺点 (1)
- Visual C++线程同步技术剖析 (转载) (1)
- 海量数据处理专题1——Bloom Filter (1)
- 海量数据处理专题2——Hash (1)
- 海量数据处理专题3——Bit-map (1)
- 海量数据处理专题4——堆 (1)
- 海量数据处理专题5——双层桶划分 (1)
- 海量数据处理专题6——数据库索引及优化 (1)
- 海量数据处理专题7——倒排索引(搜索引擎之基石) (1)
- 如何让优化你在搜索引擎上的形象 (1)
- 20个专业的SEO网站分析工具 (1)
- 杯具了,武汉开出国内首张个人网店税单:征税430余万 (1)
- java关键字的实现原理 (1)
- 关于Class类的成员函数与Java反射机制,坦言Synchronize的本质 (1)
- iBATIS的一对多关联查询 (1)
- 详解spring 依赖注入的作用 (1)
- 为什么要用JSP做显示而不用servlet? (1)
- 解决:java webservice调用net 参数返回NULL (1)
- Lucene搜索 关键字高亮 (1)
- Java常用类 Object类简单用法和深入 (1)
- 我在上海奋斗五年 从月薪3500到700万 (1)
- 每个Java初学者都应该搞懂的六个问题 (1)
- 强 奸数据库就这八步! (0)
- 数据库就这八步! (1)
- 什么才是最好处理中文方法 (1)
- JS实现简单的ajax访问Struts2的action类 (1)
- 跨域终极解决办法 (1)
- 由Map的复制问题引发对深复制和浅复制的思考 (1)
- Object类型转换为String类型的两种方式 (1)
- 写Java程序的三十个基本规则 (1)
- java计算时间差及某个时间段数据 (1)
- 推荐10个Java开源CMS系统 (1)
- 折半插入排序java实现 (1)
- 什么是程序员的优秀品质? (1)
- JDK Proxy AOP实现 (1)
- Java的最优化内存管理 (1)
- 100个Java经典例子 (1)
- java多态反射机制例子 (1)
- hashCode与equals的区别与联系 (1)
- 软件公司如何才能留住员工 (1)
- Java模拟操作系统进程调度算法—先来先服务、短作业优先、高响比优先 (1)
- 抛砖引玉 教你如何成为一名Java初级程序员 (1)
- 是什么成就了一名“高级”程序员? (1)
- 10分钟教会你Apache Shiro (1)
- Lucene排序 Payload的应用 (1)
- Lucene3.0之结果排序 (1)
- synchronized和java.util.concurrent.locks.Lock的异同 (1)
- 如何把Object对象转换为XML (1)
- 大流量网站的底层系统架构 (1)
- 程序员应该知道的100个vim命令 (1)
- 小编辑 Java 6 JVM参数选项大全(中文版) (1)
- 使用 Java Native Interface 的最佳实践 (1)
- 您适合从事Web前端开发行业吗? (1)
- 一个当了爹的程序员的自白 (1)
- Hibernate中设置MySQL的中文编码 (1)
- 雅虎声明称董事会运转良好 杨致远无需辞职 (1)
- IBM开源Java语言变种NetRexx (1)
- Tomcat VS Jetty (1)
- 正版office 2007 简体中文专业版(附正版序列号)高速下载正版office 2007 简体中文专业版 (1)
- java程序员应该知道的两种引用 (1)
- 基于Oracle 分布式数据库的查询优化 (1)
- JAVA设计模式 (1)
- java高并发-静态页面生成方案(1) (1)
- 程序员和编码员之间的区别 (1)
- 看看美国是如何解决开发人员的缺陷的 (1)
- ClassNotFoundException: org.springframework.web.util.IntrospectorCleanupListener (1)
- 开发模式 (0)
最新评论
-
泛黄秋颜:
大神你好,我最近在做云显示,奈何就是不会,能不能麻烦您发我一份 ...
Java实现标签云 -
Zhang_amao:
我的QQ邮箱1101232017@qq.com
Java实现标签云 -
Zhang_amao:
您好, 我现在也在研究这一领域,特别需要java版本来生成中文 ...
Java实现标签云 -
moon198654:
Technoboy 写道引用
总结
本文介绍了目前 Java ...
Tomcat VS Jetty -
mengxiangzhou:
dfvdf
Java模拟操作系统进程调度算法—先来先服务、短作业优先、高响比优先
本文 是基于最新的SUN官方 文档Java SE 6 Hotspot VM Options 编写的译文。主要介绍JVM 中的非稳态选项及其使用说明。
为了让读者明白每个选项的含义,作者在原文基础上补 充了大量的资料 。希望这份文档,对正在研究JVM 参数的朋友有帮助!
另外,考虑到本文档是初稿,如有描述错误,敬请指正。
非稳态 选项使用说明
-XX:+<option> 启用选项
-XX:-<option> 不启用选项
-XX:<option>=<number>
给选项设置一个数字类型值,可跟单位,例如 32k, 1024m, 2g
-XX:<option>=<string>
给选项设置一个字符串值,例如-XX:HeapDumpPath=./dump.core
行为 选项
选项 |
默认值与限制 |
描述 |
-XX:-AllowUserSignalHandlers |
限于Linux 和Solaris ,默认不启用 |
允许为java 进 程安装信号处理器。
|
-XX:-DisableExplicitGC |
默认不启用 |
禁止在运行期显式地调用 System.gc() 。
开启该选项后,GC
的 触发时机将由Garbage Collector
全权掌控。 例如RMI 就在多 数用户毫不知情的情况下,显示地调用GC 来防止自身OOM 。 请仔细权衡禁用带来的影响。 |
-XX:-RelaxAccessControlCheck |
默认不启用 |
在Class 校验 器中,放松对访问控制的检查。
作用与reflection 里 的setAccessible 类似。 |
-XX:-UseConcMarkSweepGC |
默认不启用 |
启用CMS 低停顿 垃圾收集器。
资料详见:http://kenwublog.com/docs/CMS_GC.pdf |
-XX:-UseParallelGC |
-server 时启用 其他情况下,默认不启用 |
策略为新生代使用并行清除,年老代使用单线程Mark-Sweep-Compact 的垃圾收集器。 |
-XX:-UseParallelOldGC |
默认不启用 |
策略为老年代和新生代都使用并行清除的垃圾收集器。 |
-XX:-UseSerialGC |
-client 时启用 其他情况下,默认不启用 |
使用串行垃圾收集器。 |
-XX:+UseSplitVerifier |
java5 默认不启用 java6 默认启用 |
使用新的Class 类 型校验器 。
Classload顺序
(供参考)
|
-XX:+FailOverToOldVerifier |
Java6 新引入选项,默认启用 |
如果新的Class 校 验器检查失败,则使用老的校验器。
为什么会失败? 因为JDK6 最高 向下兼容到JDK1.2 ,而JDK1.2 的class info 与JDK6 的info 存在较大的差异,所以新校验器可能会出现校验失败的情况。
|
-XX:+HandlePromotionFailure |
java5 以前是默认不启用,java6 默认启用 |
关闭新生代收集担保。
为了确保minor gc
能 够顺利完成,GC
需要在年老代中额外保留一块足以容纳所有活跃对象的内存空间。 为了确保极端情况的发生,GC参考了最坏情况下的新生代内存占 用,即Eden+First Survivor。 这种策略无疑是在浪费年老代内存,从时序角度看,还会提前触发Full GC 。 为了避免如上情况的发生,JVM 允 许开发者手动关闭新生代收集担保。
在开启本选项后,minor gc 将不再提供新生代收集担保,而是在出现survior 或年老代不够用时,抛出promotion failed 异常。 |
-XX:+UseSpinning |
java1.4.2 和1.5 需要手动启用, java6 默 认已启用 |
启用多线程自旋锁优化。
大家知道,Java
的 多线程安全是基于Lock
机制实现的,而Lock
的 性能往往不如人意。 为了避免进入OS 互 斥,Java6 的开发者们提出了自旋锁优化。
自旋锁优化的原理是在线程进入OS 互 斥前,通过CAS 自旋一定的次数来检测锁的释放。 如果在自旋次数未达到预设值前锁已被释放,则当前线程会立即持有该锁。
CAS 检测锁的原理详见: http://kenwublog.com/theory-of-lightweight-locking-upon-cas
|
-XX:PreBlockSpin=10 |
-XX:+UseSpinning 必须先启用,对于java6 来说已经默认启用 了,这里默认自旋10 次 |
控制多线程自旋锁优化的自旋次数。( 什 么是自旋锁优化?见 -XX:+UseSpinning 处的描述)
|
-XX:+ScavengeBeforeFullGC |
默认启用 |
在Full GC前触发一次Minor GC。 |
-XX:+UseGCOverheadLimit |
默认启用 |
限制GC 的运行时 间。如果GC 耗时过长,就抛OOM 。 |
-XX:+ UseTLAB |
1.4.2 以前和使用-client 选项时,默认不启用,其余版本默认启用 |
启用线程本地缓存区(Thread Local )。 |
-XX:+UseThreadPriorities |
默认启用 |
使用本地线程的优先级。 |
-XX:+UseAltSigs |
限于Solaris , 默认启用 |
为了防止与其他发送信号的应用程序冲突,允许使用候补信号替代 SIGUSR1 和SIGUSR2 。 |
-XX:+UseBoundThreads |
限于Solaris , 默认启用 |
绑定所有的用户线程到内核线程。 |
-XX:+UseLWPSynchronization |
限于solaris , 默认启用 |
使用轻量级进程(内核线程)替换线程同步。 |
-XX:+MaxFDLimit |
限于Solaris , 默认启用 |
设置java 进程 可用文件描述符为操作系统允许的最大值。 |
-XX:+UseVMInterruptibleIO |
限于solaris,默认启用 |
在solaris 中, 允许运行时中断线程 。 |
选项与默认值 |
默认值与限制 |
描述 |
-XX:+ AggressiveOpts |
JDK 5 update 6 后引入,但需要手动启用。 JDK6 默认启用。 |
启用JVM 开发团 队最新的调优成果。例如编译优化,偏向锁,并行年老代收集等。 |
-XX:CompileThreshold=10000 |
1000 |
通过JIT 编译 器,将方法编译成机器码的触发阀值,可以理解为调用方法的次数,例如调1000 次,将方法编译为机 器码。 |
-XX: LargePageSizeInBytes =4m |
默认4m amd64 位:2m |
设置堆内存的内存页大小。
调整内存页的方法和性能提升原理,详见 http://kenwublog.com/tune-large-page-for-jvm-optimization |
-XX: MaxHeapFreeRatio =70 |
70 |
GC 后,如果发现空闲堆内存占到整个预估上限值的70% ,则收缩预估上限值。
什么是预估上限值? JVM 在启动时,会申请最大值(-Xmx 指定的数值)的地址空间,但其中绝大部分空间 不会被立即分配(virtual) 。 它们会一直保留着,直到运行过程中,JVM 发现实际占用接近已分配上限值时,才从virtual 里 再分配掉一部分内存。 这里提到的已分配上限值,也可以叫做预估上限值。
注意:预估上限值的大小一定小于或等于最大值。 |
-XX:MaxNewSize=size |
1.3. 1 Sparc: 32m 1.3.1 x86: 2.5m |
新生代占整个堆内存的最大值。 |
-XX:MaxPermSize=64m |
5.0 以后: 64 bit VMs 会增大预设值的30% 1.4 amd64: 96m 1.3.1 -client: 32m
其他默认 64m |
Perm (俗称方法区)占整个堆内存的最大值。 |
-XX:MinHeapFreeRatio=40 |
40 |
GC 后,如果发现空闲堆内存占到整个预估上限值的40% ,则增大上限值。 ( 什么是预估上限值?见 -XX:MaxHeapFreeRatio 处的描述)
关联选项: -XX:MaxHeapFreeRatio=70 |
-XX:NewRatio=2 |
Sparc -client: 8 x86 -server: 8 x86 -client: 12 -client: 4 (1.3) 8 (1.3.1+) x86: 1 2
其他默认 2 |
新生代和年老代的堆内存占用比例。 例如2 表示新生代 占最大堆内存的1/2 。即年老代和新生代平分堆的占用。 |
-XX:NewSize=2.125m |
5.0 以后: 64 bit Vms 会增大预设值的30% x86: 1m x86, 5.0 以 后: 640k
其他默认 2.125m |
新生代预估上限的默认值。( 什 么是预估上限值?见 -XX:MaxHeapFreeRatio 处的描述) |
-XX:ReservedCodeCacheSize =32m |
Solaris 64-bit, amd64, -server x86: 48m 1.5.0_06 之 前, Solaris 64-bit a m d64: 1024m
其他默认 32m |
设置代码缓存的最大值,编译时用。 |
-XX:SurvivorRatio=8 |
Solaris amd64: 6 Sparc in 1.3.1: 25 Solaris platforms 5.0 以前: 32
其他默认 8 |
Eden 与Survivor 的占用比例。例如8 表 示,一个survivor 区占用 1/8 的新生代内存,另外因为有2 个survivor , 所以survivor 总 共是占用新生代内存的 2/8 ,Eden 的 占比则为 6/8 。 |
-XX: TargetSurvivorRatio =50 |
50 |
实际使用的survivor 空 间大小占比。默认是50% ,最高90% 。 |
-XX:ThreadStackSize=512 |
Sparc: 512 Solaris x86: 320 (5.0 以前 256) Sparc 64 bit: 1024 Linux amd64: 1024 ( 5.0 以前 0 )
其他默认 512. |
线程堆栈大小 |
-XX:+UseBiasedLocking |
JDK 5 update 6 后引入,但需要手动启用。 JDK6 默认启用。 |
启用偏向锁。
|
-XX:+UseFastAccessorMethods |
默认启用 |
优化原始类型的getter 方 法性能。 |
-XX:-UseISM |
默认启用 |
启用solaris 的ISM 。
|
JDK 5 update 5 后引入,但需要手动启用。 JDK6 默认启用。 |
启用大内存分页。
调整内存页的方法和性能提升原理,详见http://kenwublog.com/tune-large-page-for-jvm-optimization
关联选项 -XX:LargePageSizeInBytes=4m |
|
-XX:+UseMPSS |
1.4.1 之前: 不启用 其余版本默认启用 |
启用solaris 的MPSS ,不能与ISM 同时使用。 |
-XX:+StringCache |
默认启用 |
启用字符串缓存。 |
-XX: AllocatePrefetchLines =1 |
1 |
与机器码指令预读相关的一个选项,资料比较少,本文档不做解释。有兴趣的 朋友请自行阅读官方doc 。 |
-XX:AllocatePrefetchStyle=1 |
1 |
与机器码指令预读相关的一个选项,资料比较少,本文档不做解释。有兴趣的 朋友请自行阅读官方doc 。 |
调试选项
选项与默认值 |
默认值与限制 |
描述 |
-XX:-CITime |
1.4 引入。 默认启用 |
打印JIT 编译器 编译耗时。 |
-XX:ErrorFile=./hs_err_pid<pid>.log |
Java 6 引入。 |
如果JVM crashed , 将错误日志输出到指定文件路径。 |
-XX:-ExtendedDTraceProbes |
Java6 引入,限于solaris 默认不启用 |
启用dtrace 诊断。 |
-XX:HeapDumpPath=./java_pid<pid>.hprof |
默认是java 进 程启动位置,即user.dir |
堆内存快照的存储文件路径。
什么是堆内存快照? 当java 进程因OOM 或crash 被OS 强制终止后,会生成一个hprof (Heap PROFling )格式的堆内存快照文件。该文件用于线下调试,诊断,查找问题。 文件名一般为 java_<pid>_<date>_<time>_heapDump.hprof 解析快照文件,可以使用 jhat, eclipse MAT ,gdb 等工具。 |
-XX:-HeapDumpOnOutOfMemoryError |
1.4.2 update12 和 5.0 update 7 引入。 默认不启用 |
在OOM 时,输出 一个dump.core 文件,记录当时的堆内存快照(什么是堆内存快照? 见 -XX:HeapDumpPath 处的描 述)。 |
-XX:OnError="<cmd args>;<cmd args>" |
1.4.2 update 9 引入 |
当java 每抛出 一个ERROR 时,运行指定命令行指令集。指令集是与OS 环 境相关的,在linux 下多数是bash 脚 本,windows 下是dos 批处理。 |
-XX:OnOutOfMemoryError="<cmd args>; |
1.4.2 update 12 和java6 时引入 |
当第一次发生OOM 时, 运行指定命令行指令集。指令集是与OS 环境相关的,在linux 下 多数是bash 脚本,windows 下是dos 批处理。 |
-XX:-PrintClassHistogram |
默认不启用 |
在Windows 下, 按ctrl-break 或Linux 下是执行kill -3 (发送SIGQUIT 信号)时,打印class 柱状图。
Jmap – histo pid 也实现了相同的功能。 详见 http://java.sun.com/javase/6/docs/technotes/tools/share/jmap.html |
-XX:-PrintConcurrentLocks |
默认不启用 |
在thread dump 的 同时,打印java.util.concurrent 的 锁状态。
Jstack – l pid 也同样实现了同样的功能。 详见 http://java.sun.com/javase/6/docs/technotes/tools/share/jstack.html |
-XX:-PrintCommandLineFlags |
5.0 引入,默认不启用 |
Java 启动时,往stdout 打印当前启用的非稳态jvm options 。
例如: -XX:+UseConcMarkSweepGC -XX:+HeapDumpOnOutOfMemoryError -XX:+DoEscapeAnalysis |
-XX:-PrintCompilation |
默认不启用 |
往stdout 打 印方法被JIT 编译时的信息。
例如: 1 java.lang.String::charAt (33 bytes) |
-XX:-PrintGC |
默认不启用 |
开启GC 日志打 印。
打印格式例如: [Full GC 131115K->7482K(1015808K), 0.1633180 secs]
该选项可通过 com.sun.management.HotSpotDiagnosticMXBean API 和 Jconsole 动态启用。 详见 http://java.sun.com/developer/technicalArticles/J2SE/monitoring/#Heap_Dump |
-XX:-PrintGCDetails |
1.4.0 引入,默认不启用 |
打印GC 回收的细 节。
打印格式例如: [Full GC (System) [Tenured: 0K->2394K(466048K), 0.0624140 secs] 30822K->2394K(518464K), [Perm : 10443K->10443K(16384K)], 0.0625410 secs] [Times: user=0.05 sys=0.01, real=0.06 secs]
该选项可通过 com.sun.management.HotSpotDiagnosticMXBean API 和 Jconsole 动态启用。 详见 http://java.sun.com/developer/technicalArticles/J2SE/monitoring/#Heap_Dump |
-XX:-PrintGCTimeStamps |
默认不启用 |
打印GC 停顿耗 时。
打印格式例如: 2.744 : [Full GC (System) 2.744: [Tenured: 0K->2441K(466048K), 0.0598400 secs] 31754K->2441K(518464K), [Perm : 10717K->10717K(16384K)], 0.0599570 secs] [Times: user=0.06 sys=0.00, real=0.06 secs]
该选项可通过 com.sun.management.HotSpotDiagnosticMXBean API 和 Jconsole 动态启用。 详见 http://java.sun.com/developer/technicalArticles/J2SE/monitoring/#Heap_Dump |
-XX:-PrintTenuringDistribution |
默认不启用 |
打印对象的存活期限信息。
打印格式例如: [GC 204009K->21850K(515200K), 0.1563482 secs]
Age1 2 表示在第1 和2 次GC 后存活的对象大小。 |
-XX:-TraceClassLoading |
默认不启用 |
打印class 装 载信息到stdout 。记Loaded 状 态。
例如: [Loaded java.lang.Object from /opt/taobao/install/jdk1.6.0_07/jre/lib/rt.jar] |
-XX:-TraceClassLoadingPreorder |
1.4.2 引入,默认不启用 |
按class 的引 用/ 依赖顺序打印类装载信息到stdout 。 不同于 TraceClassLoading ,本选项只记 Loading 状态。
例如: [Loading java.lang.Object from /home/confsrv/jdk1.6.0_14/jre/lib/rt.jar] |
-XX:-TraceClassResolution |
1.4.2 引入,默认不启用 |
打印所有静态类,常量的代码引用位置。用于debug 。
例如: RESOLVE java.util.HashMap java.util.HashMap$Entry HashMap.java:209
说明HashMap 类 的209 行引用了静态类 java.util.HashMap$Entry |
-XX:-TraceClassUnloading |
默认不启用 |
打印class 的 卸载信息到stdout 。记Unloaded 状 态。 |
-XX:- TraceLoaderConstraints |
Java6 引入,默认不启用 |
打印class 的 装载策略变化信息到stdout 。
例如: [Adding new constraint for name: java/lang/String, loader[0]: sun/misc/Launcher$ExtClassLoader, loader[1]: <bootloader> ] [Setting class object in existing constraint for name: [Ljava/lang/Object; and loader sun/misc/Launcher$ExtClassLoader ] [Updating constraint for name org/xml/sax/InputSource, loader <bootloader>, by setting class object ] [Extending constraint for name java/lang/Object by adding loader[15]: sun/reflect/DelegatingClassLoader ]
装载策略变化是实现classloader 隔 离/ 名称空间一致性的关键技术。 对此感兴趣的朋友,详见 http://kenwublog.com/docs/Dynamic+Class+Loading+in+the+Java+Virtual+Machine.pdf 中的 contraint rules 一章。 |
-XX:+ PerfSaveDataToFile |
默认启用 |
当java 进程因OOM 或crashed 被强制终止后,生成一个堆快照 文件(什么是堆内存快照? 见 -XX:HeapDumpPath 处的描述)。 |
作者敬告
完善的单元测试,功能回归测试,和性能基准测试可以减少因调整非稳态JVM 选项带来的风险。
参考资料
Java6 性能调优白皮书
http://java.sun.com/performance/reference/whitepapers/6_performance.html
Java6 GC 调优指南
http://java.sun.com/javase/technologies/hotspot/gc/gc_tuning_6.html
更 为全面的options列表
http://blogs.sun.com/watt/resource/jvm-options-list.html
PDF版请点击这里:
http://kenwublog.com/docs/java6-jvm-options-chinese-edition.pdf
评论
直接复制URL就可以啦
谢谢分享
相关推荐
java.lang.instrument 提供允许 Java 编程语言代理检测运行在 JVM 上的程序的服务。 java.lang.management 提供管理接口,用于监视和管理 Java 虚拟机以及 Java 虚拟机在其上运行的操作系统。 java.lang.ref 提供了...
java.lang.instrument 提供允许 Java 编程语言代理检测运行在 JVM 上的程序的服务。 java.lang.management 提供管理接口,用于监视和管理 Java 虚拟机以及 Java 虚拟机在其上运行的操作系统。 java.lang.ref 提供...
Java局域网通信——飞鸽传书源代码,大家都知道VB版、VC版还有Delphi版的飞鸽传书软件,但是Java版的确实不多,因此这个Java文件传输实例不可错过,Java网络编程技能的提升很有帮助。 Java聊天程序,包括服务端和...
java.lang.instrument 提供允许 Java 编程语言代理检测运行在 JVM 上的程序的服务。 java.lang.management 提供管理接口,用于监视和管理 Java 虚拟机以及 Java 虚拟机在其上运行的操作系统。 java.lang.ref 提供了...
Java局域网通信——飞鸽传书源代码,大家都知道VB版、VC版还有Delphi版的飞鸽传书软件,但是Java版的确实不多,因此这个Java文件传输实例不可错过,Java网络编程技能的提升很有帮助。 Java聊天程序,包括服务端和...
1.5.1 编辑Java源代码 12 1.5.2 编译Java程序 13 学生提问:当我们使用编译C程序时,不仅需要指定存放目标文件的位置,也需要指定目标文件的文件名,这里使用javac编译Java程序时怎么不需要指定目标文件的文件名呢...
java.lang.instrument 提供允许 Java 编程语言代理检测运行在 JVM 上的程序的服务。 java.lang.management 提供管理接口,用于监视和管理 Java 虚拟机以及 Java 虚拟机在其上运行的操作系统。 java.lang.ref 提供...
java程序双击运⾏_双击jar⽂件运⾏程序 Java应⽤程序jar⽂件可以由 JVM(Java虚拟机)直接执⾏,只要操作系统安装了JVM便可以运⾏作为Java应⽤程序的jar⽂件。可是,很多 朋友遇到⼀个难题,那就是下载了jar⽂件以后在...
java.lang.instrument 提供允许 Java 编程语言代理检测运行在 JVM 上的程序的服务。 java.lang.management 提供管理接口,用于监视和管理 Java 虚拟机以及 Java 虚拟机在其上运行的操作系统。 java.lang.ref 提供...
java.lang.instrument 提供允许 Java 编程语言代理检测运行在 JVM 上的程序的服务。 java.lang.management 提供管理接口,用于监视和管理 Java 虚拟机以及 Java 虚拟机在其上运行的操作系统。 java.lang.ref 提供...
jdk_api_1_6帮助开发 java.applet 提供创建 applet 所必需的类和 applet 用来与其 applet 上下文通信的类。 java.awt 包含用于创建用户界面和绘制图形图像的所有类。 java.awt.color 提供用于颜色空间的类。 ...
java.lang.instrument 提供允许 Java 编程语言代理检测运行在 JVM 上的程序的服务。 java.lang.management 提供管理接口,用于监视和管理 Java 虚拟机以及 Java 虚拟机在其上运行的操作系统。 java.lang.ref 提供了...
java.lang.instrument 提供允许 Java 编程语言代理检测运行在 JVM 上的程序的服务。 java.lang.management 提供管理接口,用于监视和管理 Java 虚拟机以及 Java 虚拟机在其上运行的操作系统。 java.lang.ref 提供了...
您可能还已经在Maven缓存中将其下载到〜/ .m2 / repository / org / springframework / springloaded / 1.2.4.RELEASE / springloaded-1.2.4.RELEASE.jar 将JVM参数-javaagent:/Users/foo/bar/springloaded.jar -...
静态编译后的易语言可执行程序(exe)和动态链接库(dll),运行时不再依赖任何支持库文件,文件尺寸更小(相对以前的独立编译),PE结构更合理(取消了“易格式体”),加载速度更快,而且有效解决了“病毒误报”和...
•用于显示一些常见组件(例如编辑框、列表和下拉列表)的小部件 Android 包括一个构建在 WebKit 基础上的可嵌入浏览器,iPhone 的 Mobile Safari 浏览器同样也是以 WebKit 为基础。 Android 提供多种连接选项,...