私は Android アプリケーション開発者の初心者です。以下は私のプログラムですが、実行すると、LogCat で GC_CONCURRENT メッセージが発生します。これは、プログラムがメモリを消費しすぎていることが原因であることを理解していますが、コードを繰り返し読むことで、なぜ私のプログラムが予想よりもはるかに多くのメモリを消費するのか、まだわかりません.
07-11 10:38:12.258: D/dalvikvm(10060): GC_CONCURRENT 解放 88K、2% 解放 12912K/13063K、一時停止 2ms+13ms
07-11 10:38:25.024: D/dalvikvm(10060): GC_CONCURRENT 解放された 84K 、2% フリー 13249K/13447K、一時停止 1ms+3ms
以下はコードです。
public class Reader extends Activity {
TextView mText;
NfcAdapter mAdapter;
PendingIntent mPendingIntent;
IntentFilter mFilters[];
String mTechLists[][];
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
}
@Override
public void onStart(){
super.onStart();
setContentView(R.layout.activity_reader);
mText = (TextView) findViewById(R.id.text);
mAdapter = NfcAdapter.getDefaultAdapter(this);
mPendingIntent = PendingIntent.getActivity(this, 0,
new Intent(this, getClass()).addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP), 0);
IntentFilter ndef = new IntentFilter(NfcAdapter.ACTION_NDEF_DISCOVERED);
try{
ndef.addDataType("text/plain");
}catch(MalformedMimeTypeException e){
throw new RuntimeException("fail", e);
}
IntentFilter nt = new IntentFilter(NfcAdapter.ACTION_TAG_DISCOVERED);
mFilters = new IntentFilter[]{
ndef, nt
};
mTechLists = new String[][]{
new String[]{
Ndef.class.getName()
}
};
Intent intent = getIntent();
mText.setText(getNdefMessages(intent));
}
public String getNdefMessages(Intent intent){
NdefMessage[] msgs = null;
String action = intent.getAction();
if(NfcAdapter.ACTION_NDEF_DISCOVERED.equals(action)||
NfcAdapter.ACTION_TAG_DISCOVERED.equals(action)){
Parcelable[] rawMsgs = intent.getParcelableArrayExtra(NfcAdapter.EXTRA_NDEF_MESSAGES);
if(rawMsgs != null){
msgs = new NdefMessage[rawMsgs.length];
for(int i=0; i<rawMsgs.length; i++){
msgs[i] = (NdefMessage) rawMsgs[i];
}
}else{
byte[] empty = new byte[]{};
NdefRecord record = new NdefRecord(NdefRecord.TNF_UNKNOWN, empty, empty, empty);
NdefMessage msg = new NdefMessage(new NdefRecord[]{record});
msgs = new NdefMessage[]{msg};
}
}
else {
finish();
}
if(msgs==null)
return "No Tag discovered!";
else
return msgs.toString();
}
@Override
public void onResume(){
super.onResume();
if (mAdapter != null)
mAdapter.enableForegroundDispatch(this, mPendingIntent, mFilters, mTechLists);
}
@Override
public void onPause(){
super.onPause();
if (mAdapter != null)
mAdapter.disableForegroundDispatch(this);
}
@Override
public void onNewIntent(Intent intent){
Log.i("Foreground dispatch", "Discovered tag with intent:" + intent);
mText = (TextView) findViewById(R.id.text);
mText.setText(getNdefMessages(intent));
}
}