PIPI0
PIPI0
采纳率85.7%
2016-01-19 01:00 阅读 1.7k

我一启动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 江户川小南 2016-01-19 02:26

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

    点赞 评论 复制链接分享
  • bdmh bdmh 2016-01-19 01:06

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

    点赞 评论 复制链接分享
  • rui888 兔子托尼啊 2016-01-19 01:07

    你得看看具体log 信息啊

    点赞 评论 复制链接分享
  • PIPI0 PIPI0 2016-01-19 01:23

    图片说明

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

    点赞 评论 复制链接分享
  • meng20166 乐古 2016-01-19 01:50

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

    点赞 评论 复制链接分享
  • enpterexpress 把分全给哥 2016-01-19 02:39

    这个molds是不是为空

    点赞 评论 复制链接分享
  • xmt1139057136 业余草 2016-01-19 03:28

    log信息不是很全啊

    点赞 评论 复制链接分享
  • Connery_thunder 浅浅无奈 2016-01-19 03:45

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

    点赞 评论 复制链接分享
  • pengguichu pgc_tel 2016-01-19 03:47

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

    点赞 评论 复制链接分享
  • crazy1235 月盡天明 2016-01-19 05:56

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

    点赞 评论 复制链接分享

相关推荐