2016-11-25 3 views
-2

Я пытаюсь получить некоторое значение в формате Double с использованием редактируемого текста.Отображение NumberFormat Exception Invalid Double

при преобразовании значения edittext в двойное отображение number precision error.

мой activity.xml:

<EditText 
     android:id="@+id/edit1" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_above="@+id/textView1" 
     android:layout_alignRight="@+id/textView1" 
     android:layout_marginBottom="57dp" 
     android:layout_marginRight="31dp" 
     android:ems="10" 
     android:inputType="number" > 

    </EditText> 

и мой mainactivity код я пытался

извлечь значение из EditText как двойной, но показывая

NumberFormatException Invalid Double:

package com.example.habijabi; 

import android.os.Bundle; 
import android.app.Activity; 
import android.view.Menu; 
import android.widget.EditText; 
import android.widget.TextView; 

public class MainActivity extends Activity { 

    EditText et,et1; 
    TextView t; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_main); 


     et=(EditText)findViewById(R.id.edit1); 
     String s=et.getText().toString(); 
     double data; 
     data=Double.parseDouble(s); 
     System.out.println(s); 



    } 


} 

Показаны это в LogCat:

11-25 14:07:13.386: I/Process(1105): Sending signal. PID: 1105 SIG: 9 
11-25 14:07:14.797: W/Trace(1170): Unexpected value from nativeGetEnabledTags: 0 
11-25 14:07:14.797: W/Trace(1170): Unexpected value from nativeGetEnabledTags: 0 
11-25 14:07:14.906: W/Trace(1170): Unexpected value from nativeGetEnabledTags: 0 
11-25 14:07:14.906: W/Trace(1170): Unexpected value from nativeGetEnabledTags: 0 
11-25 14:07:15.256: D/AndroidRuntime(1170): Shutting down VM 
11-25 14:07:15.256: W/dalvikvm(1170): threadid=1: thread exiting with uncaught exception (group=0x40a70930) 
11-25 14:07:15.286: E/AndroidRuntime(1170): FATAL EXCEPTION: main 
11-25 14:07:15.286: E/AndroidRuntime(1170): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.habijabi/com.example.habijabi.MainActivity}: java.lang.NumberFormatException: Invalid double: "" 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at android.app.ActivityThread.access$600(ActivityThread.java:141) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at android.os.Handler.dispatchMessage(Handler.java:99) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at android.os.Looper.loop(Looper.java:137) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at android.app.ActivityThread.main(ActivityThread.java:5039) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at java.lang.reflect.Method.invokeNative(Native Method) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at java.lang.reflect.Method.invoke(Method.java:511) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at dalvik.system.NativeStart.main(Native Method) 
11-25 14:07:15.286: E/AndroidRuntime(1170): Caused by: java.lang.NumberFormatException: Invalid double: "" 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at java.lang.StringToReal.invalidReal(StringToReal.java:63) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at java.lang.StringToReal.parseDouble(StringToReal.java:248) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at java.lang.Double.parseDouble(Double.java:295) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at com.example.habijabi.MainActivity.onCreate(MainActivity.java:27) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at android.app.Activity.performCreate(Activity.java:5104) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144) 
11-25 14:07:15.286: E/AndroidRuntime(1170):  ... 11 more 
+0

Добавить StackTrace – Jens

+1

Прочитайте исключение в следующий раз;) ** java.lang.NumberFormatException: Invalid двойное: «» ** – AxelH

ответ

2

Причина заключается в том, что "" не является допустимым в два раза. Вам необходимо проверить строку перед или поймать такие исключения

double data; 

try { 
    data = new Double(et.getText().toString()); 
} catch (NumberFormatException e) { 
    data = 0; // your default value 
} 

важный момент: Добавить try and catch когда вы бросаете что-нибудь.

+0

Важные советы, создать UtilityParse попробовать или вернуть значение по умолчанию, как 'parseDouble (строковое значение , Двойной по умолчанию) ' – AxelH

+0

Изменение на это, но все еще отображается ошибка: https: //pastebin.ubuntu.com/23532423/ – ashik

Смежные вопросы