java.util.Formatter$FormatToken.unknownFormatConversionException(Formatter.java:1399) 的解决办法

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/An_Times/article/details/83652112

网上很多人的都是这样写的,但是我的一直报错:
<string name="delay_time">距离过年还有%1$d天%2$d时%3$d秒</string>
mTextView.setText(String.format(getResources().getString(R.string.delay_time),mDay,mMinute,mSecond));

D/HolaLocalUpdateActivity( 4872): nextBootCommandtime=10
D/AndroidRuntime( 4872): Shutting down VM
E/AndroidRuntime( 4872): FATAL EXCEPTION: main
E/AndroidRuntime( 4872): Process: com.jmgo.update, PID: 4872
E/AndroidRuntime( 4872): java.util.UnknownFormatConversionException: Conversion: $
E/AndroidRuntime( 4872): 	at java.util.Formatter$FormatToken.unknownFormatConversionException(Formatter.java:1399)
E/AndroidRuntime( 4872): 	at java.util.Formatter$FormatToken.checkFlags(Formatter.java:1336)
E/AndroidRuntime( 4872): 	at java.util.Formatter.transform(Formatter.java:1442)
E/AndroidRuntime( 4872): 	at java.util.Formatter.doFormat(Formatter.java:1081)
E/AndroidRuntime( 4872): 	at java.util.Formatter.format(Formatter.java:1042)
E/AndroidRuntime( 4872): 	at java.util.Formatter.format(Formatter.java:1011)
E/AndroidRuntime( 4872): 	at java.lang.String.format(String.java:1803)
E/AndroidRuntime( 4872): 	at java.lang.String.format(String.java:1777)
E/AndroidRuntime( 4872): 	at com.jmgo.update.HolaLocalUpdateActivity$1.handleMessage(HolaLocalUpdateActivity.java:155)
E/AndroidRuntime( 4872): 	at android.os.Handler.dispatchMessage(Handler.java:102)
E/AndroidRuntime( 4872): 	at android.os.Looper.loop(Looper.java:135)
E/AndroidRuntime( 4872): 	at android.app.ActivityThread.main(ActivityThread.java:5257)
E/AndroidRuntime( 4872): 	at java.lang.reflect.Method.invoke(Native Method)
E/AndroidRuntime( 4872): 	at java.lang.reflect.Method.invoke(Method.java:372)
E/AndroidRuntime( 4872): 	at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:955)
E/AndroidRuntime( 4872): 	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:750)
I/Process ( 4872): Sending signal. PID: 4872 SIG: 9
I/ActivityManager( 4095): Process com.jmgo.update (pid 4872) has died

后来我查了framework 里面的源码,源码都是这么写的,例子如下:

mIdString = String.format("Session %d: ", mId);
String tag = String.format("CameraDevice-JV-%s", mCameraId);

后来我改成下面这样就可以了

<string name="set_next_boot_tips" formatted="true">正在设置下次开机升级,请勿在 %d 内关闭电源</string>
 mTextView.setText(String.format(cxt.getResources().getString(R.string.set_next_boot_tips),nextBootCommandtime));

不清楚怎么百度的这么多人都是写成,难道都是copy 来copy去的 ?

<string name="set_next_boot_tips" formatted="true">正在设置下次开机升级,请勿在 %1$d 内关闭电源</string>

,有知道原因的可以评论区告诉我

猜你喜欢

转载自blog.csdn.net/An_Times/article/details/83652112