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

Android 无法打开日志设备'/dev/log/main';:我的Nexus 4上没有这样的文件或目录,android,logging,device,main,Android,Logging,Device,Main,正如您所看到的,我的问题是:无法打开日志设备“/dev/log/main”:没有这样的文件或目录。我正在编写的应用程序正在我的Nexus4上测试。如何解决此问题?在Jelly Bean中,Google阻止任意应用访问系统/应用程序日志,因此除非您的设备已根目录,否则您也无法访问日志文件 看 为了允许在设备上访问日志,我创建了一个用于所有调试日志的Logger类。它基本上包装了android.util.Log,将所有Logger.d调用输出到Log.d和根目录中的一个文件。它还没有输出Androi

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

在Jelly Bean中,Google阻止任意应用访问系统/应用程序日志,因此除非您的设备已根目录,否则您也无法访问日志文件

为了允许在设备上访问日志,我创建了一个用于所有调试日志的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() );
    }

}

在Jelly Bean中,Google阻止任意应用访问系统/应用日志,因此,除非您的设备是根目录,否则您也无法访问日志文件

为了允许在设备上访问日志,我创建了一个用于所有调试日志的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() );
    }

}
我发现:

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

这对我有用

我发现:

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

这对我有用


拨打那个电话号码并不能解决问题

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


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

拨打该电话号码并不能解决问题

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


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

谢谢!但是在MainActivity之前,我必须将此代码放入我的应用程序代码中?只需将其放入另一个名为Logger.java的类文件中,该类文件与MainActivity具有相同的包声明。假设您的包是com.example.app,那么第一行将是
package com.example.app;
,该文件将位于与您的com.example.app.main活动文件的级别相同,即`src/com/example/app/Logger.java'。希望这有帮助!谢谢您:D不再有日志问题..但是我的应用程序崩溃了!:(我认为滑动视图代码是问题所在。不客气!很乐意提供帮助。您是否提出了另一个有关应用程序崩溃的StackOverflow问题?谢谢!但我必须将此代码放入我的应用程序代码中?在MainActivity之前?只需将其放入另一个名为Logger.java的类文件中,并使用与MainActivity。假设您的包是com.example.app,那么第一行将是
package com.example.app;
,并且该文件将位于与您的com.example.app.MainActivity文件相同的级别,即`src/com/example/app/Logger.java'。希望这能有所帮助!谢谢您:D不再有日志问题..但是我的应用程序崩溃了!:(我认为滑动视图代码是问题所在。不客气!很乐意提供帮助。您是否提出了另一个有关应用程序崩溃的StackOverflow问题?可能重复-可能重复-我不相信这再有效了(至少在Android 4.4.4上)其他人能确认它是否有效吗?我不相信这再有效了(至少在安卓4.4.4上)还有其他人能确认它能工作吗?