您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 信息化管理 > findbugs常见错误
(一)[DLS_DEAD_LOCAL_STORE]描述:Deadstoreto未使用的局部变量解决方法:局部变量定义后未使用;实例化对象后又重新对该对象赋值(二)[ST_WRITE_TO_STATIC_FROM_INSTANCE_METHOD]描述:Writetostaticfield通过实例方法更新静态属性常见于常量类,直接通过类名.常量名获取的方式违背了封装的原则,findbugs不提倡使用,而如果将常量改成静态成员变量,又因为spring不支持静态注入导致不能实现,解决方法是非静态的setter调用静态的setter方法给静态成员变量赋值。解决方法:常量类F:classF{publicstaticStringa=“123”;}常量a改为静态成员变量,通过F.getA()获取,且由于spring不支持静态注入,改为:classF{privatestaticStringa;publicstaticIntegergetA(){returna;}publicvoidsetA(Stringa){setAValue(a);}publicstaticvoidsetAValue(Stringa){F.a=a;}}(三)[BX_UNBOXING_IMMEDIATELY_REBOXED]描述:Boxedvalueisunboxedandthenimmediatelyreboxed装箱的值被拆箱,然后立刻重新装箱了常见的是三目运算时,同时存在基本类型和包装类型。解决方法:Integera=null;//...a=(a==null)?0:a;此问题在于a不为null时,会被拆箱,赋值时再装箱。这是自动装箱拆箱的特性,只要运算中有不同类型,当涉及到类型转换时,编译器就会向下转型,再进行运算。修改方法,统一类型:Integera=null;//...a=(a==null)?Integer.valueOf(0):a;(四)[SE_BAD_FIELD]描述:Non-transientnon-serializableinstancefieldinserializableclass在可序列化的类中存在不能序列化或者不能暂存的数据解决方法:方法1:序列化该对象方法2:当采用struts2框架开发,不可避免的此问题会大量出现,因为ActionSupport实现了序列化接口,action继承了此类,而service没序列化,所以在action中引用service对象时提示此错误,最简单的解决方法是将service对象声明成transient,即service不需要序列化方法3(未验证):ToavoidjavaserializationyouneedtoimplementwriteObject()andreadObject()methodinyourClassandneedtothrowNotSerializableExceptionfromthosemethod.(action中实现这两个方法?)privatevoidwriteObject(java.io.ObjectOutputStreamstream)throwsjava.io.IOException{thrownewjava.io.NotSerializableException(getClass().getName());}privatevoidreadObject(java.io.ObjectInputStreamstream)throwsjava.io.IOException,ClassNotFoundException{thrownewjava.io.NotSerializableException(getClass().getName());}(五)[NP_LOAD_OF_KNOWN_NULL_VALUE]描述:Loadofknownnullvalue加载已知是null的值解决方法:已知方法参数为null是,直接传递null而不是参数名(六)[REC_CATCH_EXCEPTION]描述:ExceptioniscaughtwhenExceptionisnotthrown过泛地捕获异常或捕获异常后未做任何处理解决方法:异常分类捕获(至少要打印出此异常对象)(七)[NP_NULL_PARAM_DEREF]描述:Nullpassedfornonnullparameter把空值传给了非空的参数解决方法:增加非空判断(八)[NP_IMMEDIATE_DEREFERENCE_OF_READLINE]描述:ImmediatedereferenceoftheresultofreadLine()立即引用了readLine()的结果解决方法:判断readLine的结果是否为空(九)[EI_EXPOSE_REP]恶意代码漏洞描述:mayexposeinternalrepresentationbyreturninggetter方法返回引用类型eclipse自动生成的引用类型(Object、数组、Date等)的getter、setter方法会得到或通过对可变对象的引用操作而暴露代码内部实现,解决方法很多,只要返回的或赋值的对象不是原引用对象即可。解决方法:以Date类型为例:publicDategetHappenTime(){if(happenTime!=null){return(Date)happenTime.clone();}returnnull;}(十)[EI_EXPOSE_REP2]恶意代码漏洞描述:mayexposeinternalrepresentationbystoringanexternallymutableobjectintosetter方法返回引用类型eclipse自动生成的引用类型(Object、数组、Date等)的getter、setter方法会得到或通过对可变对象的引用操作而暴露代码内部实现,解决方法很多,只要返回的或赋值的对象不是原引用对象即可。解决方法:以Date类型为例:publicvoidsetHappenTime(DatehappenTime){if(happenTime!=null){this.happenTime=(Date)happenTime.clone();}else{this.happenTime=null;}}(十一)[WMI_WRONG_MAP_ITERATOR]描述:keySet迭代是低效的,使用entrySet代替解决方法:1.for(Map.EntryString,JMenuentry:menuList.entrySet()){2.mb.add(entry.getValue());3.}
本文标题:findbugs常见错误
链接地址:https://www.777doc.com/doc-2871793 .html