1、我的项目遇到的问题
讲讲在Java我的项目下的debug,起因是在我的项目中遇到一个问题,在接口写完之后,以及controller层代码都曾经写完,应用postman调试门路,获取返回数据,发现咋缺失了一个字段。
思考了一下,看着没问题啊,咋会产生这个问题呢,思考了很久,还是叫来了共事,共事应用他的debug,三下两下解决了问题,还是我看代码不认真啊。
问题复现:
而返回的类数据为:
代码逻辑是,从数据库查问进去数据,而后返回QiScoreCriteriaDTO类型数据,发在QiScoreCriteriaDTO类中,levelName和sql中的level_name是无奈对应起来的,导致查问的数据为null。
解决办法:
或者应用resultMap,建设映射,返回接口数据:
外面的property是对应到相应的sql字段中,当前在理论mybatis的xml文件中,能够间接应用resultMap,做映射文件。
这是其中一个问题,这次次要的一次意识,我还是得学下Java我的项目中的debug,这块是挺重要的,之前我始终是这样解决问题的:
System.out.print("---->" + 具体的变量);
这样解决问题也能够,不过有时定位问题还是有些难度,还是须要学会debug。
2、IDEA应用debug
bug起源于一位叫葛丽丝霍波的工程师,有一天在调试设施的时候呈现故障,拆开电器后,发现有只飞蛾被压扁在触点两头,卡住了机器的运行,因而他就把这个程序故障,成为bug(臭虫),把排除程序故障叫DEBUG。
比拟原始的是应用:
System.out.print("---->" + 具体的变量);
- 应用IDEA中自带的debug
启动我的项目后,不应用run,而是用debug模式启动我的项目,有须要的时候,在其中加断点。
在debug模式启动,如果无奈运行,但run模式能够运行,此使须要查找下,是不是因为有方块断点的起因导致的无奈debug,这是我在工作中遇到的。
这是以debug调试模式启动的我的项目
不加断点会像run模式一样执行,如果加了断点,就会如下运行:
能够看到具体的执行断点,打断点的具体程序信息。
如果想要看到变量的具体值,能够应用Evaluate Expression(Ctrl+F8)查看到具体值。
在我的项目中多应用几次debug就相熟了。
3、IDEA中debug快捷键
附上一份debug快捷键表:
Win 快捷键 | 介绍 |
---|---|
F7 | 进入下一步,如果以后断点是一个办法,则进入办法体内,如果该办法体还有办法,则不会进入该内嵌的办法中(必备) |
F8 | 进入下一步,如果以后那行断点是一个办法,则不进入以后办法体内(必备) |
F9 | 复原程序运行,如果上面还有一个断点,则停在下一个断点(必备) |
ALT+F8 | 选中对象,弹出可输出计算表达式调试框,查看该输出内容的调试后果(必备) |
CTRL+F8 | 设置光标以后行为断点,如果是断点则去掉断点 |
SHIFT+F7 | 智能步入,断点所在行有多个办法调用,会弹出进入哪个办法 |
SHIFT+F8 | 跳出,成果和F9一样 |
CTRL+SHIFT+F8 | 指定断点进入条件 |
ALT+SHIFT+F7 | 进入下一步,如果以后行断点是一个办法,则进入以后办法体内,如果办法体还有办法,则会进入该内嵌的办法中,依此循环进入 |
ALT+SHIFT+F8 | 返回上一步 |
关注我的公众号: 我只是个码字的,一起学习计算机编程常识。