文章詳情頁
python - Pyd如何做熱更新?
瀏覽:131日期:2022-06-28 16:12:44
問題描述
現在做了一個PC客戶端的插件更新系統。以前插件是.py后綴的。沒什么問題。 但是最近用cython編譯成pyd就有問題了。當主程序import pyd這個模塊的時候,就刪不掉了。提示文件占用。只有當主程序關閉后,才能刪除。 但這樣就失去了熱更新的意義。 有沒有什么辦法能動態卸載pyd或者有更好的辦法?
import xxpydimport sysprint ’xxpyd’ in sys.modulesdel sys.modules[’xxpyd’]print ’xxpyd’ in sys.modulesimport timetime.sleep(100)
及時這樣,刪除了 sys.modules,pyd也是刪不掉。
問題解答
回答1:目前有一種折中的方案,用一個插件管理類去控制導入和獲取pyd,優點就是可以隨意次數的熱更新,缺點就是所有引用的import語法都要換成插件管理類去 import
回答2:導入的pyd文件如果刪除不掉,能否每次用新的pyd文件去更新,如20170616.pyd(只是例子),其他舊的文件在每次停主程序或者其他時機刪除。
回答3:pyd 本質就是 dll
有 dll地獄一說,形容dll難于做版本管理
相關文章:
1. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?2. mysql - 數據庫建字段,默認值空和empty string有什么區別 1103. mysql - 這種分級一對多,且分級不平衡的模型該怎么設計表?4. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?5. mac OSX10.12.4 (16E195)下Mysql 5.7.18找不到配置文件my.cnf6. mysql mysql_real_escape_string() 轉義問題7. 新人求教MySQL關于判斷后拼接條件進行查詢的sql語句8. mysql - 千萬數據 分頁,當偏移量 原來越大時,怎么優化速度9. MySQL FOREIGN KEY 約束報錯10. mysql - 數據庫表中,兩個表互為外鍵參考如何解決
排行榜
