- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
这是我的代码。开始时的目标是将图像抓取到动态 ListView 中,基本上就像我自己数据库中的 RSS 提要一样。我所做的是获取 http 链接并将其转换为可绘制对象,然后从那里将可绘制对象从动态 ListView 设置到 ImageView 中。
问题来了。当我进入应用程序时,第一次加载没问题。但是,当我点击刷新按钮时,我会收到“633632 字节分配内存不足”错误,然后是该错误的更详细版本,其中包含分配的所有堆大小、限制。
我该如何解决这个问题?
package com.whatstherex.sam;
import java.io.InputStream;
import java.net.URL;
import java.util.ArrayList;
import java.util.Vector;
import org.apache.http.NameValuePair;
import android.app.Activity;
import android.app.ProgressDialog;
import android.graphics.drawable.Drawable;
import android.os.AsyncTask;
import android.os.Bundle;
import android.os.StrictMode;
import android.view.View;
import android.widget.Button;
import android.widget.ListView;
public class Snapshots extends Activity implements View.OnClickListener {
Button bBackSnapshots, bRefreshSnapshots, bSnapshotsSnapshots;
ListView snapshotsDynamicListView;
Vector<SnapshotsData> snapshotsInputs = new Vector<SnapshotsData>();
SnapshotsCustomFeedAdaptor adaptor;
String username, snapshotsList;
String[] feed;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
StrictMode.setThreadPolicy(policy);
setContentView(R.layout.snapshots);
initialize();
}
public void initialize() {
bBackSnapshots = (Button) findViewById(R.id.bBackSnapshots);
bRefreshSnapshots = (Button) findViewById(R.id.bRefreshSnapshots);
bSnapshotsSnapshots = (Button) findViewById(R.id.bSnapshotsSnapshots);
bBackSnapshots.setOnClickListener(this);
bRefreshSnapshots.setOnClickListener(this);
bSnapshotsSnapshots.setOnClickListener(this);
getInformations();
}
private AsyncTask<String, Void, String> task;
private AsyncTask<String, Void, String> task1;
private AsyncTask<String, Void, InputStream[]> task2;
public void getInformations(){
task = new AsyncTask<String, Void, String>() {
ProgressDialog dialog;
Bundle bundle;
String res;
@Override
protected void onPreExecute(){
dialog = new ProgressDialog(Snapshots.this, ProgressDialog.STYLE_SPINNER);
dialog.setMessage("Loading Data...");
dialog.setCancelable(false);
dialog.setCanceledOnTouchOutside(false);
dialog.show();
}
@Override
protected String doInBackground(String... arg0) {
bundle = getIntent().getExtras();
res = bundle.getString("Username");
return res;
}
@Override
protected void onPostExecute(String result) {
dialog.dismiss();
username = result;
task1 = new AsyncTask<String, Void, String>() {
ProgressDialog dialog1;
ArrayList<NameValuePair> postParameters;
String response1;
String res1;
@Override
protected void onPreExecute(){
snapshotsDynamicListView = (ListView) findViewById(R.id.lvSnapshots);
postParameters = new ArrayList<NameValuePair>();
dialog1 = new ProgressDialog(Snapshots.this, ProgressDialog.STYLE_SPINNER);
dialog1.setMessage("Loading Data...");
dialog1.setCancelable(false);
dialog1.setCanceledOnTouchOutside(false);
dialog1.show();
}
@Override
protected String doInBackground(String... arg0) {
try {
response1 = CustomHttpClient.executeHttpPost("http://whatstherex.info/getS.php", postParameters);
res1 = response1.toString();
res1 = res1.replaceAll("null", "");
snapshotsList = res1.toString();
return snapshotsList;
}catch(Exception e){
res1 = e.toString();
return res1;
}
}
@Override
protected void onPostExecute(String result1) {
feed = result1.split("[_]");
task2 = new AsyncTask<String, Void, InputStream[]>() {
ProgressDialog dialog2;
InputStream[] is = new InputStream[50];
Drawable[] d = new Drawable[50];
String[] res2 = new String[50];
Drawable p4, p5, p9, p10, p14, p15, p19, p20, p24, p25, p29, p30, p34, p35, p39, p40, p44, p45, p49, p50, p54, p55, p59, p60, p64, p65, p69, p70, p74, p75, p79, p80, p84, p85, p89, p90, p94, p95, p99, p100, p104, p105, p109, p110, p114, p115, p119, p120, p124, p125;
@Override
protected void onPreExecute(){
dialog2 = new ProgressDialog(Snapshots.this, ProgressDialog.STYLE_SPINNER);
dialog2.setMessage("Loading Data...");
dialog2.setCancelable(false);
dialog2.setCanceledOnTouchOutside(false);
dialog2.show();
}
@Override
protected InputStream[] doInBackground(String... src) {
for(int i = 0; i<50; i++){
res2[i] = src[i];
}
for(int i = 0; i<50; i++){
try {
is[i] = (InputStream) new URL(res2[i]).getContent();
} catch (Exception e) {
e.toString();
}
}
return is;
}
@Override
protected void onPostExecute(InputStream[] result2) {
for(int i = 0; i<50; i++){
try {
d[i] = Drawable.createFromStream(result2[i], "src name");
} catch (Exception e) {
e.toString();
}
}
p4 = d[0];
p5 = d[1];
p9 = d[2];
p10 = d[3];
p14 = d[4];
p15 = d[5];
p19 = d[6];
p20 = d[7];
p24 = d[8];
p25 = d[9];
p29 = d[10];
p30 = d[11];
p34 = d[12];
p35 = d[13];
p39 = d[14];
p40 = d[15];
p44 = d[16];
p45 = d[17];
p49 = d[18];
p50 = d[19];
p54 = d[20];
p55 = d[21];
p59 = d[22];
p60 = d[23];
p64 = d[24];
p65 = d[25];
p69 = d[26];
p70 = d[27];
p74 = d[28];
p75 = d[29];
p79 = d[30];
p80 = d[31];
p84 = d[32];
p85 = d[33];
p89 = d[34];
p90 = d[35];
p94 = d[36];
p95 = d[37];
p99 = d[38];
p100 = d[39];
p104 = d[40];
p105 = d[41];
p109 = d[42];
p110 = d[43];
p114 = d[44];
p115 = d[45];
p119 = d[46];
p120 = d[47];
p124 = d[48];
p125 = d[49];
snapshotsInputs.add(new SnapshotsData(feed[1].toString(), feed[2].toString(), feed[3].toString(), p4, p5));
snapshotsInputs.add(new SnapshotsData(feed[6].toString(), feed[7].toString(), feed[8].toString(), p9, p10));
snapshotsInputs.add(new SnapshotsData(feed[11].toString(), feed[12].toString(), feed[13].toString(), p14, p15));
snapshotsInputs.add(new SnapshotsData(feed[16].toString(), feed[17].toString(), feed[18].toString(), p19, p20));
snapshotsInputs.add(new SnapshotsData(feed[21].toString(), feed[22].toString(), feed[23].toString(), p24, p25));
snapshotsInputs.add(new SnapshotsData(feed[26].toString(), feed[27].toString(), feed[28].toString(), p29, p30));
snapshotsInputs.add(new SnapshotsData(feed[31].toString(), feed[32].toString(), feed[33].toString(), p34, p35));
snapshotsInputs.add(new SnapshotsData(feed[36].toString(), feed[37].toString(), feed[38].toString(), p39, p40));
snapshotsInputs.add(new SnapshotsData(feed[41].toString(), feed[42].toString(), feed[43].toString(), p44, p45));
snapshotsInputs.add(new SnapshotsData(feed[46].toString(), feed[47].toString(), feed[48].toString(), p49, p50));
snapshotsInputs.add(new SnapshotsData(feed[51].toString(), feed[52].toString(), feed[53].toString(), p54, p55));
snapshotsInputs.add(new SnapshotsData(feed[56].toString(), feed[57].toString(), feed[58].toString(), p59, p60));
snapshotsInputs.add(new SnapshotsData(feed[61].toString(), feed[62].toString(), feed[63].toString(), p64, p65));
snapshotsInputs.add(new SnapshotsData(feed[66].toString(), feed[67].toString(), feed[68].toString(), p69, p70));
snapshotsInputs.add(new SnapshotsData(feed[71].toString(), feed[72].toString(), feed[73].toString(), p74, p75));
snapshotsInputs.add(new SnapshotsData(feed[76].toString(), feed[77].toString(), feed[78].toString(), p79, p80));
snapshotsInputs.add(new SnapshotsData(feed[81].toString(), feed[82].toString(), feed[83].toString(), p84, p85));
snapshotsInputs.add(new SnapshotsData(feed[86].toString(), feed[87].toString(), feed[88].toString(), p89, p90));
snapshotsInputs.add(new SnapshotsData(feed[91].toString(), feed[92].toString(), feed[93].toString(), p94, p95));
snapshotsInputs.add(new SnapshotsData(feed[96].toString(), feed[97].toString(), feed[98].toString(), p99, p100));
snapshotsInputs.add(new SnapshotsData(feed[101].toString(), feed[102].toString(), feed[103].toString(), p104, p105));
snapshotsInputs.add(new SnapshotsData(feed[106].toString(), feed[107].toString(), feed[108].toString(), p109, p110));
snapshotsInputs.add(new SnapshotsData(feed[111].toString(), feed[112].toString(), feed[113].toString(), p114, p115));
snapshotsInputs.add(new SnapshotsData(feed[116].toString(), feed[117].toString(), feed[118].toString(), p119, p120));
snapshotsInputs.add(new SnapshotsData(feed[121].toString(), feed[122].toString(), feed[123].toString(), p124, p125));
adaptor = new SnapshotsCustomFeedAdaptor(Snapshots.this, R.layout.snapshotsdata, snapshotsInputs);
snapshotsDynamicListView.setAdapter(adaptor);
dialog2.dismiss();
}
};
task2.execute(feed[4], feed[5], feed[9], feed[10], feed[14], feed[15], feed[19], feed[20], feed[24], feed[25], feed[29], feed[30],
feed[34], feed[35], feed[39], feed[40], feed[44], feed[45], feed[49], feed[50], feed[54], feed[55], feed[59], feed[60],
feed[64], feed[65], feed[69], feed[70], feed[74], feed[75], feed[79], feed[80], feed[84], feed[85], feed[89], feed[90],
feed[94], feed[95], feed[99], feed[100], feed[104], feed[105], feed[109], feed[110], feed[114], feed[115], feed[119],
feed[120], feed[124], feed[125]);
dialog1.dismiss();
}
};
task1.execute();
}
};
task.execute();
}
@Override
public void onClick(View v) {
switch (v.getId()){
case R.id.bBackSnapshots:
finish();
break;
case R.id.bRefreshSnapshots:
finish();
startActivity(getIntent());
break;
case R.id.bSnapshotsSnapshots:
break;
}
}
}
最佳答案
为什么要将大量 Drawable 添加到内存中。这就是问题所在。应用程序内存限制仅为 ~16MB(根据设备更改)。然而看起来您正在加载 100 个可绘制对象,很可能超过了这个数量。
您应该只在列表请求新 View 时加载可绘制对象。它会在不需要时处理它。
编辑:
您可以做的是覆盖适配器类。并指定图像的 url。然后在 getView 方法中,从给定的 Url 加载图像。这会按需处理异步加载。
例如:
https://stackoverflow.com/a/3068012/940834
http://www.androidhive.info/2012/02/android-custom-listview-with-image-and-text/
关于android - 633632 字节分配内存不足,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14302004/
美好的一天!我试图添加两个字节变量并注意到奇怪的结果。 byte valueA = 255; byte valueB = 1; byte valueC = (byte)(valueA + valueB
嗨,我是 swift 的新手,我正在尝试解码以 [Byte] 形式发回给我的字节数组?当我尝试使用 if let string = String(bytes: d, encoding: .utf8)
我正在使用 ipv4 和 ipv6 存储在 postgres 数据库中。 因为 ipv4 需要 32 位(4 字节)而 ipv6 需要 128(16 字节)位。那么为什么在 postgres 中 CI
我很好奇为什么 Go 不提供 []byte(*string) 方法。从性能的角度来看,[]byte(string) 不会复制输入参数并增加更多成本(尽管这看起来很奇怪,因为字符串是不可变的,为什么要复
我正在尝试为UDP实现Stop-and-Wait ARQ。根据停止等待约定,我在 0 和 1 之间切换 ACK。 正确的 ACK 定义为正确的序列号(0 或 1)AND消息长度。 以下片段是我的代码的
我在下面写了一些代码,目前我正在测试,所以代码中没有数据库查询。 下面的代码显示 if(filesize($filename) != 0) 总是转到 else,即使文件不是 0 字节而是 16 字节那
我使用 Apache poi 3.8 来读取 xls 文件,但出现异常: java.io.IOException: Unable to read entire header; 0 by
字典大小为 72 字节(根据 getsizeof(dict) 在字典上调用 .clear() 之后发生了什么,当新实例化的字典返回 240 字节时? 我知道一个简单的 dict 的起始大小为“8”,并
我目前正在努力创建一个函数,它接受两个 4 字节无符号整数,并返回一个 8 字节无符号长整数。我试图将我的工作基于 this research 描述的方法,但我的所有尝试都没有成功。我正在处理的具体输
看看这个简单的程序: #include using namespace std; int main() { unsigned int i=0x3f800000; float* p=(float*)(
我创建了自己的函数,将一个字符串转换为其等效的 BCD 格式的 bytes[]。然后我将此字节发送到 DataOutputStram (使用需要 byte[] 数组的写入方法)。问题出在数字字符串“8
此分配器将在具有静态内存的嵌入式系统中使用(即,没有可用的系统堆,因此“堆”将只是“char heap[4096]”) 周围似乎有很多“小型内存分配器”,但我正在寻找能够处理非常小的分配的一个。我说的
我将数据库脚本从 64 位系统传输到 32 位系统。当我执行脚本时,出现以下错误, Warning! The maximum key length is 900 bytes. The index 'U
想知道 128 字节 ext2 和 256 字节 ext3 文件系统之间的 inode 数据结构差异。 我一直在为 ext2、128 字节 inode 使用此引用:http://www.nongnu.
我试图理解使用 MD5 哈希作为 Cassandra key 在“内存/存储消耗”方面的含义: 我的内容(在 Java 中)的 MD5 哈希 = byte[] 长 16 个字节。 (16 字节来自维基
检查其他人是否也遇到类似问题。 shell脚本中的代码: ## Convert file into Unix format first. ## THIS is IMPORTANT. ###
我们有一个测量数据处理应用程序,目前所有数据都保存为 C++ float,这意味着在我们的 x86/Windows 平台上为 32 位/4 字节。 (32 位 Windows 应用程序)。 由于精度成
我读到在 Java 中 long 类型可以提升为 float 和 double ( http://www.javatpoint.com/method-overloading-in-java )。我想问
我有一个包含 n 个十进制元素的列表,其中每个元素都是两个字节长。 可以说: x = [9000 , 5000 , 2000 , 400] 这个想法是将每个元素拆分为 MSB 和 LSB 并将其存储在
我使用以下代码进行 AES-128 加密来编码一个 16 字节的 block ,但编码值的长度给出了 2 个 32 字节的 block 。我错过了什么吗? plainEnc = AES.enc
我是一名优秀的程序员,十分优秀!