首先创建.java文件
进入某个目录,
然后创建一个.java文件:vim HelloWorld.java
在里面输入代码:
public class HelloWorld{
public static void main(String args[]){
System.out.println("Hello World in Ubuntu!")
}
}
保存并退出vim::x,回车。
编译HelloWorld.java:javac HelloWorld.java 得到HelloWorld.class文件
运行HelloWorld:sudo java HelloWorld
结果输出:Hello World in Ubuntu!
一般来说内存泄漏有两种情况。一种情况,在堆中的分配的内存,在没有将其释放掉的时候,就将所有能访问这块内存的方式都删掉(如指针重新赋值);另一种情况则是在内存对象明明已经不需要的时候,还仍然保留着这块内存和它的访问方式(引用)。第一种情况,在Java中已经由于垃圾回收机制的引入,得到了很好的解决。所以,Java中的内存泄漏,主要指的是第二种情况。可能光说概念太抽象了,大家可以看一下这样的例子:
1 Vector v=new Vector(10)
2 for (int i=1i<100i++){
3 Object o=new Object()
4 v.add(o)
5 o=null
6 }
在这个例子中,代码栈中存在Vector对象的引用v和Object对象的引用o。在For循环中,我们不断的生成新的对象,然后将其添加到Vector对象中,之后将o引用置空。问题是当o引用被置空后,如果发生GC,我们创建的Object对象是否能够被GC回收呢?答案是否定的。因为,GC在跟踪代码栈中的引用时,会发现v引用,而继续往下跟踪,就会发现v引用指向的内存空间中又存在指向Object对象的引用。也就是说尽管o引用已经被置空,但是Object对象仍然存在其他的引用,是可以被访问到的,所以GC无法将其释放掉。如果在此循环之后,Object对象对程序已经没有任何作用,那么我们就认为此Java程序发生了内存泄漏。
尽管对于C/C++中的内存泄露情况来说,Java内存泄露导致的破坏性小,除了少数情况会出现程序崩溃的情况外,大多数情况下程序仍然能正常运行。但是,在移动设备对于内存和CPU都有较严格的限制的情况下,Java的内存溢出会导致程序效率低下、占用大量不需要的内存等问题。这将导致整个机器性能变差,严重的也会引起抛出OutOfMemoryError,导致程序崩溃。
你好,很高兴为你引路:别人写的java代码要看可读性,包括类的命名,关键代码的注释以及方法的注释,如果这些都具备了,就很容易看懂,否则比较费劲。
一般来说就要是从主入口开始看,跟踪步骤来查看
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)