2

ご覧のとおり、私の問題は次のとおりです。ログデバイス '/dev/log/main' を開けません: そのようなファイルまたはディレクトリはありません。私が書いているアプリケーションは、nexus 4 でテストしています。どうすれば問題を解決できますか?

4

3 に答える 3

2

Jelly Bean では、Google は任意のアプリがシステム/アプリ ログにアクセスするのを防いだため、デバイスがルート化されていない限り、ログ ファイルにもアクセスできません。

http://commonsware.com/blog/2012/07/12/read-logs-regression.htmlを参照してください。

デバイス上でログにアクセスできるようにするために、すべてのデバッグ ログに使用する Logger クラスを作成しました。これは基本的に android.util.Log をラップし、すべての Logger.d 呼び出しを Log.d およびルート ディレクトリ内のファイルに出力します。Android ログに含まれるすべての情報をまだ出力しているわけではありませんが、編集して必要な情報をそこに入れることができます。 時々ファイルをクリアすることを忘れないでください... (: ここにあります:

package com.example.app;

import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;

import android.os.Environment;
import android.util.Log;

public class Logger
{

    private static final String LOGTAG = "Logger";

    // Set to false to remove creation of local file
    private static final boolean IS_DEBUG_MODE = true;

    private static final SimpleDateFormat mSDF = new SimpleDateFormat( "MM-dd hh:mm:ss.SSS" );

    public Logger() {

    }

    public static void d( String tag, String msg ) {
        Log.d( tag, msg );

        writeToFile( tag, msg );
    }

    public static void d( String tag, String msg, Throwable th ) {
        Log.d( tag, msg, th );

        writeToFile( tag, msg, th );
    }

    private static void writeToFile( String tag, String msg ) {

        if( IS_DEBUG_MODE ) {
            File root = Environment.getExternalStorageDirectory();
            File file = new File( root, "appLog.txt" );

            try {
                if( root.canWrite() ) {
                    FileWriter fileWriter = new FileWriter( file, true );
                    BufferedWriter out = new BufferedWriter( fileWriter );

                    Date d = new Date();

                    out.write( mSDF.format( d ) + ": " + tag + " : " + msg );
                    out.newLine();
                    out.close();
                }
            } catch( IOException e ) {
                Log.d( LOGTAG, "Couldn't write file: " + e.getMessage() );
            }
        }
    }

    private static void writeToFile( String tag, String msg, Throwable th ) {
        writeToFile( tag, msg + ", e: " + th.getMessage() );
    }

}
于 2013-05-23T17:14:03.613 に答える
2

私はこれを見つけました:

ログインを設定できる隠しサービスメニューがあります。サービスメニューは、この電話番号を「ダイヤル」することによって開始されます。 *#*#2846579#*#*

それは私のために働いた。

http://www.android-ios-tutorials.com/155/logcat-doesnt-show-messages-error-unable-to-open-log-device/

于 2014-01-30T17:13:41.243 に答える
0

その電話番号をダイヤルしても問題は解決しません。

新しいコマンド ライン (cmd) を開き、 adb shell insmod /system/lib/modules/logger.ko と記述します。

それが問題を解決するということです。(サムスンギャラクシー i9070)。

于 2016-12-16T10:43:41.913 に答える