我是android编程的新手,所以请和我一起裸照。我有一个问题,与日期比较。我有一个来自TextView的日期(通常存储在SQLite文本字段中)。 TextView rowduedate携带一个日期,其值为:“2012/10/01 15:16” 如果我对我在下面粘贴的代码进行了注释,它会正常工作,并显示R.id.rowduedate。所以它不是空的。但是我得到的logcat中出现以下错误:如何将日期TextView转换为长与当前日期进行比较
11-01 15:16:55.445: E/AndroidRuntime(783): FATAL EXCEPTION: main
11-01 15:16:55.445: E/AndroidRuntime(783): java.lang.NumberFormatException: Invalid long: ""
11-01 15:16:55.445: E/AndroidRuntime(783): at java.lang.Long.invalidLong(Long.java:125)
11-01 15:16:55.445: E/AndroidRuntime(783): at java.lang.Long.parseLong(Long.java:346)
11-01 15:16:55.445: E/AndroidRuntime(783): at java.lang.Long.parseLong(Long.java:319)
11-01 15:16:55.445: E/AndroidRuntime(783): at com.android.demo.notepad3.Notepadv3$1.setViewValue(Notepadv3.java:100)
这是代码:
TextView dueDate = (TextView) view.findViewById(R.id.rowduedate);
String due = (String) dueDate.getText().toString();
if(due!=null){
Long longDue = Long.parseLong(due);
String now = new Date().toString();
Long longNow = Long.parseLong(now);
if(longDue <= longNow){
dueDate.setTextColor(Color.RED);
}
}
希望有人能帮助我在正确的轨道上。
谢谢。