有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

运行程序时java ClassNotFoundException

我不知道为什么每当我试图运行我的地图应用程序时,它都会出现以下错误。 日志如下

07-21 12:03:55.427 21046-21046/com.dutt.rishabh.locator E/AndroidRuntime:    FATAL EXCEPTION: main
Process: com.dutt.rishabh.locator, PID: 21046
java.lang.RuntimeException: Unable to get provider   com.google.firebase.provider.FirebaseInitProvider:   java.lang.ClassNotFoundException: Didn't find class   "com.google.firebase.provider.FirebaseInitProvider" on path: DexPathList[[zip  file "/data/app/com.dutt.rishabh.locator-2.apk"],nativeLibraryDirectories= [/data/app-lib/com.dutt.rishabh.locator-2, /vendor/lib, /system/lib]]
 at   安卓.app.ActivityThread.installProvider(ActivityThread.java:5064)
 at 安卓.app.ActivityThread.installContentProviders(ActivityThread.java:4635)
 at 安卓.app.ActivityThread.handleBindApplication(ActivityThread.java:4575)
 at 安卓.app.ActivityThread.access$1600(ActivityThread.java:151)
 at 安卓.app.ActivityThread$H.handleMessage(ActivityThread.java:1414)
 at 安卓.os.Handler.dispatchMessage(Handler.java:110)
 at 安卓.os.Looper.loop(Looper.java:193)
 at 安卓.app.ActivityThread.main(ActivityThread.java:5345)
 at java.lang.reflect.Method.invokeNative(Native Method)
 at java.lang.reflect.Method.invoke(Method.java:515)
 at com.安卓.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:828)
 at com.安卓.internal.os.ZygoteInit.main(ZygoteInit.java:644)
 at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.firebase.provider.FirebaseInitProvider" on path: DexPathList[[zip file "/data/app/com.dutt.rishabh.locator-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.dutt.rishabh.locator-2, /vendor/lib, /system/lib]]
 at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
 at java.lang.ClassLoader.loadClass(ClassLoader.java:497)
 at java.lang.ClassLoader.loadClass(ClassLoader.java:457)
 at 安卓.app.ActivityThread.installProvider(ActivityThread.java:5049)
 at 安卓.app.ActivityThread.installContentProviders(ActivityThread.java:4635) 
 at 安卓.app.ActivityThread.handleBindApplication(ActivityThread.java:4575) 
 at 安卓.app.ActivityThread.access$1600(ActivityThread.java:151) 
 at 安卓.app.ActivityThread$H.handleMessage(ActivityThread.java:1414) 
 at 安卓.os.Handler.dispatchMessage(Handler.java:110) 
 at 安卓.os.Looper.loop(Looper.java:193) 
 at 安卓.app.ActivityThread.main(ActivityThread.java:5345) 
 at java.lang.reflect.Method.invokeNative(Native Method) 
 at java.lang.reflect.Method.invoke(Method.java:515) 
 at com.安卓.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:828) 
 at com.安卓.internal.os.ZygoteInit.main(ZygoteInit.java:644) 
 at dalvik.system.NativeStart.main(Native Method) 

源代码是

package com.dutt.rishabh.locator;

import 安卓.support.v4.app.FragmentActivity;
import 安卓.os.Bundle;

import com.google.安卓.gms.maps.CameraUpdateFactory;
import com.google.安卓.gms.maps.GoogleMap;
import com.google.安卓.gms.maps.OnMapReadyCallback;
import com.google.安卓.gms.maps.SupportMapFragment;
import com.google.安卓.gms.maps.model.LatLng; 
import com.google.安卓.gms.maps.model.MarkerOptions;

public class MapsActivity extends FragmentActivity implements OnMapReadyCallback {

    private GoogleMap mMap;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_maps);
        // Obtain the SupportMapFragment and get notified when the map is ready to be used.
        SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
                .findFragmentById(R.id.map);
        mapFragment.getMapAsync(this);
    }


    @Override
    public void onMapReady(GoogleMap googleMap) {
        mMap = googleMap;

        // Add a marker in Sydney and move the camera
        LatLng sydney = new LatLng(-34, 151);
        mMap.addMarker(new MarkerOptions().position(sydney).title("Marker in Sydney"));
        mMap.moveCamera(CameraUpdateFactory.newLatLng(sydney));
    }
}

渐变生成文件

    apply plugin: 'com.安卓.application'

安卓 {
    compileSdkVersion 24
    buildToolsVersion "24.0.0"
    defaultConfig {
        applicationId "com.dutt.rishabh.locator"
        minSdkVersion 15
        targetSdkVersion 24
        multiDexEnabled true
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner   "安卓.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-安卓.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    安卓TestCompile('com.安卓.support.test.espresso:espresso-core:2.2.2', {
        exclude group: 'com.安卓.support', module: 'support-annotations'
    })
    compile 'com.安卓.support:appcompat-v7:24.0.0'
    compile 'com.google.安卓.gms:play-services:9.2.0'
    testCompile 'junit:junit:4.12'
}

这是我的应用程序,但它总是给出上面提到的错误。需要帮助时请帮忙! 上述问题已解决,但现在出现以下错误

07-21 12:32:20.223 26903-26903/com.dutt.rishabh.locator E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.dutt.rishabh.locator, PID: 26903
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.dutt.rishabh.locator/com.dutt.rishabh.locator.MapsActivity}: 安卓.view.InflateException: Binary XML file line #4: Error inflating class fragment
    at 安卓.app.ActivityThread.performLaunchActivity(ActivityThread.java:2389)
    at 安卓.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2441)
    at 安卓.app.ActivityThread.access$900(ActivityThread.java:151)
    at 安卓.app.ActivityThread$H.handleMessage(ActivityThread.java:1354)
    at 安卓.os.Handler.dispatchMessage(Handler.java:110)
    at 安卓.os.Looper.loop(Looper.java:193)
    at 安卓.app.ActivityThread.main(ActivityThread.java:5345)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:515)
    at com.安卓.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:828)
    at com.安卓.internal.os.ZygoteInit.main(ZygoteInit.java:644)
    at dalvik.system.NativeStart.main(Native Method)
 Caused by: 安卓.view.InflateException: Binary XML file line #4: Error inflating class fragment
    at 安卓.view.LayoutInflater.createViewFromTag(LayoutInflater.java:713)
    at 安卓.view.LayoutInflater.rInflate(LayoutInflater.java:755)
    at 安卓.view.LayoutInflater.inflate(LayoutInflater.java:492)
    at 安卓.view.LayoutInflater.inflate(LayoutInflater.java:397)
    at 安卓.view.LayoutInflater.inflate(LayoutInflater.java:353)
    at com.安卓.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:341)
    at 安卓.app.Activity.setContentView(Activity.java:1948)
    at com.dutt.rishabh.locator.MapsActivity.onCreate(MapsActivity.java:20)
    at 安卓.app.Activity.performCreate(Activity.java:5343)
    at 安卓.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1088)
    at 安卓.app.ActivityThread.performLaunchActivity(ActivityThread.java:2343)
    at 安卓.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2441) 
    at 安卓.app.ActivityThread.access$900(ActivityThread.java:151) 
    at 安卓.app.ActivityThread$H.handleMessage(ActivityThread.java:1354) 
    at 安卓.os.Handler.dispatchMessage(Handler.java:110) 
    at 安卓.os.Looper.loop(Looper.java:193) 
    at 安卓.app.ActivityThread.main(ActivityThread.java:5345) 
    at java.lang.reflect.Method.invokeNative(Native Method) 
    at java.lang.reflect.Method.invoke(Method.java:515) 
    at com.安卓.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:828) 
    at com.安卓.internal.os.ZygoteInit.main(ZygoteInit.java:644) 
    at dalvik.system.NativeStart.main(Native Method) 
 Caused by: java.lang.NullPointerException: name == null
    at java.lang.VMClassLoader.findLoadedClass(Native Method)
    at java.lang.ClassLoader.findLoadedClass(ClassLoader.java:350)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:487)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:457)
    at 安卓.support.v4.app.Fragment.isSupportFragmentClass(Fragment.java:464)
    at 安卓.support.v4.app.FragmentManagerImpl.onCreateView(FragmentManager.java:2373)
    at 安卓.support.v4.app.FragmentController.onCreateView(FragmentController.java:120)
    at 安卓.support.v4.app.FragmentActivity.dispatchFragmentsOnCreateView(FragmentActivity.java:374)
    at 安卓.support.v4.app.BaseFragmentActivityHoneycomb.onCreateView(BaseFragmentActivityHoneycomb.java:33)
    at 安卓.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:75)
    at 安卓.view.LayoutInflater.createViewFromTag(LayoutInflater.java:689)
    at 安卓.view.LayoutInflater.rInflate(LayoutInflater.java:755) 
    at 安卓.view.LayoutInflater.inflate(LayoutInflater.java:492) 
    at 安卓.view.LayoutInflater.inflate(LayoutInflater.java:397) 
    at 安卓.view.LayoutInflater.inflate(LayoutInflater.java:353) 
    at com.安卓.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:341) 
    at 安卓.app.Activity.setContentView(Activity.java:1948) 
    at com.dutt.rishabh.locator.MapsActivity.onCreate(MapsActivity.java:20) 
    at 安卓.app.Activity.performCreate(Activity.java:5343) 
    at 安卓.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1088) 
    at 安卓.app.ActivityThread.performLaunchActivity(ActivityThread.java:2343) 
    at 安卓.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2441) 
    at 安卓.app.ActivityThread.access$900(ActivityThread.java:151) 
    at 安卓.app.ActivityThread$H.handleMessage(ActivityThread.java:1354) 
    at 安卓.os.Handler.dispatchMessage(Handler.java:110) 
    at 安卓.os.Looper.loop(Looper.java:193) 
    at 安卓.app.ActivityThread.main(ActivityThread.java:5345) 
    at java.lang.reflect.Method.invokeNative(Native Method) 
    at java.lang.reflect.Method.invoke(Method.java:515) 
    at com.安卓.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:828) 
    at com.安卓.internal.os.ZygoteInit.main(ZygoteInit.java:644) 
    at dalvik.system.NativeStart.main(Native Method) 

XML文件是

<LinearLayout xmlns:安卓="http://schemas.安卓.com/apk/res/安卓"
    安卓:layout_height="match_parent"
    安卓:layout_width="match_parent">
<fragment xmlns:安卓="http://schemas.安卓.com/apk/res/安卓"
    xmlns:map="http://schemas.安卓.com/apk/res-auto"
    xmlns:tools="http://schemas.安卓.com/tools"
    安卓:id="@+id/map"
    安卓:layout_width="match_parent"
    安卓:layout_height="match_parent"
    tools:context="com.dutt.rishabh.locator.MapsActivity" />
</LinearLayout> 

在这种情况下,请帮忙


共 (2) 个答案

  1. # 1 楼答案

    作为在Android应用程序中启用Google API或Firebase服务的一部分,您可能需要将google-services插件添加到根版本中。gradle文件:

    dependencies {
        classpath 'com.google.gms:google-services:3.0.0'
        // ...
    }
    

    然后在应用程序/构建的底部。格雷德尔补充道:

    apply plugin: 'com.google.gms.google-services'
    

    更多信息请访问The Google Services Gradle Plugin

  2. # 2 楼答案

    不要包含整个play services库,而是使用您需要的库,我认为替换该行:

    compile 'com.google.android.gms:play-services:9.2.0'
    

    与:

    compile 'com.google.android.gms:play-services-maps:9.2.0'
    

    应该能解决你的问题