java代码安全排查 java代码安全扫描工具( 二 )


java内存溢出的问题如何排查java程序大家都知道,内存溢出是经常见的错误,下面从基本的开始分析!
内存溢出是由于没被引用的对象(垃圾)过多造成JVM没有及时回收,造成的内存溢出 。如果出现这种现象可行代码排查:
一)是否App中的类中和引用变量过多使用了Static修饰 如public staitc Student s;在类中的属性中使用 static修饰的最好只用基本类型或字符串 。如public static int i = 0; //public static String str;
二)是否App中使用了大量的递归或无限递归(递归中用到了大量的建新的对象)
三)是否App中使用了大量循环或死循环(循环中用到了大量的新建的对象)
四)检查App中是否使用了向数据库查询所有记录的方法 。即一次性全部查询的方法,如果数据量超过10万多条了,就可能会造成内存溢出 。所以在查询时应采用“分页查询” 。
五)检查是否有数组,List,Map中存放的是对象的引用而不是对象,因为这些引用会让对应的对象不能被释放 。会大量存储在内存中 。
六)检查是否使用了“非字面量字符串进行+”的操作 。因为String类的内容是不可变的,每次运行"+"就会产生新的对象,如果过多会造成新String对象过多,从而导致JVM没有及时回收而出现内存溢出 。
如String s1 = "My name";
String s2 = "is";
String s3 = "xuwei";
String str = s1 + s2 + s3 +.........;这是会容易造成内存溢出的
但是String str ="My name" + " is " + " xuwei" + " nice " + " to " + " meet you"; //但是这种就不会造成内存溢出 。因为这是”字面量字符串“,在运行"+"时就会在编译期间运行好 。不会按照JVM来执行的 。
在使用String,StringBuffer,StringBuilder时,如果是字面量字符串进行"+"时,应选用String性能更好;如果是String类进行"+"时,在不考虑线程安全时,应选用StringBuilder性能更好 。
知道原因了,解决起来就非常简单了 。
java 错误排查倒数第四行java代码安全排查,编译错误java代码安全排查 , java代码安全排查你的对象在try中定义 , 但是在try外关闭
另外,关于提问题的建议,最好说明java代码安全排查了问题在哪儿,不要尝试让别人猜测你的问题
关于java代码安全排查和java代码安全扫描工具的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。

推荐阅读