
1 t133 2023-10-06 12:30:00 +08:00 via iPhone 使用 with tempfile 这种试试? |
2 aijam 2023-10-06 12:34:08 +08:00 +1 用 with |
3 ysc3839 2023-10-06 12:39:09 +08:00 via Android gc 语言就是不确定释放时机的,因此不能用 C++的 RAII 这种写法,只能用语言提供的 with 等机制。 |
4 vituralfuture 2023-10-06 12:42:58 +08:00 GC 是无法确定时机的,不一定是立刻释放,往往是内存占用达到阈值了或者满足其他条件了才会开始 GC 参考 https://docs.python.org/3/library/gc.html ,可以看看 python 提供的 GC 接口,可以调试 GC ,也可以立刻调用 GC 另外还可以把清理资源这些操作放到 run 函数末尾 |
5 BBCCBB 2023-10-06 12:57:15 +08:00 使用者必须得保证正确释放, 不然就没法完了. 文件, io 流都是这样的.. 直接用 with/try finally. |
6 julyclyde 2023-10-06 16:21:43 +08:00 run 函数末尾试试 del task |
7 ch2 2023-10-06 19:04:56 +08:00 暴露一个 cleanup 函数出去吧 |
8 nowheremanx OP @julyclyde del task 也不一定有用,因为 GC 并不会立即释放。而且 python 中各种引用太复杂了,可能无法保证 reference 为 0 。 最令我震惊的是,程序结束之后,有些文件也不会释放。 |
9 nowheremanx OP @ch2 是的,只能要求用户手动 cleanup 。 如果没有 cleanup 直接结束的话,扔一个 warning 好了。这是目前想到的方案,类似于 http 客户端或者数据库客户端的 behaviour 。 |
10 dayeye2006199 2023-10-07 07:48:18 +08:00 via Android 弄成一个 contextmanger ,清理逻辑显式写在里面 |
11 nowheremanx OP @dayeye2006199 这个是正要加的 feature ,但是我个人不是很喜欢 with ,代码块都要右移,所以最早的时候用__del__帮忙解决资源回收。这才踩坑了 |
12 Maerd 2023-10-07 11:38:25 +08:00 我很好奇为什么你认为让 gc 来“帮”你清除文件是合理的,并且还预想程序崩溃时也能自动清理,这在任何语言中都是不可靠的操作,对于文件操作我们应该手动去处理。 一般来说,python 中的临时文件都是使用 tempfile 模块来管理,tempfile 会自动在程序退出的时候删除文件 |
13 julyclyde 2023-10-07 12:18:53 +08:00 @nowheremanx gc 不 *立即* 释放,是很可以理解的。手工 del 可以“提醒”在可做可不做的情况下,让他去做。但至于说引用数没有降到 0 ,那可能是你自己需要解决的问题了 至于程序结束后还没释放……可能是 bug ?? |
14 julyclyde 2023-10-07 12:19:21 +08:00 @nowheremanx 哈哈哈代码块右移,好像是 python 被人诟病的问题之一,就是随便加点啥就右移很远了 |
16 Maerd 2023-10-07 15:05:21 +08:00 @julyclyde 哦这点是我说错了,tempfile 的清理是 context manager 结束或者关闭临时文件对象后会删除,这样免除了手动删除一次的问题 |
18 bianhui 2023-10-08 09:20:05 +08:00 首先,系统 gc 就不应该要去尝试控制。提供一个 clean 方法或者上下文管理器就行了,别老想着 pua 别的程序员,open 函数也不一定有人全部记得 close 。不会是所有的事情都要拦在自己身上。别人写不好是别人的事,就算是上下文管理器,别人也可以直接通过__enter__去调用。把自己的 api 构建好就行了。 |
20 julyclyde 2023-10-08 12:42:16 +08:00 @Maerd Under Unix, the directory entry for the file is either not created at all or is removed immediately after the file is created. Other platforms do not support this; your code should not rely on a temporary file created using this function having or not having a visible name in the file system. 大概是 deleted immediately 的方法。学习了 |