pee*_*ngh 5 c# wpf performance startup
更新
我已经更新了应用程序启动时运行的代码示例,并上传了性能配置文件结果的新图像。我不明白第一秒没有活动的原因。这似乎是最严重的延迟,我想了解这是 WPF 还是 dot net 框架在做什么?
结束更新
在 UI 线程利用率图中,我可以看到在磁盘 IO(蓝线)之前,又大部分是空白 + 应用程序代码(绿色)。我怎样才能知道空白区域发生了什么?
我看到的另一件事是 XAML 在应用程序加载时被解析(蓝色区域)。xaml 存在于不同的项目中,并在此处引用。我想知道是否有任何方法可以预先解析 xaml,因为它位于不同的项目中。
我知道这个问题有点太宽泛,但是有关如何继续的建议或指向正确工具(最好是免费的)的建议将很有价值。
我的 App.XAML 仅包含:
protected override void OnStartup(StartupEventArgs e)
{
new Entry().Show();
base.OnStartup(e);
}
Run Code Online (Sandbox Code Playgroud)
Entry的XAML是
<telerik:RadWindow x:Class="Some.Namespace.Entry"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:telerik="http://schemas.telerik.com/2008/xaml/presentation"
xmlns:local="clr-namespace:Some.Namespace"
mc:Ignorable="d"
Header ="Header" Width="1700" Height="900"
telerik:StyleManager.Theme="Windows8" WindowStartupLocation="CenterOwner">
</telerik:RadWindow>
Run Code Online (Sandbox Code Playgroud)
背后的代码:
public Entry()
{
RadWindowInteropHelper.SetAllowTransparency(this, false);
InitializeComponent();
}
Run Code Online (Sandbox Code Playgroud)
UPDATE TcpView 没有显示任何网络流量(我没想到这一点)。关闭恶意软件可能不可行。我确实尝试使用 Jet Brains profiler 获取另一份报告,这表明几乎一秒钟的时间都花在验证访问上,这是否合理,尝试在网上找到更多信息但没有得到任何结果。
Pro*_*rAl -1
您是否在发布模式下运行该应用程序?仅此一点就可以缩短启动时间。
我过去做过的一件粗暴的事情是通过调试启动应用程序,并在 Visual Studio 中不断点击中断。如果调试器总是停在同一位置,那就是问题所在。希望它在您自己的代码中,以便您能够更改它。
如果您有权访问分析器来分析您的代码,请尝试使用它。Visual Studio 附带了一个,但您只能在特定许可证的情况下使用它。