在android或者是java学习中存在4中引用,第一种是强引用,这种引用是不会被垃圾回收机制回收的,也是我们创建对象是默认的引用,第二种是软引用,这种引用是在内存不足的时候,如果被垃圾回收机制扫描到就会被回收,第三种是弱引用,这种引用只要被垃圾回收机制扫描到就会回收,第四种是虚引用,这种引用在创建后就被回收,这里的代码只演示了强引用和软引用,其它的2个和软引用的使用差不多。代码:
package com.example.strong_softdemo;
import java.lang.ref.SoftReference;
import java.util.ArrayList;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
/**
*
* @author jk 这段代码写的关于java引用里面的强引用, 软引用,弱引用,和虚引用,强引用是不会被垃圾回收机制回收的
* ,软引用是空间不够时回收,弱引用是被垃圾机制扫描到就会被回收 ,虚引用是创建就被回收。
*
*/
public class MainActivity extends Activity {
Button btn_Strong;
Button btn_Soft;
// 用强引用保存分配出来的空间
ArrayList<byte[]> data = new ArrayList<byte[]>();
// 用软引用保存分配出来的空间,data1中保存多个软引用,每个软引用指向一个byte[]
ArrayList<SoftReference<byte[]>> data1 = new ArrayList<SoftReference<byte[]>>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
init();
}
private void init() {
btn_Strong = (Button) findViewById(R.id.btn_Soft);
btn_Strong.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// 每次为强引用分配一个2m的空间
// data.add(new byte[2*1024*1024]);
}
});
btn_Soft = (Button) findViewById(R.id.btn_Soft);
btn_Soft.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// 每次为软引用开辟一个2m的空间
data1.add(new SoftReference<byte[]>(new byte[2 * 1024 * 1024]));
// 输出正在使用的空间和已经释放的空间
for (int i = 0; i < data1.size(); i++) {
if (data1.get(i).get() == null) {
System.out.println("item" + i + "空间已经释放");
} else {
System.out.println("item" + i + "空间正在使用");
}
}
}
});
}
}