从字符串中获取日期

时间:2014-02-04 21:15:03

标签: java android date

我正在尝试将字符串(例如:“2/5/2014 /”)转换为可用于与当前日期进行比较的日期。

现在我有:

private double getTimeAWAY(String sdate) {
    double time=0;
    SimpleDateFormat formatter ; 
    Date rdate ; 
       formatter = new SimpleDateFormat("MM/dd/yyyy");
       try {
        rdate = (Date) formatter.parse(sdate);
        time = rdate.getTime()-System.currentTimeMillis();
    } catch (ParseException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }

    Log.d("Time away: ", "it is "+time);
    return time;
}

但是当我尝试这个时它会崩溃。

Logcat看起来像:

02-04 16:06:59.343: E/AndroidRuntime(3434): FATAL EXCEPTION: AsyncTask #1
02-04 16:06:59.343: E/AndroidRuntime(3434): Process: com.skateconnect, PID: 3434
02-04 16:06:59.343: E/AndroidRuntime(3434): java.lang.RuntimeException: An error occured while executing doInBackground()
02-04 16:06:59.343: E/AndroidRuntime(3434):     at android.os.AsyncTask$3.done(AsyncTask.java:300)
02-04 16:06:59.343: E/AndroidRuntime(3434):     at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
02-04 16:06:59.343: E/AndroidRuntime(3434):     at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
02-04 16:06:59.343: E/AndroidRuntime(3434):     at java.util.concurrent.FutureTask.run(FutureTask.java:242)
02-04 16:06:59.343: E/AndroidRuntime(3434):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
02-04 16:06:59.343: E/AndroidRuntime(3434):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
02-04 16:06:59.343: E/AndroidRuntime(3434):     at java.lang.Thread.run(Thread.java:841)
02-04 16:06:59.343: E/AndroidRuntime(3434): Caused by: java.lang.ClassCastException: java.util.Date cannot be cast to java.sql.Date
02-04 16:06:59.343: E/AndroidRuntime(3434):     at com.skateconnect.AllSpotsActivity.getTimeAWAY(AllSpotsActivity.java:259)
02-04 16:06:59.343: E/AndroidRuntime(3434):     at com.skateconnect.AllSpotsActivity.access$5(AllSpotsActivity.java:253)
02-04 16:06:59.343: E/AndroidRuntime(3434):     at com.skateconnect.AllSpotsActivity$LoadAllSpots.doInBackground(AllSpotsActivity.java:407)
02-04 16:06:59.343: E/AndroidRuntime(3434):     at com.skateconnect.AllSpotsActivity$LoadAllSpots.doInBackground(AllSpotsActivity.java:1)
02-04 16:06:59.343: E/AndroidRuntime(3434):     at android.os.AsyncTask$2.call(AsyncTask.java:288)
02-04 16:06:59.343: E/AndroidRuntime(3434):     at java.util.concurrent.FutureTask.run(FutureTask.java:237)
02-04 16:06:59.343: E/AndroidRuntime(3434):     ... 3 more
02-04 16:07:00.056: E/WindowManager(3434): android.view.WindowLeaked: Activity com.skateconnect.AllSpotsActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView{420f8430 V.E..... R.....ID 0,0-684,192} that was originally added here
02-04 16:07:00.056: E/WindowManager(3434):  at android.view.ViewRootImpl.<init>(ViewRootImpl.java:374)
02-04 16:07:00.056: E/WindowManager(3434):  at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:248)
02-04 16:07:00.056: E/WindowManager(3434):  at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:69)
02-04 16:07:00.056: E/WindowManager(3434):  at android.app.Dialog.show(Dialog.java:286)
02-04 16:07:00.056: E/WindowManager(3434):  at com.skateconnect.AllSpotsActivity$LoadAllSpots.onPreExecute(AllSpotsActivity.java:333)
02-04 16:07:00.056: E/WindowManager(3434):  at android.os.AsyncTask.executeOnExecutor(AsyncTask.java:587)
02-04 16:07:00.056: E/WindowManager(3434):  at android.os.AsyncTask.execute(AsyncTask.java:535)
02-04 16:07:00.056: E/WindowManager(3434):  at com.skateconnect.AllSpotsActivity$3.onClick(AllSpotsActivity.java:235)
02-04 16:07:00.056: E/WindowManager(3434):  at android.view.View.performClick(View.java:4452)
02-04 16:07:00.056: E/WindowManager(3434):  at android.view.View$PerformClick.run(View.java:18498)
02-04 16:07:00.056: E/WindowManager(3434):  at android.os.Handler.handleCallback(Handler.java:733)
02-04 16:07:00.056: E/WindowManager(3434):  at android.os.Handler.dispatchMessage(Handler.java:95)
02-04 16:07:00.056: E/WindowManager(3434):  at android.os.Looper.loop(Looper.java:137)
02-04 16:07:00.056: E/WindowManager(3434):  at android.app.ActivityThread.main(ActivityThread.java:5083)
02-04 16:07:00.056: E/WindowManager(3434):  at java.lang.reflect.Method.invokeNative(Native Method)
02-04 16:07:00.056: E/WindowManager(3434):  at java.lang.reflect.Method.invoke(Method.java:515)
02-04 16:07:00.056: E/WindowManager(3434):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777)
02-04 16:07:00.056: E/WindowManager(3434):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593)
02-04 16:07:00.056: E/WindowManager(3434):  at dalvik.system.NativeStart.main(Native Method)

似乎第259行是使它崩溃的行,除非我正在读取logcat错误。

有人可以帮助我吗?

谢谢,

泰勒

3 个答案:

答案 0 :(得分:1)

这里有两个日期类型,使用相同的短名称:Date

一个是java.util.Date,另一个是java.sql.Date

这是问题所在。

您从解析中收到java.util.Date,并且您正尝试将其转换为java.sql.Date

答案 1 :(得分:1)

你输入错了。检查类代码顶部的Import子句,并将sql.Date更改为java.util.Date

答案 2 :(得分:1)

您使用了错误的导入,您应该使用java.util.Date

相关问题