[0:] Microsoft.Maui.Controls.Element: Warning: The RealParent on Microsoft.Maui.Controls.VerticalStackLayout has been Garbage Collected. #25538
Labels
area-layout
StackLayout, GridLayout, ContentView, AbsoluteLayout, FlexLayout, ContentPresenter
layout-stack
platform/android 🤖
s/needs-attention
Issue has more information and needs another look
s/triaged
Issue has been reviewed
t/bug
Something isn't working
Description
Good afternoon,
The debug logs requests to log an issue :
[0:] Microsoft.Maui.Controls.Element: Warning: The RealParent on Microsoft.Maui.Controls.VerticalStackLayout has been Garbage Collected. This should never happen. Please log a bug: https://github.com/dotnet/maui
This happens when I use a popup during navigation or any long running task.
The said popup contains a VerticalStackLayout :
Steps to Reproduce
Display a popup while another task is running.
When I do navigation or file creation, some loading can take a while, so I use a pop from CommunityToolkit.Maui.Views to display a loader on the screen.
To do so I call the following line inside a setter :
This line seems to be the culprit (Fire and Forget on the mainThread, used to open the popup).
Changing the code to properly await the task via a dedicated method at the right place doesn't change anything, the error remains. (instead of inside a setter)
Using the dispatcher.DispatchAsync and awaiting the task (instead of fire and forget) solved the issue, the error is no longer appearing
return Dispatcher.DispatchAsync(() => this.ShowPopupAsync(new AppPopupActivity(), CancellationToken.None).ConfigureAwait(false));
Calling the Dispatcher this way :
Using the mainthread static is too :
return MainThread.InvokeOnMainThreadAsync(() => this.ShowPopupAsync(new AppPopupActivity(), CancellationToken.None));
and
return MainThread.InvokeOnMainThreadAsync(() => this.ShowPopupAsync(new AppPopupActivity(), CancellationToken.None).ConfigureAwait(false));
The Test(bool x) method is awaited later in the code.
With
await task
;I hope this helps.
Link to public reproduction project repository
No response
Version with bug
8.0.10 SR3
Is this a regression from previous behavior?
Not sure, did not test other versions
Last version that worked well
Unknown/Other
Affected platforms
Android
Affected platform versions
Android 13
Did you find any workaround?
I'm just report the bug as requested in the logs.
Working and non-working cases described above.
Relevant log output
[MaterialButton] MaterialButton manages its own background to control elevation, shape, color and states. Consider using backgroundTint, shapeAppearance and other attributes where available. A custom background will ignore these attributes and you should consider handling interaction states such as pressed, focused and disabled
[MaterialButton] MaterialButton manages its own background to control elevation, shape, color and states. Consider using backgroundTint, shapeAppearance and other attributes where available. A custom background will ignore these attributes and you should consider handling interaction states such as pressed, focused and disabled
[MaterialButton] MaterialButton manages its own background to control elevation, shape, color and states. Consider using backgroundTint, shapeAppearance and other attributes where available. A custom background will ignore these attributes and you should consider handling interaction states such as pressed, focused and disabled
[MaterialButton] MaterialButton manages its own background to control elevation, shape, color and states. Consider using backgroundTint, shapeAppearance and other attributes where available. A custom background will ignore these attributes and you should consider handling interaction states such as pressed, focused and disabled
[MaterialButton] MaterialButton manages its own background to control elevation, shape, color and states. Consider using backgroundTint, shapeAppearance and other attributes where available. A custom background will ignore these attributes and you should consider handling interaction states such as pressed, focused and disabled
[EGL_emulation] app_time_stats: avg=5.66ms min=1.95ms max=31.90ms count=22
[0:] Microsoft.Maui.Controls.Element: Warning: The RealParent on Microsoft.Maui.Controls.VerticalStackLayout has been Garbage Collected. This should never happen. Please log a bug: https://github.com/dotnet/maui
[0:] Microsoft.Maui.Controls.Element: Warning: The RealParent on Microsoft.Maui.Controls.VerticalStackLayout has been Garbage Collected. This should never happen. Please log a bug: https://github.com/dotnet/maui
[0:] Microsoft.Maui.Controls.Element: Warning: The RealParent on Microsoft.Maui.Controls.VerticalStackLayout has been Garbage Collected. This should never happen. Please log a bug: https://github.com/dotnet/maui
[0:] Microsoft.Maui.Controls.Element: Warning: The RealParent on Microsoft.Maui.Controls.VerticalStackLayout has been Garbage Collected. This should never happen. Please log a bug: https://github.com/dotnet/maui
[Choreographer] Skipped 165 frames! The application may be doing too much work on its main thread.
[CustomViewTarget] Glide treats LayoutParams.WRAP_CONTENT as a request for an image the size of this device's screen dimensions. If you want to load the original image and are ok with the corresponding memory cost and OOMs (depending on the input size), use .override(Target.SIZE_ORIGINAL). Otherwise, use LayoutParams.MATCH_PARENT, set layout_width and layout_height to fixed dimension, or use .override() with fixed dimensions.
[OpenGLRenderer] Davey! duration=3083ms; Flags=0, FrameTimelineVsyncId=71941, IntendedVsync=8201182432416, Vsync=8203932432306, InputEventId=0, HandleInputStart=8203935751100, AnimationStart=8203935788100, PerformTraversalsStart=8203936954100, DrawStart=8204142729500, FrameDeadline=8201215765748, FrameInterval=8203935565000, FrameStartTime=16666666, SyncQueued=8204222847800, SyncStart=8204228963700, IssueDrawCommandsStart=8204229281400, SwapBuffers=8204258320000, FrameCompleted=8204271574700, DequeueBufferDuration=3643100, QueueBufferDuration=423200, GpuCompleted=8204267769400, SwapBuffersCompleted=8204271574700, DisplayPresentTime=8172253824100,
[EGL_emulation] app_time_stats: avg=12.38ms min=1.94ms max=48.32ms count=24
[Parcel] Expecting binder but got null!
[OpenGLRenderer] Davey! duration=3161ms; Flags=1, FrameTimelineVsyncId=71941, IntendedVsync=8201182432416, Vsync=8203932432306, InputEventId=0, HandleInputStart=8203935751100, AnimationStart=8203935788100, PerformTraversalsStart=8203936954100, DrawStart=8204335200900, FrameDeadline=8201199099082, FrameInterval=8203935565000, FrameStartTime=16666666, SyncQueued=8204339350600, SyncStart=8204395919300, IssueDrawCommandsStart=8204396084500, SwapBuffers=8204398097000, FrameCompleted=8204400389800, DequeueBufferDuration=178200, QueueBufferDuration=738400, GpuCompleted=8204399931000, SwapBuffersCompleted=8204400389800, DisplayPresentTime=0,
[aranteesTracker] Explicit concurrent copying GC freed 27430(1099KB) AllocSpace objects, 3(60KB) LOS objects, 49% free, 11MB/23MB, paused 13.117ms,62us total 64.232ms
Thread started: #39
Thread started: #40
The text was updated successfully, but these errors were encountered: