listview - 缓存图像 (ffimageloading) 在 android 上出现 OUT OF MEMORY 错误 - xamarin 表单

标签 listview exception xamarin xamarin.forms xamarin.android

我在 ffimageloading:CachedImage 库中有一个包含一些图像的 ListView ....
但是...当我测试时,我会反复执行:我打开 ListView 并在确定的时间按下操作栏上的后退按钮,当我按下后退按钮时,我有一个异常(exception):

03-02 09:31:13.511 I/art ( 2430): Starting a blocking GC Explicit 03-02 09:31:13.522 I/art ( 2430): Clamp target GC heap from 108MB to 96MB 03-02 09:31:13.522 I/art ( 2430): Explicit concurrent mark sweep GC freed 10820(745KB) AllocSpace objects, 90(1956KB) LOS objects, 3% free, 92MB/96MB, paused 136us total 9.552ms 03-02 09:31:13.535 D/Mono ( 2430): GC_OLD_BRIDGE num-objects 997 num_hash_entries 50753 sccs size 25365 init 0.00ms df1 37.29ms sort 7.73ms dfs2 26.26ms setup-cb 1.58ms free-data 17.62ms links 67211/67211/24685/2 dfs passes 118961/92576 03-02 09:31:13.535 D/Mono ( 2430): GC_BRIDGE: Complete, was running for 79.60ms 03-02 09:31:13.535 D/Mono ( 2430): GC_MAJOR_SWEEP: major size: 9136K in use: 8634K 03-02 09:31:13.535 D/Mono ( 2430): GC_MAJOR: (LOS overflow) time 60.53ms, stw 67.10ms los size: 27648K in use: 8339K 03-02 09:31:13.578 I/art ( 2430): Starting a blocking GC Alloc 03-02 09:31:13.578 I/art ( 2430): Starting a blocking GC Alloc 03-02 09:31:13.580 I/art ( 2430): Starting a blocking GC Alloc 03-02 09:31:13.585 I/art ( 2430): Clamp target GC heap from 108MB to 96MB 03-02 09:31:13.585 I/art ( 2430): Alloc partial concurrent mark sweep GC freed 4847(397KB) AllocSpace objects, 0(0B) LOS objects, 4% free, 92MB/96MB, paused 191us total 5.177ms 03-02 09:31:13.585 I/art ( 2430): Starting a blocking GC Alloc 03-02 09:31:13.594 I/art ( 2430): Clamp target GC heap from 108MB to 96MB 03-02 09:31:13.594 I/art ( 2430): Alloc concurrent mark sweep GC freed 3(96B) AllocSpace objects, 0(0B) LOS objects, 4% free, 92MB/96MB, paused 172us total 8.267ms 03-02 09:31:13.594 I/art ( 2430): Forcing collection of SoftReferences for 7MB allocation 03-02 09:31:13.594 I/art ( 2430): Starting a blocking GC Alloc 03-02 09:31:13.602 I/art ( 2430): Clamp target GC heap from 108MB to 96MB 03-02 09:31:13.602 I/art ( 2430): Alloc concurrent mark sweep GC freed 3(96B) AllocSpace objects, 0(0B) LOS objects, 4% free, 92MB/96MB, paused 178us total 7.794ms 03-02 09:31:13.602 W/art ( 2430): Throwing OutOfMemoryError "Failed to allocate a 8294412 byte allocation with 4161352 free bytes and 3MB until OOM" 03-02 09:31:13.602 I/art ( 2430): Starting a blocking GC Alloc 03-02 09:31:13.602 I/art ( 2430): Starting a blocking GC Alloc 03-02 09:31:13.604 I/art ( 2430): Starting a blocking GC Alloc 03-02 09:31:13.609 I/art ( 2430): Clamp target GC heap from 108MB to 96MB 03-02 09:31:13.609 I/art ( 2430): Starting a blocking GC Alloc 03-02 09:31:13.613 I/art ( 2430): Clamp target GC heap from 108MB to 96MB 03-02 09:31:13.614 I/art ( 2430): Forcing collection of SoftReferences for 7MB allocation 03-02 09:31:13.614 I/art ( 2430): Starting a blocking GC Alloc 03-02 09:31:13.621 I/art ( 2430): Clamp target GC heap from 108MB to 96MB 03-02 09:31:13.621 I/art ( 2430): Alloc concurrent mark sweep GC freed 3(96B) AllocSpace objects, 0(0B) LOS objects, 4% free, 92MB/96MB, paused 186us total 7.048ms 03-02 09:31:13.621 W/art ( 2430): Throwing OutOfMemoryError "Failed to allocate a 8294412 byte allocation with 4162792 free bytes and 3MB until OOM" 03-02 09:31:13.621 D/skia ( 2430): --- allocation failed for scaled bitmap Unhandled Exception: Java.Lang.OutOfMemoryError: Failed to allocate a 8294412 byte allocation with 4162792 free bytes and 3MB until OOM



在此错误之前,我还可以在输出中看到:

03-02 09:28:17.208 I/mono-stdout( 2430): at FFImageLoading.MiniLoggerWrapper.Error (System.String errorMessage, System.Exception ex) [0x00000] in C:\projects\ffimageloading\source\FFImageLoading.Common\Helpers\MiniLoggerWrapper.cs:30 03-02 09:28:17.208 I/mono-stdout( 2430): at FFImageLoading.MiniLoggerWrapper.Error (System.String errorMessage, System.Exception ex) [0x00000] in C:\projects\ffimageloading\source\FFImageLoading.Common\Helpers\MiniLoggerWrapper.cs:30 03-02 09:28:17.208 I/mono-stdout( 2430): at FFImageLoading.MiniLoggerWrapper.Error (System.String errorMessage, System.Exception ex) [0x00000] in C:\projects\ffimageloading\source\FFImageLoading.Common\Helpers\MiniLoggerWrapper.cs:30 03-02 09:28:17.208 I/mono-stdout( 2430): at FFImageLoading.MiniLoggerWrapper.Error (System.String errorMessage, System.Exception ex) [0x00000] in C:\projects\ffimageloading\source\FFImageLoading.Common\Helpers\MiniLoggerWrapper.cs:30 03-02 09:28:17.208 I/mono-stdout( 2430): at FFImageLoading.MiniLoggerWrapper.Error (System.String errorMessage, System.Exception ex) [0x00000] in C:\projects\ffimageloading\source\FFImageLoading.Common\Helpers\MiniLoggerWrapper.cs:30 03-02 09:28:17.208 I/mono-stdout( 2430): at FFImageLoading.MiniLoggerWrapper.Error (System.String errorMessage, System.Exception ex) [0x00000] in C:\projects\ffimageloading\source\FFImageLoading.Common\Helpers\MiniLoggerWrapper.cs:30 03-02 09:28:17.208 I/mono-stdout( 2430): at FFImageLoading.MiniLoggerWrapper.Error (System.String errorMessage, System.Exception ex) [0x00000] in C:\projects\ffimageloading\source\FFImageLoading.Common\Helpers\MiniLoggerWrapper.cs:30 03-02 09:28:17.208 I/mono-stdout( 2430): at FFImageLoading.MiniLoggerWrapper.Error (System.String errorMessage, System.Exception ex) [0x00000] in C:\projects\ffimageloading\source\FFImageLoading.Common\Helpers\MiniLoggerWrapper.cs:30 03-02 09:28:17.208 I/mono-stdout( 2430): at FFImageLoading.MiniLoggerWrapper.Error (System.String errorMessage, System.Exception ex) [0x00000] in C:\projects\ffimageloading\source\FFImageLoading.Common\Helpers\MiniLoggerWrapper.cs:30 03-02 09:28:17.208 I/mono-stdout( 2430): at FFImageLoading.MiniLoggerWrapper.Error (System.String errorMessage, System.Exception ex) [0x00000] in C:\projects\ffimageloading\source\FFImageLoading.Common\Helpers\MiniLoggerWrapper.cs:30 03-02 09:28:17.208 I/mono-stdout( 2430): --- End of stack trace from previous location where exception was thrown --- 03-02 09:28:17.208 I/mono-stdout( 2430): at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw () [0x0000c] in <657aa8fea4454dc898a9e5f379c58734>:0 03-02 09:28:17.208 I/mono-stdout( 2430): at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess (System.Threading.Tasks.Task task) [0x0003e] in <657aa8fea4454dc898a9e5f379c58734>:0 03-02 09:28:17.208 I/mono-stdout( 2430): at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification (System.Threading.Tasks.Task task) [0x00028] in <657aa8fea4454dc898a9e5f379c58734>:0 03-02 09:28:17.208 I/mono-stdout( 2430): at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd (System.Threading.Tasks.Task task) [0x00008] in <657aa8fea4454dc898a9e5f379c58734>:0 03-02 09:28:17.208 I/mono-stdout( 2430): at System.Runtime.CompilerServices.ConfiguredTaskAwaitable`1+ConfiguredTaskAwaiter[TResult].GetResult () [0x00000] in <657aa8fea4454dc898a9e5f379c58734>:0 03-02 09:28:17.208 I/mono-stdout( 2430): at FFImageLoading.Work.WorkScheduler+d__43.MoveNext () [0x001bb] in C:\projects\ffimageloading\source\FFImageLoading.Common\Work\WorkScheduler.cs:158 03-02 09:28:17.208 I/mono-stdout( 2430): --- End of managed Java.Lang.OutOfMemoryError stack trace --- 03-02 09:28:17.208 I/mono-stdout( 2430): java.lang.OutOfMemoryError: OutOfMemoryError thrown while trying to throw OutOfMemoryError; no stack trace available 03-02 09:28:17.211 I/Choreographer( 2430): Skipped 80 frames! The application may be doing too much work on its main thread.



我更新了 ffimageloading 但错误仍然在这里......我尝试了
MONO_GC_PARAMS=bridge-implementation=old

在环境中.txt

这是我在 PCL 中的 xaml:
<?xml version="1.0" encoding="utf-8" ?>
 <ContentPage xmlns="http://xamarin.com/schemas/2014/forms"
         xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
         x:Class="neoFly_Montana.Views.ProdutosView"          
         xmlns:local="clr-namespace:neoFly_Montana.LayoutScripts"
         xmlns:interface="clr-namespace:neoFly_Montana.Interface"
         xmlns:ffimageloading="clr-namespace:FFImageLoading.Forms;assembly=FFImageLoading.Forms"
         BackgroundImage="prodBackground.jpg"
         x:Name="ParentHost">

<ContentPage.Content>

        <Grid HorizontalOptions="FillAndExpand" RowSpacing="0" VerticalOptions="FillAndExpand">
        <Grid.RowDefinitions>
            <RowDefinition Height="9.4*"/>
            <RowDefinition Height="0.6*"/>
        </Grid.RowDefinitions>

        <!-- Lista de produtos -->
            <ListView Grid.Row="0" Grid.Column="0" ItemSelected="ListView_ItemSelected" CachingStrategy="RecycleElement" BackgroundColor="Transparent" x:Name="listview_produtos" Margin="10,0,10,0" SeparatorVisibility="None" HasUnevenRows="True" HorizontalOptions="FillAndExpand" VerticalOptions="FillAndExpand">

            <ListView.Header>

                <!-- Observação -->
                <StackLayout>
                <StackLayout x:Name="prod_stack_obser" IsVisible="False" Orientation="Horizontal" Spacing="0" HorizontalOptions="FillAndExpand">
                    <Label x:Name="label_observ" HorizontalTextAlignment="Start" VerticalOptions="Center" FontSize="Small" TextColor="White" Style="{StaticResource labelsfont}" Margin="20,10,0,10" />
                    <ffimageloading:CachedImage x:Name="lapis" Source="lapis.png" IsVisible="False" HorizontalOptions="EndAndExpand"/>
                </StackLayout>
                <BoxView HeightRequest="20"/>
                </StackLayout>
            </ListView.Header>

                <ListView.ItemTemplate>
                    <DataTemplate>
                        <ViewCell>

                        <Grid Margin="20,0,20,20">
                            <ffimageloading:CachedImage Source="texturaCateg.png" BackgroundColor="{Binding FundoColor, Source={x:Reference ParentHost}}" Grid.Row="0" Grid.Column="0" Aspect="Fill" VerticalOptions="FillAndExpand" HorizontalOptions="FillAndExpand"/>

                            <StackLayout Grid.Row="0" Grid.Column="0" VerticalOptions="FillAndExpand" x:Name="produtos_stack_color" Spacing="10">

                                <StackLayout Spacing="0" Grid.Row="0" Grid.Column="0" HorizontalOptions="FillAndExpand" VerticalOptions="CenterAndExpand">

                                <StackLayout Orientation="Horizontal" Padding="10,10,10,0" VerticalOptions="Center" HorizontalOptions="FillAndExpand">
                                        <ffimageloading:CachedImage FadeAnimationForCachedImages="True" DownsampleUseDipUnits="True" DownsampleHeight="60" HeightRequest="83" WidthRequest="130" Source="{Binding imagem}" Aspect="Fill" VerticalOptions="CenterAndExpand" HorizontalOptions="CenterAndExpand" >
                                            <!--<ffimageloading:CachedImage.CacheKeyFactory>
                                                <interface:CustomCacheKeyFactory/>
                                            </ffimageloading:CachedImage.CacheKeyFactory>-->
                                        </ffimageloading:CachedImage>

                                        <!--HeightRequest="83" WidthRequest="100"-->
                                        <!--DownsampleHeight="83"-->
                                        <!--<StackLayout Orientation="Horizontal" VerticalOptions="Center" HorizontalOptions="EndAndExpand">
                                                <Label Style="{StaticResource labelsfont}" Text="R$" VerticalOptions="CenterAndExpand" TextColor="{Binding TextColor, Source={x:Reference ParentHost}}" FontSize="Medium"/>
                                                <Label Style="{StaticResource labelsfont}" Text="{Binding valor}" TextColor="{Binding TextColor, Source={x:Reference ParentHost}}" FontAttributes="Bold" VerticalOptions="Start" FontSize="30"/>
                                            </StackLayout>-->

                                </StackLayout>

                                        <!--nome-->
                                    <Label Text="{Binding nome}"  Margin="0,10,0,10" Style="{StaticResource labelsfont}" TextColor="{Binding TextColor, Source={x:Reference ParentHost}}" HorizontalTextAlignment="Center" FontAttributes="Bold" FontSize="Medium" HorizontalOptions="CenterAndExpand"/>

                                </StackLayout>
                                <Grid VerticalOptions="FillAndExpand">
                                    <BoxView Grid.Row="0" Grid.Column="0" VerticalOptions="FillAndExpand" HorizontalOptions="FillAndExpand" BackgroundColor="WhiteSmoke" Opacity="0.2"/>
                                    <Label Grid.Row="0" Grid.Column="0" Margin="10,10,10,10" HorizontalTextAlignment="Center" Text="{Binding observacao}" Opacity="1" FontSize="Small" Style="{StaticResource labelsfont}" TextColor="{Binding TextColor, Source={x:Reference ParentHost}}" HorizontalOptions="Center" />
                                </Grid>
                            </StackLayout>
                        </Grid>

                        </ViewCell>
                    </DataTemplate>
                </ListView.ItemTemplate>
                <ListView.Footer>

                <StackLayout>
                    <Grid x:Name="prod_rl_fundo" >
                    <Grid.Margin>
                        <OnPlatform x:TypeArguments="Thickness"
                                 iOS="20,0,20,0"
                                 Android="20,10,20,10"/>
                    </Grid.Margin>
                        <ffimageloading:CachedImage x:Name="prod_acomp_img" Source="texturaCateg.png" Grid.Row="0" Grid.Column="0" HorizontalOptions="FillAndExpand" Aspect="Fill" VerticalOptions="FillAndExpand"></ffimageloading:CachedImage>

                        <!--Acompanhamentos-->
                    <StackLayout x:Name="stack_acompanhamentos" Spacing="0" Grid.Row="0" Grid.Column="0">

                        <Grid x:Name="prod_acompanhamentos_title" HorizontalOptions="FillAndExpand">
                            <BoxView Grid.Row="0" Grid.Column="0" VerticalOptions="FillAndExpand" HorizontalOptions="FillAndExpand" BackgroundColor="WhiteSmoke" Opacity="0.2"/>
                            <Label x:Name="produtos_acomp_title" Text="+ Dois Acompanhamentos" Grid.Row="0" Grid.Column="0" Style="{StaticResource labelsfont}" Margin="20,20,20,20" FontAttributes="Bold" VerticalOptions="CenterAndExpand" HorizontalOptions="Center" />
                        </Grid>

                    </StackLayout>
                    </Grid>

                <BoxView HeightRequest="50"></BoxView>
                </StackLayout>

            </ListView.Footer>

            </ListView>

            <!--Rodapé Grid-->
            <Grid Grid.Row="1" Grid.Column="0" VerticalOptions="FillAndExpand" HorizontalOptions="FillAndExpand">
            <ffimageloading:CachedImage Source="rodape.png" 
                       HorizontalOptions="FillAndExpand"
                       Aspect="AspectFill"
                       VerticalOptions="FillAndExpand"
                   Grid.Row="0"/>

            <!--Escrito Rodapé-->
            <StackLayout Orientation="Horizontal" 
                   Margin ="5,5,5,5" VerticalOptions="CenterAndExpand" HorizontalOptions="CenterAndExpand" Grid.Row="0">
                    <Label
                   FontSize="Micro"
                   Text="Você está em:"
                   Style="{StaticResource labelsfont}"
                   VerticalOptions="CenterAndExpand"
                   TextColor="White"/>

                    <Label FontSize="Micro"
                   Text="loja"
                   x:Name="prod_lbl_lojaprox"
                   Style="{StaticResource labelsfont}"
                   VerticalOptions="CenterAndExpand"
                   TextColor="{StaticResource laranjacolor}"
                   LineBreakMode="TailTruncation"
                   FontAttributes="Bold" />
                </StackLayout>
            </Grid>
        </Grid>

</ContentPage.Content>

我的主要事件:
  protected override void OnCreate(Bundle bundle)
    {
        TabLayoutResource = Resource.Layout.Tabbar;
        ToolbarResource = Resource.Layout.Toolbar;

        base.OnCreate(bundle);

        global::Xamarin.Forms.Forms.Init(this, bundle);

        //inicializa imageCircle
        ImageCircleRenderer.Init();

        //shared Preferences
        App.Init(new AndroidUserPreferences());

        //Gerenciador de memória
        CachedImageRenderer.Init(true);
        var config = new FFImageLoading.Config.Configuration()
        {
            VerboseLogging = false,
            VerbosePerformanceLogging = false,
            VerboseMemoryCacheLogging = false,
            VerboseLoadingCancelledLogging = false,
            FadeAnimationForCachedImages = false,
            MaxMemoryCacheSize = 50000000,
            FadeAnimationDuration = 500

            //Logger = new CustomLogger(),
        };
        FFImageLoading.ImageService.Instance.Initialize(config);

        LoadApplication(new App());
    }

     public override void OnTrimMemory([GeneratedEnum] TrimMemory level)
    {
        FFImageLoading.ImageService.Instance.InvalidateMemoryCache();
        GC.Collect(GC.MaxGeneration, GCCollectionMode.Forced);

        base.OnTrimMemory(level);
    }

    public override void OnLowMemory()
    {
        FFImageLoading.ImageService.Instance.InvalidateMemoryCache();
        GC.Collect(GC.MaxGeneration, GCCollectionMode.Forced);

        base.OnLowMemory();
    }

我的图像是 base64 (png)
它们有 8kb,它们是 150x84 px

其中之一:





更新:我搜索了这么多……我需要缓存键吗??

最佳答案

您是否在 MainActivity 中实现了 InvalidateMemoryCache?阅读更多 https://github.com/luberda-molinet/FFImageLoading/wiki/Advanced-Usage#clear-cache-and-memory-considerations

    public override void OnTrimMemory([GeneratedEnum] TrimMemory level)
    {
        FFImageLoading.ImageService.Instance.InvalidateMemoryCache();
        GC.Collect(GC.MaxGeneration, GCCollectionMode.Forced);

        base.OnTrimMemory(level);
    }

    public override void OnLowMemory()
    {
        FFImageLoading.ImageService.Instance.InvalidateMemoryCache();
        GC.Collect(GC.MaxGeneration, GCCollectionMode.Forced);

        base.OnLowMemory();
    }

我认为,问题出在你的 base64 逻辑上,但让我们试试这个。

关于listview - 缓存图像 (ffimageloading) 在 android 上出现 OUT OF MEMORY 错误 - xamarin 表单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48990718/

相关文章:

android - ListView 的 Layout_width

scala - 读取行期间的 Source.fromInputStream 异常处理

C#、NUnit : How to deal with testing of exceptions and deferred execution

c# - 使用 SetBinding 的 Xamarin.Forms 绑定(bind)不起作用

android - 为什么android的值为:background still being used after a switch to a new theme

android - 当计时器在每一行内运行时如何提高列表性能

listview - 如何在 flutter 中将 ListView 滚动到底部

android - 更新 getCheckedItemPositions()

java - catch block 是否能够捕获 Throwable(包括错误和异常)

c# - 如何在 Xamarin IOS 中将参数传递给事件处理程序