2 pipi0 PIPI0 于 2016.01.19 09:00 提问

我一启动service就出现问题,应该是线程的问题,请问怎么解决

package com.s5c.Changlink;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Timer;
import java.util.TimerTask;

import android.annotation.SuppressLint;
import android.app.Service;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Handler;
import android.os.IBinder;
import android.os.Message;
import android.widget.Toast;

@SuppressLint({ "SimpleDateFormat", "HandlerLeak" })
public class sqlService extends Service {

    SharedPreferences sp;
    String branch,mold,sql,id,Changelocation;
    Thread Change;
    Timer timer;
    Date molds;
    Date data=new Date(System.currentTimeMillis());
    SimpleDateFormat dateFormater = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
    Connection conn = null;
    Statement stmt = null;
    ResultSet rs = null;
    Message message;

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

    public int onStartCommand(Intent intent, int flags, int startId) {

        sp =getSharedPreferences("User", MODE_PRIVATE);
        branch = sp.getString("branch", "");
        mold = sp.getString("mold", "");
        try {
            molds = dateFormater.parse(mold);
        } catch (ParseException e) {
            e.printStackTrace();
        }
        if(molds.before(data)){
            timer.schedule(change, molds, 300000);////代码在这里出错,使程序崩溃
        }else{
            timer.schedule(change, 300000, 300000);
        }

        return super.onStartCommand(intent, flags, startId);
    }

    TimerTask change = new TimerTask(){
        public void run() {  
            message = new Message();      
            message.what = 1;      
            handler.sendMessage(message);    

        }  
    };

    Handler handler = new Handler(){  
        public void handleMessage(Message msg) {  
            switch (msg.what) {      
                case 1:
                    Toast.makeText(sqlService.this, "完全正常", Toast.LENGTH_LONG).show();
                    break;
            }      
            super.handleMessage(msg);  
        }    
    };

    public void onDestroy() {
        Toast.makeText(this, "您将取消服务", Toast.LENGTH_LONG).show();
        super.onDestroy();
    }

    public IBinder onBind(Intent intent) {
        return null;
    }

}


以上就是程序代码,我在造成崩溃的地方有标注,不明白为什么会造成程序崩溃

10个回答

u011665766
u011665766   2016.01.19 10:26
已采纳

你的Timer貌似没有创建。。只看到声明,没见到new

bdmh
bdmh   Ds   Rxr 2016.01.19 09:06

看logcat中的具体错误提示,是不是timer=null了

rui888
rui888   Ds   Rxr 2016.01.19 09:07

你得看看具体log 信息啊

PIPI0
PIPI0   2016.01.19 09:23

图片说明

这就是错误提示,我看到有明显指向的位置就是我代码中提示的位置

meng20166
meng20166   Rxr 2016.01.19 09:50

空引用异常,在控制台打印一下timer是不是没值

enpterexpress
enpterexpress   2016.01.19 10:39

这个molds是不是为空

xmt1139057136
xmt1139057136   Rxr 2016.01.19 11:28

log信息不是很全啊

Connery_thunder
Connery_thunder   2016.01.19 11:45

空指针异常,你直接在变量处设置断点用debug调试,专治各种空指针。

pengguichu
pengguichu   2016.01.19 11:47

molds这个值是空 没有new 或者没有给他赋值

crazy1235
crazy1235   Ds   Rxr 2016.01.19 13:56

空指针了。
timer貌似是空的。

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!