V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
lokamir
V2EX  ›  程序员

大家遇到过哪些看起来匪夷所思的 BUG 最后靠自己解决的

  •  1
     
  •   lokamir · 2021-05-21 16:31:58 +08:00 · 3956 次点击
    这是一个创建于 1285 天前的主题,其中的信息可能已经有所发展或是发生改变。
    21 条回复    2021-05-23 21:42:05 +08:00
    GM
        1
    GM  
       2021-05-21 16:38:03 +08:00   ❤️ 4
    1. 成年了发现国家不分配老婆,
    2. 毕业了发现国家没分配工作
    3. 退休了发现.............
    THESDZ
        2
    THESDZ  
       2021-05-21 16:55:38 +08:00
    @GM #1 第三条通过不退休解决
    fengjianxinghun
        3
    fengjianxinghun  
       2021-05-21 16:57:05 +08:00
    @THESDZ 通过 996 猝死解决
    BeautifulSoap
        4
    BeautifulSoap  
       2021-05-21 16:57:56 +08:00 via Android
    https://www.zhihu.com/question/34787444

    知乎这个问题挺好玩的,程序员可以看来乐乐
    raaaaaar
        5
    raaaaaar  
       2021-05-21 18:24:14 +08:00 via Android
    @BeautifulSoap 第一个回答笑了,最后竟然是重启解决的,一种意料之外情理之中的感觉。。
    gam2046
        6
    gam2046  
       2021-05-21 19:43:47 +08:00
    很久没做 Windows 桌面应用开发了,最近写了一个(还用了一些 WIN32 API ),但是重复使用下,重置应用状态太麻烦了,改了半天总会出些奇奇怪怪的问题。

    实在没办法了,每次用户点新的请求都自己重启应用,还是这样省事。
    debuggerx
        7
    debuggerx  
       2021-05-21 19:56:55 +08:00 via Android   ❤️ 1
    xingguang
        8
    xingguang  
       2021-05-21 20:14:30 +08:00
    Google 自动翻译导致 UI 框架的 api 不生效,有够离奇吧
    cz5424
        9
    cz5424  
       2021-05-21 20:23:26 +08:00 via iPhone
    @gam2046 经常内存泄露,只能重开进程
    zhou1024
        10
    zhou1024  
       2021-05-21 22:13:19 +08:00
    很多端口,网络之类的问题,重启可以解决百分之 90 。
    proxychains
        11
    proxychains  
       2021-05-21 23:24:54 +08:00
    @debuggerx 哇,这也太匪夷所思了
    wty
        12
    wty  
       2021-05-21 23:35:39 +08:00
    https://wtywtykk.github.io/2019/12/15/STM32-Flash-Error.html

    未初始化变量+时序问题,找了好久才解决

    https://sysprogs.com/w/forums/topic/bin-file-size-ecxeeds-flash-size-with-no-error/

    链接脚本问题导致编译结果超过实际允许大小,离谱的是这个有问题的代码出自 gcc 的 manual,并且很多地方都直接沿用了。
    ragnaroks
        13
    ragnaroks  
       2021-05-21 23:38:54 +08:00
    csharp 方法重载的 BUG,好像是 4.5.1 的,如下定义的情况下,使用 methodName(new IEnumerable<Int32>{1}) 实际上调用的是第一个重载,如果方法内没有业务逻辑问题就不大,我们当时运行了一个星期才发现录入的数据有问题,玩家积分全是错的,查了半天

    public void methodName(Int32 v1,Int32 v2)=>Console.Write(v1);

    public void methodName(Int32[] v1)=>Console.Write(v1);

    public void methodName(List<Int32> v1)=>Console.Write(v1);
    infun
        14
    infun  
       2021-05-21 23:40:03 +08:00
    Redis 小概率没有按设置的失效时间失效
    结果是底层封装太老,分开设置值和失效时间
    ragnaroks
        15
    ragnaroks  
       2021-05-21 23:40:26 +08:00
    现在已经修复了,IEnumerable<Int32> 只匹配 IList<Int32> 或 Int32[],有前者就用前者,否则是后者
    CismonX
        16
    CismonX  
       2021-05-21 23:59:32 +08:00
    Heisenbug 一生之敌
    CNife
        17
    CNife  
       2021-05-22 00:56:21 +08:00
    4 月份我在写硕士毕业论文,最后几天用 LaTeX 排版,一边学一边实操。为了降低错误出现的概率,我把各个章节都放在单独的.tex 文件中,每次只排版一个章节。
    前面几章问题都不大,稍微有点小问题都能解决,问题出在了第 4 章。第 4 章十分长,编译了好一会才看到编译器打印出了超过 100 条错误信息,编译失败。看错误信息,应该是语法错误,可是这么长的章节,到底是哪里有语法错误呢?
    我先是尝试了一些之前就出现过的解决方法,结果还是编译错误;用 Google 搜索错误信息,尝试别人的方法也没有成功。这个问题从晚上 8 点开始,一直到 10 点多都没有解决,忙了一天脑子也不清楚了,我想就到这里吧。
    然后旁边的同学提醒了我,能不能截取出一段最短的问题片段,这样就能缩小问题可能的范围。我一想对啊!先注释掉第 4 章的前半部分,编译看有没有错误,如果有错误就接着注释掉后半段的一半,如果没有错误就取消前半段的一半,这样使用二分法逐渐缩小可能出现问题的范围。
    就这样,我最终锁定了一个单词,这个单词里有一个下划线。难道是它?查了一下才知道 LaTeX 里下划线必须转义!至此,这个问题终于得到了解决,我也终于能回宿舍睡觉了。或许这不算 bug,但是定位问题的思路我认为还是相当有意义的。
    Justin13
        18
    Justin13  
       2021-05-22 08:23:57 +08:00 via Android
    前端程序,有次重构把前后端请求的 promise 改成了 async/await 了,结果内存泄露了
    反反复复看了几遍没问题,devtool 定位到方法后,尝试把其上面可有可无的 async 去掉,结果就好了
    再去看 babel 转出来的代码,果然是它的问题,多了 async 就多了层闭包,而且隔了层闭包把一些变量抓住了,导致无法 GC,就泄露了
    gam2046
        19
    gam2046  
       2021-05-22 09:26:56 +08:00
    @cz5424 #9 倒也不是内存泄漏,因为这个工具主要的作用是一个胶水工具,把几个第三方工具整合到一起,因此用一些 WIN32 API 把不同第三方工具弄到一个界面里( SetParent ),这其中又涉及到由于网络原因,某些第三方工具可能会打开失败,那么其他已经打开的应用就需要统一一起关闭,这里面处理太麻烦了。经常会造成整合的界面显示奇奇怪怪以及焦点获取有问题
    wzzzx
        20
    wzzzx  
       2021-05-22 09:29:05 +08:00   ❤️ 1
    在虚拟机里编译系统,一直编译出问题。查了查发现是虚拟机的核心数分配了一个,然后脚本获取核心数除以 2,导致只有 0 个核心数,所以就出问题了。。
    chihiro2014
        21
    chihiro2014  
       2021-05-23 21:42:05 +08:00
    前段时间遇到一个重构的项目,项目中有个表单提交的部分,目测我改的时候发现的那个 bug,没人发现,但是线上估计也没人用过。明明有个 form 表单,但是他不写 form 表单,导致整个组件没法用
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1129 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 22:50 · PVG 06:50 · LAX 14:50 · JFK 17:50
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.