Java 在linux mint的Filereader中,Im获取文件未找到异常

Java 在linux mint的Filereader中,Im获取文件未找到异常,java,android,json,filereader,Java,Android,Json,Filereader,代码如下: package com.example.def5ine; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); FileReader fileReader; try { Log.d("dd", "msg");

代码如下:

package com.example.def5ine;

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

    FileReader fileReader;
    try {
        Log.d("dd", "msg");
        //FileReader("/home/likewise-open/vigneshwaranm/workspace/java/src/example/dictionary.json")

        fileReader = new FileReader("/android_asset/dictionary.json");
        jsonReader = new JsonReader(fileReader);
         jsonReader.beginObject();

    } catch (Exception e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }

    Button srch=(Button)findViewById(R.id.button1);
    final TextView res=(TextView)findViewById(R.id.textView1);
    srch.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            // TODO Auto-generated method stub
            try {
                while (jsonReader.hasNext()) {
                    String name = jsonReader.nextName();
                    if (name.equals("domain")) {
                        res.setText("ss");
                    } else {
                        jsonReader.skipValue();
                        res.setText("fail");
                    }
                }
                jsonReader.endObject();
                jsonReader.close();
            } catch (IOException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
    }); 
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
}
日志Cat输出:

12-12 07:12:26.600: D/dd(1359): msg
<b>12-12 07:12:26.600: W/System.err(1359): java.io.FileNotFoundException: /android_asset/dictionary.json: open failed: ENOENT (No such file or directory)
12-12 07:12:26.610: W/System.err(1359):     at </b>libcore.io.IoBridge.open(IoBridge.java:409)
12-12 07:12:26.610: W/System.err(1359):     at java.io.FileInputStream.<init>(FileInputStream.java:78)
12-12 07:12:26.610: W/System.err(1359):     at java.io.FileInputStream.<init>(FileInputStream.java:105)
12-12 07:12:26.610: W/System.err(1359):     at java.io.FileReader.<init>(FileReader.java:66)
12-12 07:12:26.620: W/System.err(1359):     at com.example.def5ine.MainActivity.onCreate(MainActivity.java:30)
12-12 07:12:26.620: W/System.err(1359):     at android.app.Activity.performCreate(Activity.java:5243)
12-12 07:12:26.620: W/System.err(1359):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
12-12 07:12:26.620: W/System.err(1359):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2140)
12-12 07:12:26.620: W/System.err(1359):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2226)
12-12 07:12:26.620: W/System.err(1359):     at android.app.ActivityThread.access$700(ActivityThread.java:135)
12-12 07:12:26.620: W/System.err(1359):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1397)
12-12 07:12:26.620: W/System.err(1359):     at android.os.Handler.dispatchMessage(Handler.java:102)
12-12 07:12:26.620: W/System.err(1359):     at android.os.Looper.loop(Looper.java:137)
12-12 07:12:26.620: W/System.err(1359):     at android.app.ActivityThread.main(ActivityThread.java:4998)
12-12 07:12:26.620: W/System.err(1359):     at java.lang.reflect.Method.invokeNative(Native Method)
12-12 07:12:26.620: W/System.err(1359):     at java.lang.reflect.Method.invoke(Method.java:515)
12-12 07:12:26.620: W/System.err(1359):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777)
12-12 07:12:26.620: W/System.err(1359):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593)
12-12 07:12:26.620: W/System.err(1359):     at dalvik.system.NativeStart.main(Native Method)
12-12 07:12:26.620: W/System.err(1359): Caused by: libcore.io.ErrnoException: open failed: ENOENT (No such file or directory)
12-12 07:12:26.640: W/System.err(1359):     at libcore.io.Posix.open(Native Method)
12-12 07:12:26.640: W/System.err(1359):     at libcore.io.BlockGuardOs.open(BlockGuardOs.java:110)
12-12 07:12:26.640: W/System.err(1359):     at libcore.io.IoBridge.open(IoBridge.java:393)
12-12 07:12:26.640: W/System.err(1359):     ... 18 more
12-12 07:12:26.900: D/(1359): HostConnection::get() New Host Connection established 0xb85fd238, tid 1359
12-12 07:12:26.950: W/EGL_emulation(1359): eglSurfaceAttrib not implemented
12-12 07:12:26.960: D/OpenGLRenderer(1359): Enabling debug mode 0
12-12 07:12:27.140: W/IInputConnectionWrapper(1359): showStatusIcon on inactive InputConnection
12-12 07:12:51.980: D/AndroidRuntime(1359): Shutting down VM
12-12 07:12:51.980: W/dalvikvm(1359): threadid=1: thread exiting with uncaught exception (group=0xb4a5bb90)
12-12 07:12:51.990: E/AndroidRuntime(1359): FATAL EXCEPTION: main
12-12 07:12:51.990: E/AndroidRuntime(1359): Process: com.example.def5ine, PID: 1359
12-12 07:12:51.990: E/AndroidRuntime(1359): java.lang.NullPointerException
12-12 07:12:51.990: E/AndroidRuntime(1359):     at com.example.def5ine.MainActivity$1.onClick(MainActivity.java:46)
12-12 07:12:51.990: E/AndroidRuntime(1359):     at android.view.View.performClick(View.java:4424)
12-12 07:12:51.990: E/AndroidRuntime(1359):     at android.view.View$PerformClick.run(View.java:18383)
12-12 07:12:51.990: E/AndroidRuntime(1359):     at android.os.Handler.handleCallback(Handler.java:733)
12-12 07:12:51.990: E/AndroidRuntime(1359):     at android.os.Handler.dispatchMessage(Handler.java:95)
12-12 07:12:51.990: E/AndroidRuntime(1359):     at android.os.Looper.loop(Looper.java:137)
12-12 07:12:51.990: E/AndroidRuntime(1359):     at android.app.ActivityThread.main(ActivityThread.java:4998)
12-12 07:12:51.990: E/AndroidRuntime(1359):     at java.lang.reflect.Method.invokeNative(Native Method)
12-12 07:12:51.990: E/AndroidRuntime(1359):     at java.lang.reflect.Method.invoke(Method.java:515)
12-12 07:12:51.990: E/AndroidRuntime(1359):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777)
12-12 07:12:51.990: E/AndroidRuntime(1359):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593)
12-12 07:12:51.990: E/AndroidRuntime(1359):     at dalvik.system.NativeStart.main(Native Method)
12-12 07:13:03.090: I/Process(1359): Sending signal. PID: 1359 SIG: 9
12-12 07:12:26.600:D/dd(1359):msg
12-12 07:12:26.600:W/System.err(1359):java.io.FileNotFoundException:/android_asset/dictionary.json:open failed:enoint(没有这样的文件或目录)
12-12 07:12:26.610:W/System.err(1359):位于libcore.io.IoBridge.open(IoBridge.java:409)
12-12 07:12:26.610:W/System.err(1359):位于java.io.FileInputStream。(FileInputStream.java:78)
12-12 07:12:26.610:W/System.err(1359):位于java.io.FileInputStream。(FileInputStream.java:105)
12-12 07:12:26.610:W/System.err(1359):位于java.io.FileReader。(FileReader.java:66)
12-12 07:12:26.620:W/System.err(1359):位于com.example.def5ine.MainActivity.onCreate(MainActivity.java:30)
12-12 07:12:26.620:W/System.err(1359):位于android.app.Activity.performCreate(Activity.java:5243)
12-12 07:12:26.620:W/System.err(1359):在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
12-12 07:12:26.620:W/System.err(1359):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2140)
12-12 07:12:26.620:W/System.err(1359):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2226)
12-12 07:12:26.620:W/System.err(1359):在android.app.ActivityThread.access$700(ActivityThread.java:135)
12-12 07:12:26.620:W/System.err(1359):在android.app.ActivityThread$H.handleMessage(ActivityThread.java:1397)
12-12 07:12:26.620:W/System.err(1359):位于android.os.Handler.dispatchMessage(Handler.java:102)
12-12 07:12:26.620:W/System.err(1359):在android.os.Looper.loop(Looper.java:137)
12-12 07:12:26.620:W/System.err(1359):位于android.app.ActivityThread.main(ActivityThread.java:4998)
12-12 07:12:26.620:W/System.err(1359):位于java.lang.reflect.Method.invokenactive(本机方法)
12-12 07:12:26.620:W/System.err(1359):位于java.lang.reflect.Method.invoke(Method.java:515)
12-12 07:12:26.620:W/System.err(1359):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777)
12-12 07:12:26.620:W/System.err(1359):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593)
12-12 07:12:26.620:W/System.err(1359):在dalvik.System.NativeStart.main(本机方法)
12-12 07:12:26.620:W/System.err(1359):由以下原因引起:libcore.io.ErrnoException:open失败:enoint(没有这样的文件或目录)
12-12 07:12:26.640:W/System.err(1359):位于libcore.io.Posix.open(本机方法)
12-12 07:12:26.640:W/System.err(1359):位于libcore.io.BlockGuardOs.open(BlockGuardOs.java:110)
12-12 07:12:26.640:W/System.err(1359):位于libcore.io.IoBridge.open(IoBridge.java:393)
12-12 07:12:26.640:W/系统错误(1359):。。。还有18个
12-12 07:12:26.900:D/(1359):主机连接::get()新主机连接已建立0xb85fd238,tid 1359
12-12 07:12:26.950:W/EGL_仿真(1359):未实现eglSurfaceAttrib
12-12 07:12:26.960:D/OpenGLRenderer(1359):启用调试模式0
12-12 07:12:27.140:W/IIInputConnectionWrapper(1359):在非活动输入连接上显示状态图标
12-12 07:12:51.980:D/AndroidRuntime(1359):关闭虚拟机
12-12 07:12:51.980:W/dalvikvm(1359):threadid=1:线程退出时出现未捕获异常(组=0xb4a5bb90)
12-12 07:12:51.990:E/AndroidRuntime(1359):致命异常:主
12-12 07:12:51.990:E/AndroidRuntime(1359):进程:com.example.def5ine,PID:1359
12-12 07:12:51.990:E/AndroidRuntime(1359):java.lang.NullPointerException
12-12 07:12:51.990:E/AndroidRuntime(1359):在com.example.def5ine.MainActivity$1.onClick(MainActivity.java:46)
12-12 07:12:51.990:E/AndroidRuntime(1359):在android.view.view.performClick(view.java:4424)
12-12 07:12:51.990:E/AndroidRuntime(1359):在android.view.view$PerformClick.run(view.java:18383)
12-12 07:12:51.990:E/AndroidRuntime(1359):在android.os.Handler.handleCallback(Handler.java:733)
12-12 07:12:51.990:E/AndroidRuntime(1359):在android.os.Handler.dispatchMessage(Handler.java:95)上
12-12 07:12:51.990:E/AndroidRuntime(1359):在android.os.Looper.loop(Looper.java:137)
12-12 07:12:51.990:E/AndroidRuntime(1359):位于android.app.ActivityThread.main(ActivityThread.java:4998)
12-12 07:12:51.990:E/AndroidRuntime(1359):位于java.lang.reflect.Method.Invokenactive(本机方法)
12-12 07:12:51.990:E/AndroidRuntime(1359):在java.lang.reflect.Method.invoke(Method.java:515)
12-12 07:12:51.990:E/AndroidRuntime(1359):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777)
12-12 07:12:51.990:E/AndroidRuntime(1359):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593)
12-12 07:12:51.990:E/AndroidRuntime(1359):在dalvik.system.NativeStart.main(本机方法)
12-12 07:13:03.090:I/进程(1359):发送信号。PID:1359信号:9

注意因为这个问题有一些观点,我想这可能会对其他人有所帮助,所以我现在发布我自己问题的答案

要访问资产目录,您必须在目录名前面加前缀文件://:

就我而言:

String pathToMyAssetDirectory="file:///android_asset/dictionary.json";
File file= new File(pathToMyAssetDirectory);
获取资产目录引用的另一个选项是使用应用程序上下文,如下所示:

context.getResources().getAssets().open("fileName", Context.MODE_PRIVATE);

你的问题是?试着给予绝对的尊重path@AniketThakur你肯定想把它放在类路径上吗?你检查过
/android\u asset/dictionary.json
是否存在吗?看起来你已经把绝对路径注释掉了。那不管用吗?文件是否可读(检查权限)?