首页 > 解决方案 > 如何修复“java.lang.NumberFormatException:无效浮点数:“16.0dip””

问题描述

我正在将 BooksAdapter 中的数据解析为 BookDetailActivity,但NumberFormatException: Invalid float: 16.0dip我的 logcat 中出现错误。

我已经在线搜索了错误,但我只得到了 3 个没有帮助的搜索结果。

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

    Book book = getIntent().getParcelableExtra("Book");
}

'BooksAdapter'
@Override
    public void onClick(View v) {
        int position = getAdapterPosition();
        Book selectedBook = books.get(position);
        Intent intent = new Intent(v.getContext(), BookDetail.class);
        intent.putExtra("Book", selectedBook);
        v.getContext().startActivity(intent);
    }

我希望在用户单击 RecyclerView 中的项目后启动 BookDetailActivity。相反,应用程序崩溃了。

(java;no:11 from logcat) = setContentView(R.layout.activity_book_detail);

来自日志猫的错误是:  

java.lang.RuntimeException:无法启动活动 ComponentInfo{www.frank.books/www.frank.books.BookDetail}:java.lang.NumberFormatException:无效浮点:android.app.ActivityThread.performLaunchActivity 处的“16.0dip”(ActivityThread .java:2429) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2493) 在 android.app.ActivityThread.access$800(ActivityThread.java:166) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java :1283) 在 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.os.Looper.loop(Looper.java:136) 在 android.app.ActivityThread.main(ActivityThread.java:5590) 在 java .lang.reflect.Method.invokeNative(Native Method) 在 java.lang.reflect.Method.invoke(Method.java:515) 在 com.android。internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1280) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1096) at dalvik.system.NativeStart.main(Native Method) 原因: java.lang.NumberFormatException:无效浮点数:java.lang.StringToReal.invalidReal(StringToReal.java:63) 处 java.lang.StringToReal.parseFloat(StringToReal.java:310) 处 java.lang.Float 处的“16.0dip”。 parseFloat(Float.java:300) 在 android.content.res.TypedArray.getFloat(TypedArray.java:300) 在 android.support.constraint.ConstraintLayout$LayoutParams.(ConstraintLayout.java:2822) 在 android.support.constraint。 ConstraintLayout.generateLayoutParams(ConstraintLayout.java:1972) 在 android.support.constraint.ConstraintLayout.generateLayoutParams(ConstraintLayout.java:482) 在 android.view.LayoutInflater.rInflate(LayoutInflater.java:770) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:499) 在 android.view.LayoutInflater.inflate(LayoutInflater.java:398) 在android.view.LayoutInflater.inflate(LayoutInflater.java:354) 在 android.support.v7.app.AppCompatDelegateImpl.setContentView(AppCompatDelegateImpl.java:469) 在 android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java: 140) 在 www.frank.books.BookDetail.onCreate(BookDetail.java:11) 在 android.app.Activity.performCreate(Activity.java:5447) 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1094) 在android.app 上的 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2393)。ActivityThread.handleLaunchActivity(ActivityThread.java:2493) 在 android.os.Handler 的 android.app.ActivityThread.access$800(ActivityThread.java:166) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1283)。 dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:136) at android.app.ActivityThread.main(ActivityThread.java:5590) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:515) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1280) at com.android.internal.os.ZygoteInit .main(ZygoteInit.java:1096) 在 dalvik.system.NativeStart.main(Native 方法)ActivityThread.access$800(ActivityThread.java:166) 在 android.os.Looper 的 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1283)。在 java.lang.reflect.Method.invokeNative(Native Method) 在 java.lang.reflect.Method.invoke(Method. java:515) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1280) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1096) 在 dalvik.system.NativeStart .main(本机方法)ActivityThread.access$800(ActivityThread.java:166) 在 android.os.Looper 的 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1283)。在 java.lang.reflect.Method.invokeNative(Native Method) 在 java.lang.reflect.Method.invoke(Method. java:515) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1280) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1096) 在 dalvik.system.NativeStart .main(本机方法)dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:136) at android.app.ActivityThread.main(ActivityThread.java:5590) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:515) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1280) at com.android.internal.os.ZygoteInit .main(ZygoteInit.java:1096) 在 dalvik.system.NativeStart.main(Native 方法)dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:136) at android.app.ActivityThread.main(ActivityThread.java:5590) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:515) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1280) at com.android.internal.os.ZygoteInit .main(ZygoteInit.java:1096) 在 dalvik.system.NativeStart.main(Native 方法)ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1280) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1096) 在 dalvik.system.NativeStart.main(Native Method)ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1280) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1096) 在 dalvik.system.NativeStart.main(Native Method)

  [1]: https://i.stack.imgur.com/DZoCS.png


book_detail.xml

    <?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".BookDetail">

    <ImageView
        android:id="@+id/imgCover"
        android:layout_width="163dp"
        android:layout_height="184dp"
        android:layout_marginTop="@dimen/standard_margin"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/tvAuthors"
        app:srcCompat="@drawable/book_open"
        android:contentDescription="@string/todo"
        android:layout_marginStart="@dimen/standard_margin"/>

    <TextView
        android:id="@+id/tvTitle"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="@dimen/standard_margin"
        android:layout_marginTop="@dimen/standard_margin"
        android:layout_marginEnd="@dimen/standard_margin"
        android:text="@string/tv_title"
        android:textSize="36sp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <TextView
        android:id="@+id/tvAuthors"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="@dimen/standard_margin"
        android:layout_marginTop="@dimen/standard_margin"
        android:layout_marginEnd="@dimen/standard_margin"
        android:text="@string/tv_subtitle"
        android:textSize="24sp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/tvTitle" />

    <TextView
        android:id="@+id/tv_authors"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="@dimen/standard_margin"
        android:layout_marginTop="@dimen/standard_margin"
        android:text="@string/tv_author"
        android:textSize="18sp"
        app:layout_constraintStart_toEndOf="@+id/imgCover"
        app:layout_constraintTop_toBottomOf="@+id/tvAuthors" />

    <TextView
        android:id="@+id/tvPublisher"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="@dimen/standard_margin"
        android:layout_marginTop="@dimen/standard_margin"
        android:text="@string/tv_publisher"
        android:textSize="16sp"
        app:layout_constraintStart_toEndOf="@+id/imgCover"
        app:layout_constraintTop_toBottomOf="@+id/tv_authors" />

    <TextView
        android:id="@+id/tvPublishedDate"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="@dimen/standard_margin"
        android:layout_marginTop="@dimen/standard_margin"
        android:text="@string/tv_pub_date"
        android:textSize="16sp"
        app:layout_constraintStart_toEndOf="@+id/imgCover"
        app:layout_constraintTop_toBottomOf="@+id/tvPublisher" />

    <TextView
        android:id="@+id/textView6"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textSize="16sp"
        android:layout_marginStart="@dimen/standard_margin"
        android:layout_marginTop="@dimen/standard_margin"
        android:layout_marginEnd="@dimen/standard_margin"
        android:text="@string/tv_detail"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="@dimen/standard_margin"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/imgCover" />
</android.support.constraint.ConstraintLayout>

dimens.xml

    <?xml version="1.0" encoding="utf-8"?>
<resources>
    <dimen name="title_size">20sp</dimen>
    <dimen name="authors_size">18sp</dimen>
    <dimen name="published_date_padding">8dp</dimen>
    <dimen name="standard_margin">16dp</dimen>
</resources>

标签: androidandroid-debug

解决方案


结帐这条路线: at java.lang.StringToReal.invalidReal(StringToReal.java:63)它说第StringToReal63 行的课程有问题。

我认为您已将一个值为16.0dpto float 的字符串强制转换为无效。

首先使用以下方法清除dp它:

String a = "16.0dp";
Strign newA = a.replace("dp", "");

然后尝试投射它。

但是由于这不是您要更改的来源,因此您应该检查在哪里给出了输出。检查您dimens.xml并查看您在哪里使用了无效值。


推荐阅读