Caused by: libcore.io.ErrnoException: open failed: ENOENT (No such file or directory)

來源:互聯網
上載者:User

今天做了一個手機查詢歸屬地的小程式,遇到了一個疑惑,糾結了好久。。後來發現是低級錯誤,吐血。。。。所以把它寫出來分享,希望大家不要犯如此低級的錯誤


報錯提示:Caused by: libcore.io.ErrnoException: open failed: ENOENT (No such file or directory)

11-13 08:26:17.002: W/System.err(4828):  at android.app.ActivityThread.main(ActivityThread.java:4340)
11-13 08:26:17.002: W/System.err(4828):  at java.lang.reflect.Method.invokeNative(Native Method)
11-13 08:26:17.012: W/System.err(4828):  at java.lang.reflect.Method.invoke(Method.java:511)
11-13 08:26:17.062: W/System.err(4828):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
11-13 08:26:17.062: W/System.err(4828):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
11-13 08:26:17.062: W/System.err(4828):  at dalvik.system.NativeStart.main(Native Method)
11-13 08:26:17.161: I/WindowManager(114): createSurface Window{4160d2c0 Toast paused=false}: DRAW NOW PENDING
11-13 08:26:17.261: D/dalvikvm(4828): GC_CONCURRENT freed 276K, 4% free 10034K/10439K, paused 11ms+26ms
11-13 08:28:40.201: W/ThrottleService(114): unable to find stats for iface rmnet0
11-13 08:31:19.921: A/NetworkStats(114): problem reading network stats
11-13 08:31:19.921: A/NetworkStats(114): java.lang.IllegalStateException: problem parsing line: null
11-13 08:31:19.921: A/NetworkStats(114):  at com.android.internal.net.NetworkStatsFactory.readNetworkStatsDetail(NetworkStatsFactory.java:313)
11-13 08:31:19.921: A/NetworkStats(114):  at com.android.server.NetworkManagementService.getNetworkStatsUidDetail(NetworkManagementService.java:1271)
11-13 08:31:19.921: A/NetworkStats(114):  at com.android.server.net.NetworkStatsService.performPollLocked(NetworkStatsService.java:810)
11-13 08:31:19.921: A/NetworkStats(114):  at com.android.server.net.NetworkStatsService.performPoll(NetworkStatsService.java:771)
11-13 08:31:19.921: A/NetworkStats(114):  at com.android.server.net.NetworkStatsService.access$100(NetworkStatsService.java:128)
11-13 08:31:19.921: A/NetworkStats(114):  at com.android.server.net.NetworkStatsService$3.onReceive(NetworkStatsService.java:610)
11-13 08:31:19.921: A/NetworkStats(114):  at android.app.LoadedApk$ReceiverDispatcher$Args.run(LoadedApk.java:728)
11-13 08:31:19.921: A/NetworkStats(114):  at android.os.Handler.handleCallback(Handler.java:605)
11-13 08:31:19.921: A/NetworkStats(114):  at android.os.Handler.dispatchMessage(Handler.java:92)
11-13 08:31:19.921: A/NetworkStats(114):  at android.os.Looper.loop(Looper.java:137)
11-13 08:31:19.921: A/NetworkStats(114):  at android.os.HandlerThread.run(HandlerThread.java:60)
11-13 08:31:19.921: A/NetworkStats(114): Caused by: java.io.FileNotFoundException: /proc/net/xt_qtaguid/stats: open failed: ENOENT (No such file or directory)
11-13 08:31:19.921: A/NetworkStats(114):  at libcore.io.IoBridge.open(IoBridge.java:406)
11-13 08:31:19.921: A/NetworkStats(114):  at java.io.FileInputStream.<init>(FileInputStream.java:78)
11-13 08:31:19.921: A/NetworkStats(114):  at java.io.FileReader.<init>(FileReader.java:42)
11-13 08:31:19.921: A/NetworkStats(114):  at com.android.internal.net.NetworkStatsFactory.readNetworkStatsDetail(NetworkStatsFactory.java:272)
11-13 08:31:19.921: A/NetworkStats(114):  ... 10 more
11-13 08:31:19.921: A/NetworkStats(114): Caused by: libcore.io.ErrnoException: open failed: ENOENT (No such file or directory)
11-13 08:31:19.921: A/NetworkStats(114):  at libcore.io.Posix.open(Native Method)
11-13 08:31:19.921: A/NetworkStats(114):  at libcore.io.BlockGuardOs.open(BlockGuardOs.java:98)
11-13 08:31:19.921: A/NetworkStats(114):  at libcore.io.IoBridge.open(IoBridge.java:390)
11-13 08:31:19.921: A/NetworkStats(114):  ... 13 more
11-13 08:31:20.211: D/dalvikvm(114): GC_CONCURRENT freed 394K, 10% free 12112K/13383K, paused 26ms+11ms
: E/(): Device disconnected: 1
: E/(): Device disconnected



上網百度了一下,說什麼網路中斷連線沒串連,什麼記憶體不足等等。。。我一一檢查了自己的程式,都不是這些問題。

糾結好久之後,才想起這是串連網路的程式,串連網路都是耗時的。在主線程上面運行耗時的操作時不行的,後來換了2.3的模擬器去運行(2.3模擬器沒有在主線程做是否耗時判斷),結果成功運行了。這樣就確定了問題所在了。


解決辦法 一:

在AndroidManifest.xml中修改uses-sdk
    <uses-sdk
        android:minSdkVersion="8"/>


解決辦法二:把耗時操作放進子線程中


package com.example.webservice;import com.webservice.service.WebServiceRequestFromAndroid;import android.os.Bundle;import android.os.Handler;import android.os.Message;import android.app.Activity;import android.view.Menu;import android.view.View;import android.view.View.OnClickListener;import android.widget.Button;import android.widget.EditText;import android.widget.TextView;import android.widget.Toast;public class MainActivity extends Activity { private Button button = null; private EditText phone = null; private static TextView resultText = null;  private final int SUCCESS=1; private final int ERROR=1; private String result;  private Handler handler = new Handler(){  @Override  public void handleMessage(Message msg) {   if(msg.what==SUCCESS){    String r = (String) msg.obj;    resultText.setText(r);   }else if(msg.what==ERROR){    Toast.makeText(MainActivity.this, "伺服器繁忙", 2).show();   }  }   }; @Override protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(R.layout.activity_main);    button=(Button) findViewById(R.id.button);  phone=(EditText) findViewById(R.id.phonenum);  resultText = (TextView) findViewById(R.id.result);    button.setOnClickListener(new OnClickListener() {      @Override   public void onClick(View v) {    final String phoneNum = phone.getText().toString();    if(!phoneNum.equals("")){     new Thread(){      public void run(){       try {        result = WebServiceRequestFromAndroid.getAddress(phoneNum); //這代碼訪問了網路,是耗時操作。所以把它放進子線程中        Message msg = new Message();        msg.what=SUCCESS;        msg.obj=result;        handler.sendMessage(msg);       } catch (Exception e) {        Message msg = new Message();        msg.what=ERROR;        handler.sendMessage(msg);               }      }     }.start();    }else{     Toast.makeText(MainActivity.this, "請輸入手機號", 2).show();    }       }  }); }}


聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.