gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 11:19:10 24 4
gpt4 key购买 nike

我在 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com