写一段栈溢出代码java 什么情况下栈溢出
java栈内存溢出怎么解决
第一对所有的代码包括页面中的java代码都进行一遍彻底的回顾检查,
专业成都网站建设公司,做排名好的好网站,排在同行前面,为您带来客户和效益!创新互联为您提供成都网站建设,五站合一网站设计制作,服务好的网站设计公司,网站制作、网站建设负责任的成都网站制作公司!
1.对那些静态(static)的对象要特别留神,特别是类型为Map,List,Set的,静态的变量会一直驻存在内存中,生命周期比较长,不会被垃圾器回收。
2.对于代码,要审查是否生成了大量的冗余的对象,还有一些逻辑业务处理的类,
算法是否过于复杂,调整算法,对于代码认真审查,再仔细重构一遍代码,能提高代码质量,提高程序运行稳定性。
3.Java中的内存溢出大都是因为栈中的变量太多了。其实内存有的是。建议不用的尽量设成null以便回收,多用局部变量,少用成员变量。
1),变量所包含的对象体积较大,占用内存较多。
2),变量所包含的对象生命周期较长。
3),变量所包含的对象数据稳定。
4),该类的对象实例有对该变量所包含的对象的共享需求。
4.在我的程序中对静态变量的优化后,使程序占用内存量至少提升了5k-10k。所以也不容忽视。
第二还有就是String类相关的东西:
1.字符串累加的时候一定要用StringBuffer的append方法,不要使用+操作符连接两个字符串。差别很大。而且在循环或某些重复执行的动作中不要去创建String对象,因为String对象是要用StringBuffer对象来处理的,一个String对象应该是产生了 3个对象(大概是这样:))。
2.字符串length()方法来取得字符串长度的时候不要把length放到循环中,可以在循环外面对其取值。(包括vector的size方法)。特别是循环次数多的时候,尽量把length放到循环外面。
int size = xmlVector.size();
for (int i = 2; i size; i++) {
。。。
}
3 写代码的时候处理内存溢出
try{
//do sth
....
}catch (outofmemoryerror e){//可以用一个共通函数来执行.
system.out.print (“no memory! ”);
system.gc();
//do sth again
....
}
4.对于频繁申请内存和释放内存的操作,还是自己控制一下比较好,但是System.gc()的方法不一定适用,最好使用finallize强制执行或者写自己的finallize方法。 Java 中并不保证每次调用该方法就一定能够启动垃圾收集,它只不过会向JVM发出这样一个申请,到底是否真正执行垃圾收集,一切都是个未知数。
Java如何在不使用递归的情况下导致栈溢出?
归 调用,在不断的压 栈 过程中,造成 栈 容量超过1m而 导致 溢出 .2,解决方案:方... 算法正确的情况下,使用过程中会出现堆 栈溢出 的话,可以通过修改PLUS函数,
java程序错误,错误提示是栈溢出.
private static void qsort(int[]a,int low,int high)
{
int pos=Qpass(a, low, high);
qsort(a,low,pos-1);
qsort(a,pos+1,high);
}
没有结束条件,肯定会一致无限地递归下去,直到栈溢出了。。
快速排序的终止条件是:low=high
即改为
private static void qsort(int[]a,int low,int high)
{
if( low high)
{
int pos=Qpass(a, low, high);
qsort(a,low,pos-1);
qsort(a,pos+1,high);
}
}
如何用java编写代码让java虚拟机崩溃
堆溢出 或者栈溢出
堆溢出: 你new一个Long类型长度的对象数组 直接就够了
栈溢出: 使用递归调用,创建对象(同理于死循环创建对象堆溢出 或者栈溢出
堆溢出: 你new一个Long类型长度的对象数组 直接就够了
栈溢出: 使用递归调用,创建对象(同理于死循环创建对象)
如何解决java中混合快速排序法栈溢出(stack overflow)
1. 应该是您的递归算法调用的层级太多导致的。优化下算法,让调用层级减低才行。
2. 这种情况自己维护个栈序列,用循环的方式来处理应该就可以了。
例如可以是:
1. (start,end)入栈
2. 栈是否为空,若为空则退出
3. 弹出栈定元素,如果start-endbreakpoint使用插入排序,完成后回到2。
否则对[start,end]序列进行划分,将小于和大于choosePivot(a,start,end);的区间入栈
(minstart,minend), (maxstart, maxend)
4. 重复2,3,直到栈为空
小弟正在学习java,现在遇到一个问题,快速排序的栈溢出的问题,希望大家能够帮一下,谢谢。
我帮你调了半天还是没有看出来具体是哪点出错了。
不过你大概的算法我看出来了,是从左右两边同时与关键数进行对比,而且对比成功后还是进行的交换,而不是更换位置(这个很有可能是出错的原因)。我觉得 可能是在两边 交换的过程造成了无限循环。
其实对比的时候只从一个方向同关键数对比就行了,而且若某个数字满足移动的条件,应当把它取出放到队首或队尾,而不是进行交换。比如从第一个数开始查看,每个数字做以下判断:
1、若它是最后一个数字,则结束一轮对比;
2、若它等于关键数字,则跳过它;
3、若它比关键数字小,且在其左边,则直接跳过;
4、若它比关键数字小,且在右边,则将它从队列中取出,并放到队首;(注意,是取出放到队首,而不是与某个元素交换,你的算法可能问题就出在这个上边)
5、若它比关键数字大,且在左边,则将它从队列中取出,并放到队尾;
6、若它比关键数字大,且在右边,则直接跳过。
你可以先修改 交换的那部分,换成取出并放到队首或队尾试试,应该就没问题了。
网站题目:写一段栈溢出代码java 什么情况下栈溢出
转载源于:http://ybzwz.com/article/hjopjo.html