java,让debug出色
虽然我们不喜欢bug,但是bug永远都存在。
虽然我们牛逼,但是仍然有不知道的东西,解决不了的问题。
so,还得借助工具,让咱效率提起来扛扛的。
解决的问题如是:由于某种原因,其他系统发送的mq,我这边说没收到,他那边说发了。然后,一愁不展,咋办呢?好吧,肯定是抓包确认问题咯。嘿,这不是本文的重点,请自行脑补抓包。

从对方系统的mq记录里,取出消息体,放到mq后台,直接发送到消费服务器。模拟发送情况,然后就遇到报错了,苦思不得结果后,只能使用终级绝招,就用本机来代替debug吧。
本地服务起来之后,同样,mq后台发送消息。不出意外地,和测试服务器上报了不一样的错。这就尴尬了。和测试环境不一样,咋整呢?
不怕,咱一步步来。按照堆栈指示的代码行,很快定位了有问题的代码。原因为某个jar包中的值报了空指针异常。咋整呢,咱们的本机环境不像测试环境呢。
解决办法1:将本机模拟成测试环境一样的情况,太难,至少linux和windows环境就是不一样的。
方法2:想办法让这个变量的变得和测试环境一样。也许可行。
方法3:想办法跳过报错的代码,使其继续后面的程序,存在2个问题,1是程序做不到跳过不执行功能,2是跳过执行后后续可能使用这里的值,会导致其他错误。故此,只有改变变量值一法了。
案例1:改变一个基本类型变量的值
直接setvalue即可。
public static void main(String[] args) {
String var1 = "var1";
int i = 1;
System.out.println("var1:" + var1); // 输出 var1:changed
}


案例2:改变一个hashmap变量的值
hashmap是个复杂类型,不能直接设置值。需要使用 add to watches功能。
public static void main(String[] args) {
Map<String, Object> map = new HashMap<>();
int i = 2;
System.out.println("map:" + map); // 输出 map:{name:hello}
}



案例3:改变一个实体对象值
可以使用set value 方式直接改变值,也可以使用add to watches操作代码来设置 。 总之你想要都能给你变出来。
public static void main(String[] args) {
UserInfo info = new UserInfo();
int i = 3;
System.out.println("info:" + info); //输出info:UserInfo{id='123', name='null', sex='null', age=null, address='golden street'}
}


报的错是找不到某个处理方法,但是实际上我自认为已经写了某个方法。那么到底怎么回事呢。
第一次跟踪,到某一行后,退出了程序。debug往下调整。进入方法再进行单步调试。再次发现某一次代码退出。最后定位到反射调用的这一行。原因是之时的入参类型,与现有入参类型不一致。再往前分析,是因为在调用转换器的时候,并没有进行相应的转换,而是以原来的二进制格式返回了。分析程序,知道里面某参数需要包含某值,转换器才会起作用。对症下药,给他这个参数,果然进入到了转换流程。然而,进入后又转换成另一个不可预料的参数了,没办法,getmapper方法不好模拟出来,还是算了,直接模拟转换结果吧,add to watch,改变值。这下,终于进入方法了,代码不再报错。测试通过了。
弄清原理之后,解决就简单了!如果对方没有设置某属性值,让其设置就ok了。如果一定要以某结构参数进行接收处理,那变写一个对应的处理方法即可。小case。
debug,单步调试,进入,退出,计算变量值,推测执行是debug基础,必备。
debug, 让问题变得简单!
java,让debug出色的更多相关文章
- 【Java远程debug】
转自 http://blog.csdn.net/hongchangfirst/article/details/44191925 一.远程debug原理 Java远程调试的原理是两个JVM之间通过deb ...
- java的debug和release编译方式
以前没有注意过,其实Java编译成.class 有两种方式 使用javac,默认使用的release方式,而我们经常使用的MyEclipse工具,用的是debug模式. 区别暂时了解如下: relea ...
- java remote debug
1. java -Xdebug -Xrunjdwp:transport=dt_socket,server=y,address=8000 -jar test.jar 2.会出现Listening for ...
- Java在Debug的时候,有些变量能无限展开(循环了)?
抛异常的时候,Java Debug 时,有些变量能无限展开,怎么做到的? 先来一个报错的例子: Exception in thread "main" java.lang.Stack ...
- java 远程debug
在启动jar包添加如下参数16091是端口 java -Xdebug -Xrunjdwp:transport=dt_socket,address=16091,server=y,suspend=n -j ...
- 【Java】Debug断点调试常用技巧
Debug操作技巧 Show Execution Point 将光标回到当前断点停顿的地方 Step Over 执行当前行代码,并将运行进度跳转到下一行. Step Into 进入到当前代码行的方法内 ...
- Java的Debug调试
一.在项目上右键,Debug As>Debug on Server 二.在测试类上,Run As>Run On Server
- java remote debug parameters
java -agentlib:jdwp=transport=dt_socket,server=y,address=8000,suspend=n
- java Eclipse debug技巧
摘要:调试不仅可以查找到应用程序缺陷所在,还可以解决缺陷.对于Java程序员来说,他们不仅要学会如何在Eclipse里面开发像样的程序,更需要学会如何调试程序.本文介绍了Java程序员必知的10个调试 ...
随机推荐
- Numpy用户指南
Numpy是Python语言的一个扩展库,支持大量的维度数组和矩阵运算,此外也针对数组运算提供大量的数学函数库. Mumpy是一个运行速度非常快的数学库,主要用于数组计算,包涵: 1.一个强大的N维数 ...
- Java 调用执行其他语言的程序
以 Java 调用 Python 为例 1. 使用 Runtime 类 该方式简单,但是增加了 Java 对python 的依赖,需要事先安装python,及python程序依赖的第三方库 Runti ...
- GUI学习之四——QWidget控件学习总结
上一章将的QObject是PyQt里所有控件的基类,并不属于可视化的控件.这一章所讲的QWidget,是所有可视化控件的基类. QWidget包含下面几点特性 a.控件是用户界面的最小的元素 b.每个 ...
- vue项目部署到服务器
1.配置config目录下index.js index: path.resolve(__dirname, '../dist/index.html'), assetsRoot: path.resolve ...
- WebAPI常见的鉴权方法,及其适用范围
在谈这个问题之前,我们先来说说在WebAPI中保障接口请求合法性的常见办法: API Key + API Secret cookie-session认证 OAuth JWT 当然还有很多其它的,比如 ...
- 第二阶段第六次spring会议
昨天我将对初始页面进行加工和修改. 我用两个小动物作为按钮分别进入动物便签界面和植物便签界面,可以让用户自由选择. 今天我将尝试对软件进行添加搜索引擎的界面. private void linkLab ...
- 【转】async & await 的前世今生(Updated)
async 和 await 出现在C# 5.0之后,给并行编程带来了不少的方便,特别是当在MVC中的Action也变成async之后,有点开始什么都是async的味道了.但是这也给我们编程埋下了一些隐 ...
- 83、源代码管理工具(Git)
一.简介 git是一款开源的分布式版本控制工具 在世界上所有的分布式版本控制工具中,git是最快.最简单.最流行的 git起源 作者是Linux之父:Linus Benedict Torvalds 当 ...
- JDBC学习(含转载)
首先连接数据库: Class.forName("com.mysql.jdbc.Driver");//加载jdbc驱动 Connection conn=DriverManager.g ...
- Redis与SpringBoot整合
添加Redis相关jar包 <dependency> <groupId>org.springframework.boot</groupId> <artifac ...