享受Android应用程序的Java技术盛宴
2010-10-27 21:24:37 来源:Web开发网清单 5 中的类完全封装了一个用于存储股票信息的 SQLite 数据库。因为您将要使用一个嵌入式数据库,不仅是您的应用程序要使用它,而且也要通过应用程序来创建它。您需要提供代码来创建该数据库。Android 提供一个有用的抽象帮助类 SQLiteOpenHelper。要完成这一操作,您需要扩展这个抽象类并提供代码通过使用 onCreate 方法创建您的数据库。当您有一个帮助程序实例时,就可以获取一个 SQLiteDatabase 实例,您可以用来执行任意 SQL 语句。
您的数据库类有两个较为方便的方法。第一个是 addStock,用于将新股票保存到数据库中。注意,您使用了一个 SQLiteStatement 实例,这类似于一个 java.sql.PreparedStatement。需要注意的是,在您的类构造器中如何对其进行编译,使其在每次调用 addStock 时都能重复利用。在每个 addStock 调用中,SQLiteStatement 的变量(INSERT_SQL 字符串中的问号)必然要将数据传递给 addStock。再一次强调,这类似于 PreparedStatement ,您可以从 JDBC 了解它。
另一个方法是 getStocks。顾名思义,它从数据库中检索所有股票。注意,您再次使用一个 SQL 字符串,正如您在 JDBC 中所用的那样。您可以在 SQLiteDatabase 类上通过使用 rawQuery 方法来进行处理。这个类也有几个查询方法,让您可以不使用 SQL 直接查询数据库。所有这些方法都返回一个 Cursor 对象,和 java.sql.ResultSet 非常相似。您可以将 Cursor 移动到从数据库中返回的数据所在行,在每一行,您可以使用 getInt、getString 和其他的方法来检索您要查询的数据库中各列相关的值。再一次强调,这和 ResultSet 十分相似。也和 ResultSet 比较相似,当您完成操作之后,关闭 Cursor 也十分重要的。如果您没有关闭 Cursors,那么可能会迅速地耗尽内存并导致您的应用程序崩溃。
查询本地数据库是一个比较慢的过程,特别是,如果您有多行数据或者您需要在多个表之间运行复杂的查询语句。然而,数据库查询或插入超过 5 秒且出现一个 Application Not Responding 对话框,这种情况不太可能发生,但是当您的数据库忙于读取和写入数据时,冻结您的 UI 是不明智的。当然,避免这种情况最好的办法是使用 AsyncTask。清单 6 展示了这个示例。
清单 6. 在一个单独的线程上插入数据库
Button button = (Button) findViewById(R.id.btn);
button.setOnClickListener(new OnClickListener(){
public void onClick(View v) {
String symbol = symbolIn.getText().toString();
symbolIn.setText("");
double max = Double.parseDouble(maxIn.getText().toString());
maxIn.setText("");
double min = Double.parseDouble(minIn.getText().toString());
minIn.setText("");
double pricePaid =
Double.parseDouble(priceIn.getText().toString());
priceIn.setText("");
int quantity = Integer.parseInt(quantIn.getText().toString());
quantIn.setText("");
Stock stock = new Stock(symbol, pricePaid, quantity);
stock.setMaxPrice(max);
stock.setMinPrice(min);
new AsyncTask<Stock,Void,Stock>(){
@Override
protected Stock doInBackground(Stock... newStocks) {
// There can be only one!
return db.addStock(newStocks[0]);
}
@Override
protected void onPostExecute(Stock s){
addStockAndRefresh(s);
}
}.execute(stock);
}
});
您可以先为按钮创建一个实践监听器。当用户点击按钮时,您可以从各个小部件(确切地说是 EditText 小部件)读取股票数据并填入一个新的 Stock 对象。您可以创建一个 AsyncTask,并通过 doInBackground 方法从 清单 5 中调用 addStock 方法。如此,addStock 将在一个背景线程上执行,而不是在主 UI 线程上。完成之后,将新 Stock 对象从数据库传递到在主 UI 线程上执行的 addStockAndRefresh 方法。
结束语
本文显示了,即使 Android 在 Java 环境下仅支持众多 API 的一个子集,但是其功能却一点都不逊色。在某些示例中,比如网络,它完全实现了熟悉的 API,也提供了一些更为便捷的方法。在其他的示例中,比如并发性,Android 添加了额外 API 以及一些必须遵循的惯例。最后,在数据库访问案例中,Android 提供了完全不同的方法来访问数据库,但使用的是熟悉的概念。这不仅仅是标准 Java 和 Android Java 技术之间主观上的差异:它们形成了Android 开发的基础构建元件。
http://tech.cncms.com/shouji/iphone/111402.html
http://tech.cncms.com/shouji/android/40607.html
http://tech.cncms.com/shouji/android/41623.html
更多精彩
赞助商链接