亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

WPF應(yīng)用啟動(dòng)慢的問題解決

 更新時(shí)間:2021年05月22日 11:00:36   作者:louzi  
今天碰到一個(gè)奇怪的現(xiàn)象,在某些機(jī)器上,進(jìn)行了系統(tǒng)還原后,WPF應(yīng)用打開較慢,約有35s。本文先記錄下該問題的解決方案,應(yīng)用啟動(dòng)性能官方文檔中有說明,還有搜到的其它方案沒來(lái)得及測(cè)試,如NGEN update

方案一,更改啟動(dòng)項(xiàng)

出問題應(yīng)用的啟動(dòng)項(xiàng)是使用的默認(rèn)設(shè)置,查看App.g.cs文件,可以看到自動(dòng)生成的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();
}

新建一個(gè)StartUp文件,將項(xiàng)目啟動(dòng)項(xiàng)修改為WpfApp1.StartUp,這樣就可以解決該問題,代碼如下。與原始方案對(duì)比,該方案使用了WindowsFormsApplicationBase,該方案為什么可以解決啟動(dòng)慢的問題,我還沒搞清楚,或許和方案二有關(guān)。

// StartUp.cs
class StartUp : Application
{
    [STAThread]
    public static void Main(string[] args)
    {
        var startUp = new MyStartUp();
        startUp.Run(args);
    }
}

// 需要添加對(duì)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();
    }
}

方案二,禁用檢查應(yīng)用程序的CAS發(fā)布者策略

在config文件中添加如下配置項(xiàng)。generatePublisherEvidence指定運(yùn)行時(shí)是否為CAS創(chuàng)建發(fā)布者證據(jù),其默認(rèn)值為true,即創(chuàng)建發(fā)布者證據(jù),這樣可能會(huì)導(dǎo)致超時(shí)和服務(wù)啟動(dòng)延遲。因此將其置為false,該方法也可以解決啟動(dòng)慢的問題。

<configuration>
    <runtime>
        <generatePublisherEvidence enabled="false"/>
    </runtime>
</configuration>

以上就是WPF應(yīng)用啟動(dòng)慢的問題解決的詳細(xì)內(nèi)容,更多關(guān)于WPF應(yīng)用啟動(dòng)慢的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論