android - AsyncTask 可以在服务内部运行并写入数据库吗?

标签 android sqlite android-asynctask

public class IdService extends Service {
    private UploadFilesTask task;
    DBAdapter dbs;

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

    @Override
    public void onCreate() {
        super.onCreate();               
    }

    @Override
    public void onStart(Intent intent, int startId) {   
        super.onStart(intent, startId); 
        if(Networking.isNetworkAvailable(this)){
            if ( intent.hasExtra("start") && taskIsNotRunning() ) {
                task = new UploadFilesTask();
                task.execute();             
            } 
        }
        else{
            if ( intent.hasExtra("start") && taskIsNotRunning() ) {
                Calendar cal = Calendar.getInstance();
                cal.add(Calendar.MINUTE, 5);
                String start = "start";
                Intent i = new Intent(IdService.this, IdService.class);
                i.putExtra("start", start);
                PendingIntent sender = PendingIntent.getService(this, 192837, i, PendingIntent.FLAG_UPDATE_CURRENT);
                AlarmManager am = (AlarmManager) getSystemService(ALARM_SERVICE);
                am.set(AlarmManager.RTC_WAKEUP, cal.getTimeInMillis(), sender);  
             }
        }
    }   

    private boolean taskIsNotRunning() {
        return task == null || task.getStatus() != AsyncTask.Status.RUNNING || task.isCancelled();
    }

    @Override
    public void onDestroy() {  
             super.onDestroy();

    }
    private class UploadFilesTask extends AsyncTask<Object, Object, Object> {
        @Override
        protected Object doInBackground(Object... arg0) {  
            SQLiteDatabase db = dbs.getWritableDatabase(); 
            ContentValues values = new ContentValues();
            values.put(DBAdapter.ID,  "blank");
            db.insert(DBAdapter.Table, null, values);
            return null;            
        }

        @Override
        protected void onPostExecute(Object result) {       
            super.onPostExecute(result);
            stopSelf();
        }   
    }
}

我想运行一个服务,将一个值插入到 sql 数据库的表中。如果没有互联网连接,我希望它等待 5 分钟,然后再次运行该服务。

代码中的问题在 SQLiteDatabase db = dbs.getWritableDatabase(); 我可以评估服务中的数据库吗?如果是这样,我如何让我的代码运行?谢谢

最佳答案

是的,为什么不呢。使用常规方法。不要忘记添加 SQLiteDatabse.setLockingEnabled(true);使数据库连接线程安全!

附言我看不到你从哪里开始 asyncTask?

关于android - AsyncTask 可以在服务内部运行并写入数据库吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6369258/

相关文章:

Java AsyncTask 将变量传递给主线程

java - 为 Android 创建第三方库的项目设置

Android Studio SQLite 游标

android - RecyclerView 适配器内部的 AsyncTask,如何同步?

javascript - 使用查询或使用编程语言从 SQLite 中排序数据

mysql - 在连接的情况下是否对条件进行分组在 SQL 中是否重要?

Android单例线程与服务器通信

java - 新的谷歌分析 SDK 4

android - 如何清除 EditText 的格式?

android - 如果按下stopButton,则停止音乐