这两天工作中遇到一个调试问题,就是在当我的客户端连接一个错误的ip地址的服务器的时候,会出现单步调试的结果和直接快速运行的程序结果输出不一样的情况,当单步调试的时候可以按照希望的逻辑走到应该报错的地方,但是当程序直接运行,没有下断点的时候,就会走显示网络没有问题的逻辑。经过一段时间的分析探讨,我发现问题的原因在于,我们的网络是异步的,当连接命令交给底层的网络模块后,网络内部的逻辑会去执行它自己的逻辑,我不能等待它的返回结果。当我传入的ip地址是正确的时候,很快速地就可以得到网络的状态为可以读入、写入,并成功连接,但当我的ip地址是错误的话,底层的网络模块就会自动开启一系列的重连机制,导致消耗大量的无意义时间,在这个过程中,我的逻辑并没有进行特殊的处理,因此按照之前的逻辑返回了成功,只有当等待相当长的一段时间后,才能够成功取得连接错误的结果,返回失败。因此,在直接运行程序的时候,由于程序运行速度很快,这段时间太短没有办法直接取到想要的结果,但是在单步调试的时候,调试程序花费了较多的时间,导致程序运行到对应位置的时候已经可以取到网络连接失败的状态。
所以,虽然网络部分有很多看似玄学的东西,但是实际上也基本都是可以找到问题的原因的,只在于我们的经验和细心程度。还需要多努力啊。