編輯:關於android開發
今天接到一個波蘭的客戶說有個APP在英文狀態下一切運行正常,但是當系統語言切換到波蘭語言的時候,程序奔潰了。好吧,又是我來維護。
好吧,先把系統語言切換到波蘭語,切換到波蘭語的方法查看文章
地址:http://blog.csdn.net/ouyang_peng/article/details/50209789
====================================================================================
報錯如下:
D/AndroidRuntime( 9067): Shutting down VM E/AndroidRuntime( 9067): FATAL EXCEPTION: main E/AndroidRuntime( 9067): Process: com.runbo.outdoormeter, PID: 9067 E/AndroidRuntime( 9067): java.lang.NumberFormatException: Invalid float: 1019,35 E/AndroidRuntime( 9067): at java.lang.StringToReal.invalidReal(StringToReal.java:63) E/AndroidRuntime( 9067): at java.lang.StringToReal.initialParse(StringToReal.java:164) E/AndroidRuntime( 9067): at java.lang.StringToReal.parseFloat(StringToReal.java:323) E/AndroidRuntime( 9067): at java.lang.Float.parseFloat(Float.java:306) E/AndroidRuntime( 9067): at java.lang.Float.valueOf(Float.java:343) E/AndroidRuntime( 9067): at com.runbo.outdoormeter.service.DataService.onSensorChanged(DataService.java:66) E/AndroidRuntime( 9067): at android.hardware.SystemSensorManager$SensorEventQueue.dispatchSensorEvent(SystemSensorManager.java:405) E/AndroidRuntime( 9067): at android.os.MessageQueue.nativePollOnce(Native Method) E/AndroidRuntime( 9067): at android.os.MessageQueue.next(MessageQueue.java:148) E/AndroidRuntime( 9067): at android.os.Looper.loop(Looper.java:151) E/AndroidRuntime( 9067): at android.app.ActivityThread.main(ActivityThread.java:5637) E/AndroidRuntime( 9067): at java.lang.reflect.Method.invoke(Native Method) E/AndroidRuntime( 9067): at java.lang.reflect.Method.invoke(Method.java:372) E/AndroidRuntime( 9067): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:959) E/AndroidRuntime( 9067): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:754)好吧,數字格式異常,java.lang.NumberFormatException: Invalid float: 1019,35 ,怎麼浮點型1019.35就變成了1019,35 小數點(.)變成了逗號(“,”)。查看源代碼,代碼如下:
LocationApplication.dangxia_qiya=event.values[0]; Log.i(sensor,senser is running 1.....); float a1=LocationApplication.dangxia_qiya; String aa1=String.format(%.2f,a1); Log.i(sensor,a1=+a1); Log.i(sensor,aa1=+aa1); LocationApplication.dangxia_qiya=Float.valueOf(aa1);
運行時,打印日志:
C:Documents and SettingsAdministrator>adb logcat -s sensor --------- beginning of system --------- beginning of main I/sensor ( 8175): senser is running 1..... I/sensor ( 8175): a1=1019.00757 I/sensor ( 8175): aa1=1019,01
這說明,得到的a1參數是正常的,只是通過String.format方法轉換後,就變成了1019,01。坑爹啊!將系統語言切換為英文,再打印下日志,如下:
C:Documents and SettingsAdministrator>adb logcat -s sensor --------- beginning of system --------- beginning of main I/sensor ( 8648): senser is running 1..... I/sensor ( 8648): a1=1019.01685 I/sensor ( 8648): aa1=1019.02好吧,得到的a1參數是正常的,aa1也是正常的1019.02。
====================================================================================
好吧,看了代碼後,感覺用String.format來格式化浮點型數字真心不給力。這個保留小數點後兩位的問題還是用其他方法來解決吧。將代碼改成下面代碼後一切正常。
LocationApplication.dangxia_qiya=event.values[0]; Log.i(sensor,senser is running 1.....); float a1=LocationApplication.dangxia_qiya; //String aa1=String.format(%.2f,a1); //Log.i(sensor,a1=+a1); //Log.i(sensor,aa1=+aa1); //LocationApplication.dangxia_qiya= Float.valueOf(aa1); float aa1 = (float)(Math.round(a1*100))/100; Log.i(sensor,a1=+a1); Log.i(sensor,aa1=+aa1); LocationApplication.dangxia_qiya=aa1;====================================================================================
不知道String.format()這樣的錯誤,是不是java設計時候的一個缺陷呢?
《第一行代碼》目錄 圖書目錄: 第1章 開始啟程,你的第一行Android代碼 1.1 了解全貌,Android王國簡介 1.1.1 Androi
10個學習Android開發的網站推薦,android網站推薦1. Android Developers 作為一個Android開發者,官網的資料當然不可錯過,
百度地圖開發的學習(一),百度地圖開發學習由於項目需求緣故,最近在學習Android地圖的開發,所以就記錄一下學習過程。最近都會陸續更新啦。目前使用百度地圖API的挺多的
iOS,Android網絡抓包教程之tcpdump 現在的移動端應用幾乎都會通過網絡請求來和服務器交互,通過抓包來診斷和網絡相關的bug是程序員的重要技能之一。抓包的