别说你懂我 你只是在意Java你把我留在家里身和心却始终在她那里难道我只是她的附属品?错,我是我,我是JVM,没有我就没有他! 如果你想懂我或者不管你是否懂我我都在这里等你---[深入JVM内核—原理.诊断与优化]在线培训课第2期.---错过这期,再等半年课程费用是100起,葛一鸣老师博客:www.uucode.net.---报名猛戳:http://www.dataguru.cn/article-5021-1.html---主要包括JVM运行机制.启动流程.内存模型.JVM参数.GC算法.类装载…
请点赞关注,你的支持对我意义重大. Hi,我是小彭.本文已收录到 GitHub · AndroidFamily 中.这里有 Android 进阶成长知识体系,有志同道合的朋友,关注公众号 [彭旭锐] 带你建立核心竞争力. 前言 Java 中一切皆对象,同时对象也是 Java 编程中接触最多的概念,深入理解 Java 对象能够更帮助我们深入地掌握 Java 技术栈.在这篇文章里,我们将从内存的视角,带你深入理解 Java 对象在虚拟机中的表现形式. 学习路线图: 1. 对象在哪里分配? 在 Jav…
在上面一节我们分析了JobTracker调用JobQueueTaskScheduler进行任务分配,JobQueueTaskScheduler又调用JobInProgress按照一定顺序查找任务的流程,获得了任务之后,将任务封装为TaskTrackerAction数组返回的整个过程.TaskTracker通过心跳响应接收到了这个数组.本节我们继续分析,TaskTracker拿到了这个数组之后,如何对任务进行处理的. 1,TaskTracker在其方法offerService中,将得到的任务加入队…
1. 什么是Java反射,有什么用?反射使程序代码能够接入装载到JVM中的类的内部信息,允许在编写与执行时,而不是源代码中选定的类协作的代码,是以开发效率换运行效率的一种手段.这使反射成为构建灵活应用的主要工具.反射可以:调用一些私有方法,实现黑科技.比如双卡短信发送.设置状态栏颜色.自动挂电话等.实现序列化与反序列化,比如PO的ORM,Json解析等.实现跨平台兼容,比如JDK中的SocketImpl的实现通过xml或注解,实现依赖注入(DI),注解处理,动态代理,单元测试等功能.比如Retr…
我们在我们Server的gc log上经常看到下面的这个日志: 总结一下各个字段表达的是什么意思:  Young GC Full GC: top -H -P $PID  动态查看java线程的消耗情况 top -H -b -n 1 -p $PID 打印一次java线程情况 jstack $PID 打印当前运行的java线程栈信息(建议打印2,3次) jstat -gcutil $PID <毫秒数>  动态的观察jvm内存各区情况,主要看下FGC与YGC的使用情况! jmap -dump:for…
弄JAVA,那JVM,JAVA语法,JDK库,JAVAEE,流行框架是一个都不能少,才可以有全局感的. JVM高级特性这书,看得差不多了.慢慢实践. /** * * *VM Args: -Xms20m -Xmx20m -XX:+HeapDumpOnOutOfMemoryError *@author hengheng */ public class HeapOOM { private int stackLength = 1; public void stackLeak() { stackLengt…
JVM类加载过程学习总结 先不说JVM类加载的原理,先看实例: NormalTest类,包含了一个静态代码块,执行的任务就是打印一句话. /** * 在正常类加载条件下,看静态代码块是否会执行 * @author jianying.wcj * @date 2013-6-21 */ public class NormalTest { static { System.out.println("hello world!"); } } TestStatic类, 有三行代码,其中两行被注释,测试…
转自:http://blog.163.com/itjin45@126/blog/static/10510751320144201519454/ 官方手册:http://docs.oracle.com/javase/7/docs/     ---->http://docs.oracle.com/javase/7/docs/technotes/tools/solaris/java.html   java命令的各种选项的说明 参考书籍: <深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)&…
这里向大家描述一下如何使用Tomcat配置JVM参数,Tomcat本身不能直接在计算机上运行,需要依赖于硬件基础之上的操作系统和一个java虚拟机.您可以选择自己的需要选择不同的操作系统和对应的JDK的版本,但还是推荐您使用Sun公司发布的JDK. jvm在client模式,进行内存回收时,会停下所有的其它工作,带回收完毕才去执行其它任务,在这期间eclipse就卡住了.所以适当的增加jvm申请的内存大小来减少其回收的次数甚至不回收,就会是卡的现象有明显改善. 主要通过以下的几个jvm参数来设置…
前面几章跟着作者的脚步实现了使用Go语言查看java的.class文件源码(16进制) 复习一下: 相比Java语言,Go的访问控制非常简单,只有公开和私有两种. 所有首字母大写的类型, 结构体,字段,变量,函数,方法等都是公开的. 可供其它包使用. 首字母小写则是私有的. 只能在包内部使用. 接下来使用大神作者的classpy查看某个class文件,当然也能打开.jar  这是被称呼为魔数的代码. 很多文件格式都会规定满足该格式的文件必须以某几个固定字节开头,这几个字节主要起到标识作用, 叫做…