精易论坛

标题: (原创)扫描仪之数码设备支持库(官方)内存泄漏的完美解决... [打印本页]

作者: hot1987115    时间: 2025-3-7 01:22
标题: (原创)扫描仪之数码设备支持库(官方)内存泄漏的完美解决...
本帖最后由 hot1987115 于 2025-3-7 01:28 编辑

在之前我在论坛求助过这个问题(https://125.confly.eu.org/forum.php?mod=viewthread&tid=14825956&extra=),开发过扫描仪相关程序的人应该是碰到过,当你连续扫描时,会导致你的应用程序内存暴增,一张图涨大约50M,过不了4 50张图,内存就不足,就会报错中断,很是恼火。后来慢慢找问题也基本确认这个内存泄漏的问题,但是试过各种方法,什么设置 图片={ },内存释放,内存释放EX,内存优化,也用过别人的各种内存插件,都无济于事,究其根源是因为没有找到具体是哪一块的内存泄漏。如果我有支持库源码其实很好解决,但网上确实找不到。
没办法,就想着自己重新写一个twain_32.dll的支持库吧,查阅到twain标准是英文版,又到处找翻译软件翻译了全文,我会把协议全文附在后边,以及C语言twain.h头文件(里边有各种参数详细值)。
废话就不多说了,反正是花了我很长很长的时间。最终的解决方案就是,用精易模块中的类_APIHOOK,函数,可以在应用程序点击扫描后安装HOOK,也可以开局就安装,APIHOOK.安装 (“twain_32.dll”, “DSM_Entry”, &新DSM_Entry),在新的DSM_Entry()入口函数里干2件事,一是拦截取图的三元组合
#DG_IMAGE / #DAT_IMAGENATIVEXFER / #MSG_GET,当拦截到常量#DAT_IMAGENATIVEXFER(也就是260)时,就记录下pData的指针,这个指针就是扫描仪源返回的全局DIB内存位置,等我们用完要释放的,在事件子程序(“图片传送完毕”)中的最后来释放。第二件事就是要返回正常的DSM_Entry()操作,不然后续步骤会执行不下去。
支持库因为不知道应用程序什么时候调用完这个图片数据,所以没有进行释放,所也也不怪他,但是他应该在支持库里应该记录下这些内存块,当用户调用完一次就释放一次。
我也算是把twain协议摸到门了,有什么不懂再问我吧,里边涉及到的东西太多了,一下也讲不了,真有需求的人看源码就懂了。
(对于我这个不懂C语言的,研究这个也是异常艰难)
另外,twain标准协议中文翻译pdf文件大于3M,我就不传了,有需要留言或联系我

twain研究历程.e

1.12 MB, 下载次数: 6, 下载积分: 精币 -2 枚

没啥用

Twain.h头文件.zip

19.05 KB, 下载次数: 5, 下载积分: 精币 -2 枚

twain.h c语言头文件

扫描仪-数码设备支持库内存泄漏解决方案.e

958.22 KB, 下载次数: 16, 下载积分: 精币 -2 枚

整理版


作者: fooker    时间: 2025-3-7 01:53
整的这么麻烦,直接把这一块功能写成exe,然后调用这个exe就可以了,每扫描一次就运行一次exe
作者: hot1987115    时间: 2025-3-7 02:04
fooker 发表于 2025-3-7 01:53
整的这么麻烦,直接把这一块功能写成exe,然后调用这个exe就可以了,每扫描一次就运行一次exe ...

连续扫描,容不得你频繁调用exe,如果你只调一次,内存一样暴涨,之前就有人提过写进多进程,思路不错,解决不了此问题
作者: hot1987115    时间: 2025-3-7 02:05
本帖最后由 hot1987115 于 2025-3-7 02:11 编辑

fooker 发表于 2025-3-7 01:53
整的这么麻烦,直接把这一块功能写成exe,然后调用这个exe就可以了,每扫描一次就运行一次exe ...


你讲的是内存泄漏的大众解决方案,但是只有搞过扫描仪的才知道痛点
作者: qq1056123185    时间: 2025-3-7 08:33
感谢分享,临时用不到,等用到了再来请教~
作者: 小虎来了    时间: 2025-3-7 09:14
感谢分享啊
作者: hjinpwhe1    时间: 2025-3-7 09:31
感谢分享啊
作者: hot1987115    时间: 2025-3-7 14:55
TW_IMAGEINFO,其实取图片前取了图片信息这个变量也是有泄漏的,只不过这点内存占用算不得什么,如果有特别需要清理这部份的,再联系我,也就是DAT=257的时候取到的数据
作者: kyo9766    时间: 2025-3-7 15:33
用过这个支持库,但是没有达到楼主这么多的数量,感谢分享
作者: 1184798949    时间: 2025-3-7 16:39
感谢分享
作者: panaowei    时间: 2025-3-25 19:51
这个不是乱码 而是加密了
需要解密才行
作者: hot1987115    时间: 2025-3-27 14:16
panaowei 发表于 2025-3-25 19:51
这个不是乱码 而是加密了
需要解密才行

说的个啥?
作者: 涤尘    时间: 2025-4-17 20:32
谢谢分享,学习一下
作者: futiem    时间: 2025-5-25 08:00
可以在应用程序点击扫描后安装HOOK
作者: hot1987115    时间: 2025-5-25 12:11
futiem 发表于 2025-5-25 08:00
可以在应用程序点击扫描后安装HOOK

看不见我讲的?
作者: 不离01    时间: 2025-6-2 23:44
感谢分享  6666




欢迎光临 精易论坛 (https://125.confly.eu.org/) Powered by Discuz! X3.4