在 VSCode 中,它位于带有所选 .NET 测试日志的输出窗口中,显示象形文字而不是俄语字母。它在输出中,无论是在调试控制台还是在终端中,那里的一切都非常正常。我知道 OmniSharp 吓坏了。
有谁知道如何解决?
在 VSCode 中,它位于带有所选 .NET 测试日志的输出窗口中,显示象形文字而不是俄语字母。它在输出中,无论是在调试控制台还是在终端中,那里的一切都非常正常。我知道 OmniSharp 吓坏了。
有谁知道如何解决?
是否可以在 F# 中创建将基本类型限制在某个范围内的自定义类型?有条件地看起来像这样的东西
type myInt = Value of int when Value > 1000 & Value < 1000;
并且会在编译时禁止分配无效值
let a : myInt = 1000; //ошибка, не компилируется
假设我有一个绑定到 ViewModel 命令的 Button。在我写的 ViewModel 中:
public ICommand ClickCommand { get; set; }
public bool IsClicked;
public MainViewModel()
{
ClickCommand = ReactiveCommand.Create(OnClick);
}
private void OnClick()
{
//символизирует некую быструю операцию
IsClicked = true;
}
我希望代码能够同步执行,更何况我根本不改变界面中的任何东西,我只是想执行一个快速操作。但是此代码失败并出现错误:
System.InvalidOperationException: '调用线程无法访问此对象,因为另一个线程拥有此对象。'
因为它里面的 ReactiveCommand.Execute 爬进了 CanExecute 命令属性,这导致了对 System.Windows.Controls.Primitives.ButtonBase.UpdateCanExecute() 按钮方法的调用(这一切都可以从错误中的调用堆栈中看出)。这一切都很好,我不明白为什么不在 UI 线程中这样做,以及如何将这个调用全部推送到 UI 线程中。
在 ReactiveCommand 构造函数中,默认情况下,如果不传递自己的调度器,则会选择 RxApp.MainThreadScheduler。
问题是,有没有人遇到过这种行为以及如何让它正常工作?
UPD:完整的错误堆栈跟踪
System.InvalidOperationException
HResult=0x80131509
Message=Вызывающий поток не может получить доступ к данному объекту, так как владельцем этого объекта является другой поток.
Source=WindowsBase
StackTrace:
at System.Windows.Threading.Dispatcher.VerifyAccess()
at System.Windows.DependencyObject.GetValue(DependencyProperty dp)
at System.Windows.Controls.Primitives.ButtonBase.get_Command()
at System.Windows.Controls.Primitives.ButtonBase.UpdateCanExecute()
at ReactiveUI.ReactiveCommand.OnCanExecuteChanged()
at System.Reactive.AnonymousSafeObserver`1.OnNext(T value) in D:\a\1\s\Rx.NET\Source\src\System.Reactive\AnonymousSafeObserver.cs:line 46
at System.Reactive.Subjects.FastImmediateObserver`1.EnsureActive(Int32 count) in D:\a\1\s\Rx.NET\Source\src\System.Reactive\Subjects\ReplaySubject.cs:line 889
at System.Reactive.Subjects.ReplaySubject`1.ReplayBase.OnNext(T value) in D:\a\1\s\Rx.NET\Source\src\System.Reactive\Subjects\ReplaySubject.cs:line 273
at System.Reactive.Linq.ObservableImpl.DistinctUntilChanged`2._.OnNext(TSource value) in D:\a\1\s\Rx.NET\Source\src\System.Reactive\Linq\Observable\DistinctUntilChanged.cs:line 79
at System.Reactive.Linq.ObservableImpl.CombineLatest`3._.SecondObserver.OnNext(TSecond value) in D:\a\1\s\Rx.NET\Source\src\System.Reactive\Linq\Observable\CombineLatest.cs:line 180
at System.Reactive.Subjects.FastImmediateObserver`1.EnsureActive(Int32 count) in D:\a\1\s\Rx.NET\Source\src\System.Reactive\Subjects\ReplaySubject.cs:line 889
at System.Reactive.Subjects.ReplaySubject`1.ReplayBase.OnNext(T value) in D:\a\1\s\Rx.NET\Source\src\System.Reactive\Subjects\ReplaySubject.cs:line 273
at System.Reactive.Linq.ObservableImpl.DistinctUntilChanged`2._.OnNext(TSource value) in D:\a\1\s\Rx.NET\Source\src\System.Reactive\Linq\Observable\DistinctUntilChanged.cs:line 79
at System.Reactive.Linq.ObservableImpl.Select`2.Selector._.OnNext(TSource value) in D:\a\1\s\Rx.NET\Source\src\System.Reactive\Linq\Observable\Select.cs:line 49
at System.Reactive.Linq.ObservableImpl.Scan`2._.OnNext(TSource value) in D:\a\1\s\Rx.NET\Source\src\System.Reactive\Linq\Observable\Scan.cs:line 50
at System.Reactive.SafeObserver`1.OnNext(TSource value) in D:\a\1\s\Rx.NET\Source\src\System.Reactive\Internal\SafeObserver.cs:line 41
at System.Reactive.ScheduledObserver`1.Dispatch(ICancelable cancel) in D:\a\1\s\Rx.NET\Source\src\System.Reactive\Internal\ScheduledObserver.cs:line 93
at System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
at System.Threading.ThreadHelper.ThreadStart()