dongle3217 2014-02-27 02:18
浏览 24

来自go的COM调用通过GC收集了其数据,将已用内存清零

I have a go program that executes a WMI query then converts the data back into go-land data structures (using the method here). Every so often, go's GC comes along and nukes some seemingly random parts of memory to 0s, causing horrible breakage.

I am trying to figure out what exactly is causing this problem, and the next step, I believe, is to understand what happens during the COM call. My current understanding is:

  1. call into COM with the WMI query from a process
  2. the OS executes the query and writes the results into some memory location owned by the process
  3. that location is returned from the COM call, which I can then access and serialize

Is this about what happens? How does Windows choose that memory location such that it doesn't overwrite existing data?

  • 写回答

1条回答 默认 最新

  • duanqinjiao5244 2014-02-27 03:00
    关注

    Every COM object is reference counted with AddRef() and Release(). Perhaps you need an extra AddRef() to keep it around longer.

    I see from the sample code that there are a lot of defered Release calls. This is fine because we want the objects released at the end of main. In your program you might want to put off Release even longer (but, I don't know go or exactly what defer does)

    评论

报告相同问题?

悬赏问题

  • ¥15 linux驱动,linux应用,多线程
  • ¥20 我要一个分身加定位两个功能的安卓app
  • ¥15 基于FOC驱动器,如何实现卡丁车下坡无阻力的遛坡的效果
  • ¥15 IAR程序莫名变量多重定义
  • ¥15 (标签-UDP|关键词-client)
  • ¥15 关于库卡officelite无法与虚拟机通讯的问题
  • ¥15 目标检测项目无法读取视频
  • ¥15 GEO datasets中基因芯片数据仅仅提供了normalized signal如何进行差异分析
  • ¥100 求采集电商背景音乐的方法
  • ¥15 数学建模竞赛求指导帮助