首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >Avalonia 已知问题 过早创建 App 对象将抛出 PlatformNotSupportedException 异常

Avalonia 已知问题 过早创建 App 对象将抛出 PlatformNotSupportedException 异常

作者头像
林德熙
发布2026-04-04 09:04:51
发布2026-04-04 09:04:51
1130
举报
文章被收录于专栏:林德熙的博客林德熙的博客

本文记录 Avalonia 的一个已知问题,过早创建 App 对象将抛出 PlatformNotSupportedException 异常

此问题能够在 Avalonia 的 11.3 以及更早版本复现

只需要让 App 对象在 AppBuilder.Configure 委托之外创建,那么在调用 StartWithClassicDesktopLifetime 方法时,将在 Avalonia.Threading.Dispatcher.MainLoop 方法抛出异常

代码语言:javascript
复制
System.PlatformNotSupportedException: Operation is not supported on this platform.
   at Avalonia.Threading.Dispatcher.MainLoop(CancellationToken cancellationToken)
   at Avalonia.Controls.ApplicationLifetimes.ClassicDesktopStyleApplicationLifetime.StartCore(String[] args)
   at Avalonia.Controls.ApplicationLifetimes.ClassicDesktopStyleApplicationLifetime.Start(String[] args)
   at Avalonia.ClassicDesktopStyleApplicationLifetimeExtensions.StartWithClassicDesktopLifetime(AppBuilder builder, String[] args, Action`1 lifetimeBuilder)
   at RemhemlaidejeheWhahaheenalira.Program.Main(String[] args)

点进去 Dispatcher.MainLoop 看,可以发现进入了 _controlledImpl == null 的分支,如以下代码所示

代码语言:javascript
复制
	public void MainLoop(CancellationToken cancellationToken)
	{
		if (_controlledImpl == null)
		{
			throw new PlatformNotSupportedException();
		}
		DispatcherFrame frame = new DispatcherFrame();
		cancellationToken.Register(delegate
		{
			frame.Continue = false;
		});
		PushFrame(frame);
	}

大概问题原因就是因为 App 过早初始化,导致碰了静态的 Dispatcher.UIThread 属性,进而导致了 Dispatcher 过早初始化,导致 _controlledImpl 没有被初始化,这才导致出现此异常

代码语言:javascript
复制
public partial class Dispatcher : IDispatcher
{
    ...
    public static Dispatcher UIThread
    {
        [MethodImpl(MethodImplOptions.AggressiveInlining)]
        get
        {
            return s_uiThread ??= CreateUIThreadDispatcher();
        }
    }

    ...
}

我认为这是 Avalonia 的一个设计问题,但可以按照它现在的框架,也没有什么可以优化

本文代码放在 githubgitee 上,可以使用如下命令行拉取代码。我整个代码仓库比较庞大,使用以下命令行可以进行部分拉取,拉取速度比较快

先创建一个空文件夹,接着使用命令行 cd 命令进入此空文件夹,在命令行里面输入以下代码,即可获取到本文的代码

代码语言:javascript
复制
git init
git remote add origin https://gitee.com/lindexi/lindexi_gd.git
git pull origin 266f08d8df93a15051573c88676671d48136aeb0

以上使用的是国内的 gitee 的源,如果 gitee 不能访问,请替换为 github 的源。请在命令行继续输入以下代码,将 gitee 源换成 github 源进行拉取代码。如果依然拉取不到代码,可以发邮件向我要代码

代码语言:javascript
复制
git remote remove origin
git remote add origin https://github.com/lindexi/lindexi_gd.git
git pull origin 266f08d8df93a15051573c88676671d48136aeb0

获取代码之后,进入 AvaloniaIDemo/RemhemlaidejeheWhahaheenalira 文件夹,即可获取到源代码

更多技术博客,请参阅 博客导航

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档