无法打开日志设备'/ dev / log / main':我的Nexus 4上没有这样的文件或目录

时间:2013-05-23 16:53:39

标签: android logging device main

正如您所看到的,我的问题是:无法打开日志设备'/ dev / log / main':没有这样的文件或目录。我正在编写的应用程序正在测试我的nexus 4.我如何解决问题?

3 个答案:

答案 0 :(得分: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() );
    }

}

答案 1 :(得分:2)

我发现了这个:

  

有一个隐藏的服务菜单,您可以在其中设置登录。该   通过“拨打”此电话号码启动服务菜单:       *#*#2846579#*#*

它对我有用。

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

答案 2 :(得分:0)

拨打该电话号码无法解决问题。

打开一个新命令行(cmd)并编写adb shell insmod /system/lib/modules/logger.ko

它将解决问题。 (三星Galaxy i9070)。