WPF應用啟動慢的問題解決
方案一,更改啟動項
出問題應用的啟動項是使用的默認設置,查看App.g.cs文件,可以看到自動生成的Main入口函數(shù),如下:
[System.STAThreadAttribute()] [System.Diagnostics.DebuggerNonUserCodeAttribute()] [System.CodeDom.Compiler.GeneratedCodeAttribute("PresentationBuildTasks", "4.0.0.0")] public static void Main() { WpfApp1.App app = new WpfApp1.App(); app.InitializeComponent(); app.Run(); }
新建一個StartUp文件,將項目啟動項修改為WpfApp1.StartUp,這樣就可以解決該問題,代碼如下。與原始方案對比,該方案使用了WindowsFormsApplicationBase,該方案為什么可以解決啟動慢的問題,我還沒搞清楚,或許和方案二有關。
// StartUp.cs class StartUp : Application { [STAThread] public static void Main(string[] args) { var startUp = new MyStartUp(); startUp.Run(args); } } // 需要添加對Microsoft.VisualBasic的引用 class MyStartUp : WindowsFormsApplicationBase { protected override bool OnStartup(StartupEventArgs eventArgs) { App app = new App(); app.Run(); return false; } } // App.xaml.cs 刪除App.xaml中的StartupUri="MainWindow.xaml" public partial class App : Application { public App() { var win = new MainWindow(); win.Show(); } }
方案二,禁用檢查應用程序的CAS發(fā)布者策略
在config文件中添加如下配置項。generatePublisherEvidence指定運行時是否為CAS創(chuàng)建發(fā)布者證據(jù),其默認值為true,即創(chuàng)建發(fā)布者證據(jù),這樣可能會導致超時和服務啟動延遲。因此將其置為false,該方法也可以解決啟動慢的問題。
<configuration> <runtime> <generatePublisherEvidence enabled="false"/> </runtime> </configuration>
以上就是WPF應用啟動慢的問題解決的詳細內(nèi)容,更多關于WPF應用啟動慢的資料請關注腳本之家其它相關文章!
相關文章
C#創(chuàng)建Windows Service(Windows 服務)的方法步驟
本文介紹了如何用C#創(chuàng)建、安裝、啟動、監(jiān)控、卸載簡單的Windows Service 的內(nèi)容步驟和注意事項,具有一定的參考價值,感興趣的可以了解一下2023-11-11C# DateTime.ToString根據(jù)不同語言生成相應的時間格式
本文分享了一個按照不同國家的語言生成相應時間格式的案例,有需要做國外網(wǎng)站或者多國語言網(wǎng)站的朋友可以參考一下。2016-03-03WPF利用TextBlock實現(xiàn)查找結(jié)果高亮顯示效果
在應用開發(fā)過程中,經(jīng)常遇到這樣的需求:通過關鍵字查找數(shù)據(jù),把帶有關鍵字的數(shù)據(jù)顯示出來,同時在結(jié)果中高亮顯示關鍵字,所以本文就來和大家介紹一下如何利用TextBlock實現(xiàn)查找結(jié)果高亮顯示效果吧2023-08-08