这是运行代码时加载的默认活动。 当我单击“创建新帐户”链接时,屏幕变为空白,GC_FOR_ALLOC日志消息开始出现。切换到下一个活动(创建新帐户页面)时似乎存在问题。我已经在我的索尼xperia z1和geny运动模拟器上尝试了它,同样的结果发生了。
package com.michaelsony.gcsemathsrevisionapp;
import android.content.Intent;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.util.Log;
import android.view.View;
import android.content.Intent;
import android.widget.TextView;
public class LoginPage extends ActionBarActivity {
private static final String TAG = "Michael's Message";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_login_page);
Log.i(TAG, "OnCreate");
}
public void onClick(View view){
Intent i = new Intent(this, CreateAccount.class);
startActivity(i);
}
@Override
protected void onStart() {
super.onStart();
Log.i(TAG, "onStart");
}
@Override
protected void onResume() {
super.onResume();
Log.i(TAG, "onResume");
}
@Override
protected void onPause() {
super.onPause();
Log.i(TAG, "onPause");
}
@Override
protected void onStop() {
super.onStop();
Log.i(TAG, "onStop");
}
@Override
protected void onRestart() {
super.onRestart();
Log.i(TAG, "onRestart");
}
@Override
protected void onDestroy() {
super.onDestroy();
Log.i(TAG, "onDestroy");
}
@Override
protected void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
Log.i(TAG, "onSaveInstanceState");
}
@Override
protected void onRestoreInstanceState(Bundle savedInstanceState) {
super.onRestoreInstanceState(savedInstanceState);
Log.i(TAG, "onRestoreInstanceState");
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_login_page, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
//noinspection SimplifiableIfStatement
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
}
这是我尝试切换到的活动
package com.michaelsony.gcsemathsrevisionapp;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.EditText;
import android.widget.Toast;
import android.util.Log;
public class CreateAccount extends ActionBarActivity {
EditText firstnamebox, surnamebox, usernamebox, passwordbox, confirmpassbox;
UserDBHandler dbHandler;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_create_account);
firstnamebox = (EditText) findViewById(R.id.firstnamebox);
surnamebox = (EditText) findViewById(R.id.surnamebox);
usernamebox = (EditText) findViewById(R.id.usernamebox);
passwordbox = (EditText) findViewById(R.id.passwordbox);
confirmpassbox = (EditText) findViewById(R.id.confirmpassbox);
dbHandler = new UserDBHandler(this, null, null, 1);
printDatabase();
}
//Add a user to the database(create a user)
public void createAccountClick(View view){
Users user = new Users(firstnamebox.getText().toString(), surnamebox.getText().toString(), usernamebox.getText().toString(), passwordbox.getText().toString(), confirmpassbox.getText().toString());
Log.d("app1", "Password=" + passwordbox.getText().toString() + " confirm=" + confirmpassbox.getText().toString());
//dbHandler.addUser(user);
//Toast.makeText(getBaseContext(),"Account Created!", Toast.LENGTH_LONG).show();
if(!passwordbox.getText().toString().equals(confirmpassbox.getText().toString()))
{
Toast.makeText(getBaseContext(),"Passwords Do Not Match",Toast.LENGTH_LONG).show() ;
passwordbox.setText("");
confirmpassbox.setText("");
Log.d("app1", "Password=" + passwordbox.getText().toString() + " confirm=" + confirmpassbox.getText().toString());
}
else
{
dbHandler.addUser(user);
Toast.makeText(getBaseContext(),"Account Created!", Toast.LENGTH_LONG).show();
Log.d("app1", "Password=" + passwordbox.getText().toString() + " confirm=" + confirmpassbox.getText().toString());
}
}
public void printDatabase(){
String dbString = dbHandler.databaseToString();
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_create_account, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
//noinspection SimplifiableIfStatement
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
}
日志消息如下:
05-09 13:34:51.371 1941-1941/com.michaelsony.gcsemathsrevisionapp D/dalvikvm﹕ GC_FOR_ALLOC freed 279K, 12% free 4248K/4776K, paused 5ms, total 5ms
05-09 13:34:51.395 1941-1941/com.michaelsony.gcsemathsrevisionapp D/dalvikvm﹕ GC_FOR_ALLOC freed 155K, 12% free 4216K/4776K, paused 5ms, total 5ms
05-09 13:34:51.399 1941-1941/com.michaelsony.gcsemathsrevisionapp D/dalvikvm﹕ GC_FOR_ALLOC freed 279K, 12% free 4248K/4776K, paused 5ms, total 5ms
05-09 13:34:51.415 1941-1941/com.michaelsony.gcsemathsrevisionapp D/dalvikvm﹕ GC_FOR_ALLOC freed 155K, 12% free 4216K/4776K, paused 14ms, total 14ms
05-09 13:34:51.435 1941-1941/com.michaelsony.gcsemathsrevisionapp D/dalvikvm﹕ GC_FOR_ALLOC freed 279K, 12% free 4248K/4776K, paused 9ms, total 9ms
05-09 13:34:51.447 1941-1941/com.michaelsony.gcsemathsrevisionapp D/dalvikvm﹕ GC_FOR_ALLOC freed 155K, 12% free 4216K/4776K, paused 6ms, total 6ms
05-09 13:34:51.455 1941-1941/com.michaelsony.gcsemathsrevisionapp D/dalvikvm﹕ GC_FOR_ALLOC freed 280K, 12% free 4248K/4776K, paused 6ms, total 6ms
这些只是他们一直充斥着logcat!
答案 0 :(得分:0)
Don使用onClick
作为方法名称,将其命名为
public void onClick(View view){
Intent i = new Intent(this, CreateAccount.class);
startActivity(i);
}
像
public void onCreateAccountClicked(View view){
Intent i = new Intent(LoginPage.this, CreateAccount.class);
startActivity(i);
}
避免打印整个数据库。它可能很大并占用大量内存,这将导致过度调用GC(当它开始在内存上运行不足时)并最终使应用程序崩溃,因为它最终耗尽内存。
public void printDatabase(){
//String dbString = dbHandler.databaseToString();
}