都说全局变量是万恶之源, 可读性差, 而且还容易产生错误, 此话不假。
最近, 本来需要扩展函数参数,但当时为了图方便, 直接用了全局变量, 但每次结束后又没有清空, 结果出现异常:
1. 在测试环境下, 表现没有异常。 序列化打包OK.
2. 在灰度外网的时候, 开始表现也没有异常, 于是全量外网。 过一会发现非关键功能出现异常。
百思不得其解, 还是打印日志吧, 最后发现, 是全局变量没有清空, 导致字符串累加连接,积累一段时间后, 超出了一定长度, 序列化打包时出错。 测试环境请求量小,所以不容易发现异常, 但外网请求量大, 很快累积, 容易出现异常。
我当时用的全局变量是stingstream类型的, 没有人为清空, 形成了字符串串扰。
以后能不用全局变量, 就不用吧。 如果要用, 千万要注意。
关于stringstream的清空操作, 我后来又遇到一个坑, 这个放到下篇文章再说, 敬请期待。