看别人写的代码是件比较痛苦的事情,更加痛苦的是别人的代码出错还要负责调试好。
关于如何迅速定位问题和调试代码,我的一点感受是:逐行认真查看错误信息,在这些信息中找自己熟悉的内容(包括文件名、方法名等),不熟悉的内容先跳过。针对这些熟悉的内容,回溯相应的代码所在行,定位错误原因。
切忌囫囵吞枣的看了一通,其实什么有效信息也没有获得,也几乎不可能就这样定位到问题。
举例:
1、定位问题
在使用jedis监听和订阅消息时报以下错误。经逐行查看错误信息,定位到斜体的三行:分析错误原因是mget调用出错,且错误代码在OnlineFriend文件的112/257行。
redis.clients.jedis.exceptions.JedisDataException: ERR wrong number of arguments for 'mget' command
at redis.clients.jedis.Protocol.processError(Protocol.java:59) at redis.clients.jedis.Protocol.process(Protocol.java:66)
at redis.clients.jedis.Protocol.read(Protocol.java:131)
at redis.clients.jedis.Connection.getIntegerReply(Connection.java:188)
at redis.clients.jedis.Jedis.mget(Jedis.java:873)
at com.caffinc.OnlineFriend$MsgListener.onMessage(OnlineFriend.java:112)
at com.caffinc.OnlineFriend.main(OnlineFriend.java:257)
出错代码如下:List topRoles = jedis.srandmember(top_set_key, 10);
List topLevels = jedis.mget(topRoles.toArray(new String[0]));
2、检查问题
根据以上代码,分析可能原因是jedis.mget(key)方法没有获取到key值,即key为空。
直接在redis-cli中运行> srandmember top_set_key,发现top_set_key集合为空,并由此导致mget方法参数缺失。
3、问题处理
导入相应数据到redis top_set_key集合,重新运行代码后一切正常。
总结下,有两点收获:一是调试代码要逐行认真看错误信息,不可囫囵吞枣;二是具体到技术点,mget如果参数为空,会导致ERR wrong number of arguments for 'mget' 错误。