从Activity,Async和Service访问SQLite

时间:2012-04-20 08:24:58

标签: android sqlite android-asynctask android-service

我正在从收件箱中读取前100条短信并将其存储在本地数据库中。我在AsyncTask的帮助下这样做。之后我正在从本地数据库中读取这些短信并显示它。在阅读& s之后的AysncTask的onPostExecute中存储前100条短信,我正在调用该服务来读取剩余的短信并将其存储在本地数据库中。在调用服务之前,UI是响应式的,但在调用服务后,UI变得无法响应。是由于数据库锁定还是其他原因。请帮忙解决这个问题...

我的AsyncTask代码

private class InitialSetup extends AsyncTask<String, Integer, Long> {
    @Override
    protected Long doInBackground(String... urls) {
        fetchSMS();
        updateDatabase();
        return 0L;
    }

    @Override
    protected void onPostExecute(Long result) {
        if (this.dialog.isShowing()) {
            this.dialog.dismiss();
        }
        populateUI(getApplicationContext());
        Intent intent = new Intent(getApplicationContext(), SMSService.class);
        getApplication().startService(intent);
    }
}

服务代码

public class SMSService extends Service {

    Long inboxSMSID, localSMSID;

    @Override
    public IBinder onBind(Intent arg0) {
        return null;
    }

    @Override
    public void onStart(Intent intent, int startid) {
        if (intent.hasExtra("InboxSMS") && intent.hasExtra("SMSID")) {
            inboxSMSID = intent.getLongExtra("InboxSMS", 0);
            localSMSID = intent.getLongExtra("SMSID", 0);
            globalToLocalSMSDB(inboxSMSID);
        }
    }

    private void globalToLocalSMSDB(Long id) {
        SMSTable smsObj = new SMSTable(getApplicationContext());
        smsObj.open();
        Uri uriSMSURI = Uri.parse("content://sms/inbox");
        Cursor smscur = getContentResolver().query(uriSMSURI, null,
                "_id < " + id, null, "_id DESC");
        while (smscur.moveToNext()) {
            String sender = SMSManagement.getSender(smscur);
            String message = SMSManagement.getMessage(smscur);
            String timeStamp = SMSManagement.getTime(smscur);
            smsObj.insertIntoSMSTable(sender, message, timeStamp);
        }
        smscur.close();
        smsObj.close();
    }
}

1 个答案:

答案 0 :(得分:0)

该服务也在UI线程中运行,您必须手动创建工作线程,除非它是IntentService。