全局变量未清空, 定位耗费一小时

972 篇文章 329 订阅
322 篇文章 11 订阅

       都说全局变量是万恶之源, 可读性差, 而且还容易产生错误, 此话不假。


       最近, 本来需要扩展函数参数,但当时为了图方便, 直接用了全局变量, 但每次结束后又没有清空, 结果出现异常:

       1. 在测试环境下, 表现没有异常。 序列化打包OK.

       2. 在灰度外网的时候, 开始表现也没有异常, 于是全量外网。 过一会发现非关键功能出现异常。


       百思不得其解, 还是打印日志吧, 最后发现, 是全局变量没有清空, 导致字符串累加连接,积累一段时间后,  超出了一定长度, 序列化打包时出错。 测试环境请求量小,所以不容易发现异常, 但外网请求量大, 很快累积, 容易出现异常。

      我当时用的全局变量是stingstream类型的, 没有人为清空, 形成了字符串串扰。

   

      以后能不用全局变量, 就不用吧。 如果要用, 千万要注意。


      关于stringstream的清空操作, 我后来又遇到一个坑, 这个放到下篇文章再说, 敬请期待。






评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值