java队列溢出解决代码 java队列满了抛弃
java 算出溢出处理
帅哥。。。
目前创新互联建站已为成百上千家的企业提供了网站建设、域名、网站空间、成都网站托管、企业网站设计、宁阳网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。
System.out.println("int的最小值="+Integer.MIN_VALUE);
System.out.println("int的最大值="+Integer.MAX_VALUE);
查看下java中int表示的最大值和最小值,我看跟你写的不一样。。。
有不懂的再问,你现在b存的数没有溢出。。。。
java写一个简单队列,有进队和出队操作,帮我检查一下程序
数据的情况:
[0] [1] [2] [3] [4]
加入一个:
[0] [1] [2] [3] [4] [5]
取出一个后
[0] [1] [2] [3] [4] [5]
可以看出来,每次取出第一个,第一个元素还是没变,一直是0
要让其数据变成 [1] [2] [3] [4] [5] 那么就要自己手动变动数据(就是手动往前移动)
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内存溢出,求解决
你想想你的代码List最大长度多少:
for(int i = 0 ; i10000000 ; i++){
list.add(i) ;
if(i==100000){
list.clear();
System.gc() ;
}
你到100000时清空,那List最大长度是10000000 - 100000 = 9900000,如果你的意思是每100000次清空一下,应该写成:
if(i % 100000 == 0)
List中存Integer,一个Integer在Sun的虚拟机上是16字节,9900000就占用约160MB,超过了Sun虚拟机默认堆内存64MB,可以在启动时加参数改成1024MB内存
java -Xmx1024m YourClass
}
文章标题:java队列溢出解决代码 java队列满了抛弃
标题链接:http://scyanting.com/article/dogcgoo.html