- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
对于任何想知道的人,画廊是 http://www.spore.com/sporepedia .
我的应用程序使用 Spore API 获取 100 个最新创建的内容,然后将它们显示在 GridView 中。关于创作的文本数据易于存储,但图像存在问题。
据我所知,我可以将图像保存在哈希表中,也可以在每次查看图像时抓取它们。这些都不起作用 - Hashtable 很快就会出现 OutOfMemoryError,并且不断的重新加载会导致服务器上的大量负载和客户端上的大量滞后。
有没有更好的方式存储图片?
最佳答案
首先不要一次获得 100 张,您不可能在 gridview 中显示 100 张图像并使它们具有有用的可见尺寸。异步检索图像并一次获取全屏或半屏。我猜你可以在每个屏幕上显示 6 到 9 个大小合适的图像,并支持文本/UI 元素,你甚至可能想根据手机屏幕大小/分辨率选择显示多少。因此,您应该一次获取 9 到 12 张图像。
其次,我不知道这些图像的分辨率是多少,但听起来像是“大”。如果 API 支持,它只会为您的 GridView 接收缩略图版本。如果没有,我可能会做的是:当您从 API 收到图像时,首先创建一个新图像,按比例缩小到进入 GridView 的缩略图所需的大小,并将其保存在内存中。然后创建一个按比例缩小到“详细信息”屏幕(如果有的话)所需大小的新图像并将其缓存到 SD 卡并将其从 ram 以及原始源图像中释放出来,这种缩放可能会发生在一个单独的线程中,以避免它影响您的 UI 线程的响应能力。根据使用模式,我可能还会将缩略图缓存到 SD 卡中,这样释放它们在 onStop/onPause 中使用的 ram 并在 onStart/onResume 中重新加载它们会很便宜。 IT 听起来也像是您在下载“前 100 名”之类的东西。由于我不希望每次使用的应用程序都出现全新的前 100 名,因此您可以通过将图像和信息缓存到 SD 卡并仅在每次程序运行时下载新条目来节省大量网络流量。
或者像这样的过程:
接收图片->原地缩放到细节大小->缓存细节大小->原地缩放细节到缩略图大小->在gridview中显示缩略图,同时异步缓存缩略图
会使用更少的内存,因为内存中只有 1 个图像副本,但它会减慢 gridview 的响应,因为图像在显示之前必须缩放两次。它可能足够快而无关紧要,或者您可以通过在后台生成缩略图时显示大图像(内部缩放)来使用 GridView 玩花样,准备好后将 GridView 切换到缩略图。您只需尝试确定它是否足够快。
关于android - 巨大的在线图片库 - 如何避免 OutOfMemoryError?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2889318/
我正在尝试将用户提供的经纬度值与数据库中的经纬度值进行比较。如果它们在彼此半径 15 公里内,则应更改 TextView 。但我面临以下错误, 我的数据库包含值 source lat = 19.218
我在我的应用程序中使用改造来下载一些媒体文件,如视频、mp3、jpg、pdf 等。当我想下载一个 55MB 的 mp4 格式的大文件时,这是一个问题。当我想下载这个文件时,我收到这样的错误: OutO
所以我正在创建一个 Android 应用程序,这段代码引发了 "Caused by: java.lang.OutOfMemoryError: OutOfMemoryError thrown while
直到昨天,我的应用程序运行良好,但我所做的是,由于某些原因,我不得不在 Android Studio 中打开具有不同工作空间的同一个应用程序。从那时起,当我尝试运行该应用程序时,我遇到了以下异常,所以
我正在尝试构建一个应用程序,其中客户端将其屏幕发送到服务器,客户端仅在上次发送屏幕和最新捕获的屏幕之间存在差异时才发送其屏幕(以便该程序在网络)。服务器使用 JFrame 和 JLabel 来显示图像
我正在尝试使用内存映射模式在 cupy 中加载一些较大的 .npy 文件,但我不断遇到 OutOfMemoryError 。 我认为,由于它是在内存映射模式下打开的,因此此操作不应该占用太多内存,因为
我正在尝试对基于 ant 的(Netbeans RCP)项目进行分级并找到奇怪的分级行为。 我用探查器做了一些观察,得到了下一个结果。 环境配置 Gradle 1.9 Build time: 20
我有一个应用程序可以进行网络调用并检索 XML 数据。如果没有太多数据,下面的代码可以正常工作。 public class WebClient { private static final S
在我的应用程序中,我每 3 分钟刷新一次数据。如果应用程序可以工作几个小时,我会遇到这样的错误: java.lang.OutOfMemoryError at org.apache.http.util.
我在我的一个应用程序中偶尔收到 OutOfMemoryError: (Heap Size=49187KB, Allocated=41957KB)。我该怎么做才能诊断? 01-09 10:32:02
对于学校项目,我必须编写不同类型的算法。问题是,我得到了一个工作算法。但是我必须多次运行它,一段时间后它给了我以下错误: Exception in thread "main" java.lang.Ou
这个问题在这里已经有了答案: 8年前关闭。 Possible Duplicate: Recursive function causing a stack overflow 完成示例惰性序列 here
我收到 java.lang.OutOfMemoryError 错误,即使我还有足够的空闲 RAM。我进行的内存转储在 200MB 到 1GB 之间,而我的服务器有 24GB 的 RAM。我设置了 -X
我不明白为什么这段代码没有OutOfMemoryError public static void main(String[] args) { Object[] ref = new Object
我正在使用这个语句 //some code int a[][]=new int[5000000][5000000]; //some code 并使用命令运行它 java -mx512m Test 它给
今天我在玩OOM错误,我发现了一些我自己无法解释的东西。 我尝试分配一个比堆大的数组,期望 “请求的阵列大小超出 VM 限制”错误,但我得到一个“ Java 堆空间 ”错误。 根据JDK 11 doc
我有一个显示图像的简单页面。来源是 URL var img = new Image (); var source = new UriImageSource { Uri =
我有一个 Java Spring Boot 应用程序。它是一个非常大的应用程序,具有许多服务,并且可以执行大量任务。我尝试实现的新任务之一是从 Oracle DB 读取一些数据并通过 REST 将其发
我正在尝试使用流读取一个非常大的文件,因此我需要并行流而不是每行迭代...我正在尝试如下: String cont = new String(Files.readAllBytes(Paths.get(
假设我们的最大内存为 256M,为什么这段代码可以工作: public static void main(String... args) { for (int i = 0; i < 2; i++)
我是一名优秀的程序员,十分优秀!