报错:exception: java.lang.reflect.InvocationTargetException: null
JAVA 报错 null lang Exception reflect
2023-09-11 14:14:33 时间
报错背景
Java代码偶然报错,但是正常情况下运行不会报错。
报错现象
exception: java.lang.reflect.InvocationTargetException: null
2020-05-11 at 15:17:39 CST traceId:[] ERROR io.netty.util.internal.logging.AbstractInternalLogger 91 error - Unexpected exception: java.lang.reflect.InvocationTargetException: null at sun.reflect.GeneratedMethodAccessor214.invoke(Unknown Source) ~[?:?] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:1.8.0_192] at java.lang.reflect.Method.invoke(Method.java:498) ~[?:1.8.0_192] at org.yeauty.pojo.PojoEndpointServer.doOnClose(PojoEndpointServer.java:121) [netty-websocket-spring-boot-starter-0.8.0.jar!/:?] at org.yeauty.standard.WebSocketServerHandler.channelInactive(WebSocketServerHandler.java:29) [netty-websocket-spring-boot-starter-0.8.0.jar!/:?] at io.netty.channel.AbstractChannelHandlerContext.invokeChannelInactive(AbstractChannelHandlerContext.java:257) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.channel.AbstractChannelHandlerContext.invokeChannelInactive(AbstractChannelHandlerContext.java:243) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.channel.AbstractChannelHandlerContext.fireChannelInactive(AbstractChannelHandlerContext.java:236) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.handler.codec.ByteToMessageDecoder.channelInputClosed(ByteToMessageDecoder.java:393) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.handler.codec.ByteToMessageDecoder.channelInactive(ByteToMessageDecoder.java:358) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.channel.AbstractChannelHandlerContext.invokeChannelInactive(AbstractChannelHandlerContext.java:257) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.channel.AbstractChannelHandlerContext.invokeChannelInactive(AbstractChannelHandlerContext.java:243) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.channel.AbstractChannelHandlerContext.fireChannelInactive(AbstractChannelHandlerContext.java:236) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.channel.DefaultChannelPipeline$HeadContext.channelInactive(DefaultChannelPipeline.java:1416) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.channel.AbstractChannelHandlerContext.invokeChannelInactive(AbstractChannelHandlerContext.java:257) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.channel.AbstractChannelHandlerContext.invokeChannelInactive(AbstractChannelHandlerContext.java:243) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.channel.DefaultChannelPipeline.fireChannelInactive(DefaultChannelPipeline.java:912) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.channel.AbstractChannel$AbstractUnsafe$8.run(AbstractChannel.java:816) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.util.concurrent.AbstractEventExecutor.safeExecute(AbstractEventExecutor.java:163) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.util.concurrent.SingleThreadEventExecutor.runAllTasks(SingleThreadEventExecutor.java:416) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:515) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.util.concurrent.SingleThreadEventExecutor$5.run(SingleThreadEventExecutor.java:918) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30) [netty-all-4.1.38.Final.jar!/:4.1.38.Final] at java.lang.Thread.run(Thread.java:748) [?:1.8.0_192] Caused by: java.util.ConcurrentModificationException at java.util.HashMap$HashIterator.nextNode(HashMap.java:1445) ~[?:1.8.0_192] at java.util.HashMap$EntryIterator.next(HashMap.java:1479) ~[?:1.8.0_192] at java.util.HashMap$EntryIterator.next(HashMap.java:1477) ~[?:1.8.0_192] at com.jcdz.hbdservice.websocket.ServerWebSocket1.onClose(ServerWebSocket1.java:38) ~[coalminehbdservice-1.0.jar!/:1.0] ... 25 more
报错原因
报错原因有很多,我只说我接触到的这个原因:
(1)if(==) 判断语句出错
if(devMap.getOrDefault("locationcode","") == null)
devMap.get("locationcode"):有可能传过来是一个null,此时就会出现空指针的现象
查看 getOrDefault() 源码
1 /** 2 * Returns the value to which the specified key is mapped, or 3 * {@code defaultValue} if this map contains no mapping for the key. 4 * 5 * @implSpec 6 * The default implementation makes no guarantees about synchronization 7 * or atomicity properties of this method. Any implementation providing 8 * atomicity guarantees must override this method and document its 9 * concurrency properties. 10 * 11 * @param key the key whose associated value is to be returned 12 * @param defaultValue the default mapping of the key 13 * @return the value to which the specified key is mapped, or 14 * {@code defaultValue} if this map contains no mapping for the key 15 * @throws ClassCastException if the key is of an inappropriate type for 16 * this map 17 * (<a href="{@docRoot}/java/util/Collection.html#optional-restrictions">optional</a>) 18 * @throws NullPointerException if the specified key is null and this map 19 * does not permit null keys 20 * (<a href="{@docRoot}/java/util/Collection.html#optional-restrictions">optional</a>) 21 * @since 1.8 22 */ 23 default V getOrDefault(Object key, V defaultValue) { 24 V v; 25 return (((v = get(key)) != null) || containsKey(key)) 26 ? v 27 : defaultValue; 28 }
@throws NullPointerException如果指定的键为null并且此映射不允许使用空键
我们可以看到 getOrDefault() 方法里面有 get(key) 方法,此时如果key的值是一个null就会报错,例如 key:null。
map 传入值的时候要避免传入map.put(key:null)现象的发生,可以以map.put(key:"")来代替。
(2)if(equals) 判断语句出错
if(!time.equals("1900-01-01 00:00:00"))
time:有可能传过来是一个null,此时就会出现空指针的现象
报错解决
修改判断语句的前后顺序,如下:
if(null == devMap.getOrDefault("locationcode",""))
if(!"1900-01-01 00:00:00".equals(time))
相关文章
- 报错:Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object
- Java 遍历文件夹里面的全部文件、指定文件
- Java第二次作业參考代码
- 阿里 P8 熬了一个月肝出这份 32W 字 Java 面试手册,在 Github 标星 31K+
- 34 异常机制 异常体系结构 Java把异常当做对象来处理 并定义一个基类java.lang.Throwable作为所有异常的超类 Error Exception
- 深入理解Java虚拟机——Java对象是否存活
- 《Java线程与并发编程实践》—— 2.3 谨防活跃性问题
- 《Java遗传算法编程》—— 1.9 基因表示
- 《Java 开发从入门到精通》—— 2.3 使用IDE工具序
- 《Java入门经典(第7版)》—— 6.11 练习
- Hive启动报错 java.lang.RuntimeException: org.apache.hadoop.hive.ql.metadata.HiveException: java.lang
- Java过滤器处理Ajax请求,Java拦截器处理Ajax请求,java 判断请求是不是ajax请求
- Java线程锁,synchronized、wait、notify详解--java 管程
- java为什么要用类型擦除实现泛型?--c++,java,c# 的泛型是如何实现的
- JAVA编程(一)基础环境
- Ubuntu系统中CUDA套件nvvp启动后报错Unable to make protected void java.net.URLClassLoader.addURL(java.net.URL) accessible: module java.base does not "opens java.net" to unnamed module @380fb434
- Java打印输出:java在线8x8x
- (JAVA):字符串的比较操作-----String类常见的API。
- 连通块(dfs)java实现
- 浅析部署遇到的2个报错:Caused by: java.net.SocketTimeoutException: connect timed out的原因及解决、no suitable node (host-mode port already in use on 1 node)原因及解决
- Java编程常用数据转换:String与int互转、Date与String互转、BigDecimal与int比较(报错operator > cannot be applied to java.math.BigDecimal,int)
- 『Java练习生的自我修养』java-se进阶² • 并发与多线程
- [转]Java虚拟机是如何判断变量类型的
- java中路径中参数值是中文,打印到页面是乱码的解决方案
- 解决Java使用response下载文件报错,并总结可能出错的原因: java.io.IOException: 你的主机中的软件中止了一个已建立的连接。
- mytbatis mapper.xml报错:java.lang.UnsupportedOperationException] with root cause