搜索
查看
编辑修改
首页
UNITY
NODEJS
PYTHON
AI
GIT
PHP
GO
CEF3
JAVA
HTML
CSS
搜索
我家自动化
这个屌丝很懒,什么也没留下!
关注作者
热门标签
jquery
HTML
CSS
PHP
ASP
PYTHON
GO
AI
C
C++
C#
PHOTOSHOP
UNITY
iOS
android
vue
xml
爬虫
SEO
LINUX
WINDOWS
JAVA
MFC
CEF3
CAD
NODEJS
GIT
Pyppeteer
article
热门文章
1
数据结构与算法(九):分治与回溯算法_分治和回溯
2
Vue2系列教程——路由守卫_vue2路由守卫
3
Python——ASCII编码与Unicode(UTF-8,UTF-16 和 UTF-32)编码_python 编码unicode utf-8
4
【夏虫语冰】测试服务器端口是否打开(命令行、Python)_端口测试
5
SSM+汽车销售平台 毕业设计-附源码171619_投诉建议功能模块
6
面试题-项目(各种项目地址汇总),2024年最新java电商面试
7
python毕业设计:基于python的城市轨道交通线路查询系统_地铁查询系统python
8
Unity中Newtonsoft.Json的使用(三)_unity newtonsoft.json jobject
9
unity中鼠标与物体的交互_使用unity设计鼠标点击选中后,物体随鼠标移动,再次点击放置物体的交互。
10
基于深度学习的30种常见的水果识别_水果识别的数据集
当前位置:
article
> 正文
Android中LOG机制详解_android dslog
作者:我家自动化 | 2024-06-07 09:01:09
赞
踩
android dslog
一、简介
Android
中LOG的实现架构如下图所示,这基本上也是Android的某个模块实现各个层次的经典架构。
图1
Android应用程序通过Framework提供的Log类来进行日志的输出;而Log类其实是通过JNI函数来进行日志输出;JNI函数则是调用底层库函数进行日志的输出;然后库函数通过操作映射的设备文件操作设备。
在Linux中,系统其实把LOG作为一种设备处理,并把它映射为文件。因此库函数操作映射的LOG文件,
其实是通过kernel中的
LOG的Driver
完成相应的操作
。
关于Android中LOG实现架构更详细的流程图请参考《
Android LOG机制流程图
》
二、
类android.util.Log
Android的Java程序通过android.util.Log类来输出Log,下图2.1列出了我们常用的Log的静态方法。
图2.1
一般,要输出Log信息,可直接调用
Log.v()/Log.d()/Log.i()/Log.w()/Log.e()
等类方法。这里之所以有这么多有区分的方法,这也是Log的分类。Log的分类就如同Log的静态常量成员定义的那样,而Log的优先级按照数字大小排列,数字大的优先级高。
Log.wtf()
一般用于输出的非常致命的FAULT信息(What a Terrible Failure),报这个错误,不光是在Log里记录,还要在界面上有提示,并可能杀死当前的进程。
它在输出日志的同时,它会把此处代码此时的执行路径(调用栈)打印出来。在调试时,我们可以使用它来打印当前代码的执行栈。
isLoggable()
用于判断是否需要输出日志,
如果日志的tag太长或如果要输出的LOG优先级低于当前设置的优先级,则返回false,表示不用输出该日志
。在Java程序中,用Log的方法打印Log之前,可以先用
isLoggable()
判断一下是否需要,才进行输出日志。
另外,
Log.println()
能达到与
Log.v()/Log.d()/…
等方法同样的输出效果,只是在用它时,要指定对应的优先级。
2.1、类android.util.Log的java实现
类
android.util.Log
的java实现是比较简单的。类
android.util.Log
的构造函数是私有的,并不会被实例化,只是提供了静态的属性和方法。
而
android.util.Log
的各种Log记录方法的实现都依赖于native的实现
println_native()
,
Log.v()/Log.d()/Log.i()/Log.w()/Log.e()
最终都是调用了
println_native()
。如Log.d()的实现:
public static int d(String tag, String msg) {
return println_native(LOG_ID_MAIN, DEBUG, tag, msg);
}
2.2、类android.util.Log的JNI实现
类android.util.Log有两个Native方法,它们通过JNI用c/c++中实现。
public static native boolean
isLoggable(String tag,
int
level);
public static native int
println_native(
int
bufID,int priority, String tag, String msg);
这两个方法是在
frameworks/base/core/jni/android_util_log.cpp
中实现的。这两个方法分别对应下列两个c/c++函数。
static jboolean
android_util_Log_isLoggable(JNIEnv* env, jobject clazz, jstring tag,
jint
level)
static jint
android_util_Log_println_native(JNIEnv* env, jobject clazz,jint bufID, jint priority, jstring tagObj, jstring msgObj)
isLoggable()
的实现是比较<level>(来自参数)与当前property里设定的“log.tag.<tag>”(<tag>来自参数)的level值,大于或等于都是可记录的。程序实现片断如下
:
// LOG_NAMESPACE : “log.tag.”
// chars: convert from param<tag>
strncpy(key, LOG_NAMESPACE, sizeof(LOG_NAMESPACE)-1);
strcpy(key + sizeof(LOG_NAMESPACE) - 1, chars);
//略
len = property_get(key, buf, "");
i
nt logLevel = toLevel(buf);
//略
return (logLevel >= 0 && level >= logLevel) ? true : false;
println_native()
的实现要负责些。关于此最好对比着
《
Android LOG机制流程图
》
来看。
在
android_util.Log.cpp
中,
函数
android_util_Log_println_native()
调用了
Android_log_buf_write()
函数,而
Android_log_buf_write()
又直接调用了
system/core/liblog/logd_write.c
中的
__android_log_buf_write()
。在
文件
system/core/liblog/logd_write.c
中,
__android_log_buf_write()
组织了参数,又调用了
write_to_log
这个函数指针。
write_to_log
这个函数指针是实现的关键。
看
write_to_log
的定义
:
static int __write_to_log_init(log_id_t, struct iovec *vec, size_t nr);
static int (*write_to_log)(log_id_t, struct iovec *vec, size_t nr) = __write_to_log_init;
write_to_log
初始是指向
__write_to_log_init()
这个函数的。所以第一次执行write_to_log的时候是执行了
__write_to_log_init()
。而如果
write_to_log
不是第一次被执行,它已经在
__write_to_log_init()
里被修改指向了
__write_to_log_kernel()
。
先看
__write_to_log_init()
的实现:
static int
__write_to_log_init(log_id_t log_id, struct iovec *vec, size_t nr)
{
#ifdef HAVE_PTHREADS
pthread_mutex_lock(&log_init_lock);
#endif
if
(write_to_log == __write_to_log_init) {
log_fds[LOG_ID_MAIN] = log_open("/dev/"LOGGER_LOG_MAIN, O_WRONLY);
log_fds[LOG_ID_RADIO] = log_open("/dev/"LOGGER_LOG_RADIO, O_WRONLY);
log_fds[LOG_ID_EVENTS] = log_open("/dev/"LOGGER_LOG_EVENTS, O_WRONLY);
log_fds[LOG_ID_SYSTEM] = log_open("/dev/"LOGGER_LOG_SYSTEM, O_WRONLY);
write_to_log = __write_to_log_kernel;
if
(log_fds[LOG_ID_MAIN] < 0 || log_fds[LOG_ID_RADIO] < 0 ||
log_fds[LOG_ID_EVENTS] < 0) {
log_close(log_fds[LOG_ID_MAIN]);
log_close(log_fds[LOG_ID_RADIO]);
log_close(log_fds[LOG_ID_EVENTS]);
log_fds[LOG_ID_MAIN] = -1;
log_fds[LOG_ID_RADIO] = -1;
log_fds[LOG_ID_EVENTS] = -1;
write_to_log = __write_to_log_null;
}
if
(log_fds[LOG_ID_SYSTEM] < 0) {
log_fds[LOG_ID_SYSTEM] = log_fds[LOG_ID_MAIN];
}
}
#ifdef HAVE_PTHREADS
pthread_mutex_unlock(&log_init_lock);
#endif
return
write_to_log(log_id, vec, nr);
}
如果是第一次调用(
write_to_log
还指向
__write_to_log_init()
),就打开相应的设备文件,获取描述符,并把
write_to_log
指向
__write_to_log_kernel()
。再在
__write_to_log_kernel()
中具体执行写入文件操作。
再看
__write_to_kernel()
的实现,基本就是写操作
:
static int
__write_to_log_kernel(log_id_t log_id, struct iovec *vec, size_t nr)
{
ssize_t ret;
int
log_fd;
if
(/*(int)log_id >= 0 &&*/ (int)log_id < (int)LOG_ID_MAX) {
log_fd = log_fds[(int)log_id];
}
else
{
return
EBADF;
}
do
{
ret = log_writev(log_fd, vec, nr);
}
while
(ret < 0 && errno == EINTR);
return
ret;
}
声明:
本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:
https://www.wpsshop.cn/w/我家自动化/article/detail/684730
推荐阅读
article
用
Kivy
和
Buildozer
生成
Android
APK
_
buildozer
打包
apk
...
从一无所有开始环境Ubuntu 19.04 Disco DingoPython 3.7.3kivy 1.10.1buil...
赞
踩
article
6.3
Android
打包_使用
Buildozer
打包成
apk
_
buildozer
打包
apk
...
使用
Buildozer
可以自动构建整个打包的过程,该软件会自动下载并设置 python-for-android的必备...
赞
踩
article
深入分析
Android
Activity
(一)...
Activity
是
Android
应用程序的核心组件之一,负责管理用户界面和用户交互。通过生命周期方法、启动模式、视图...
赞
踩
article
Android
中
资源
文件夹
RES/RAW和
ASSETS
的
使用
区别_
raw
文件夹
...
/ 读取res/
raw
/example.txt文件内容try {= null) {*res/
raw
:适用于简单的
资源
文件...
赞
踩
article
Android
Gems
— Java
源码
分析之
HashMap
和
SparseArray
_
gems
源码
...
SparseArray
是Google为了提高性能替换
HashMap
而推荐使用的容器类,本文从
源码
的角度来了解一下两种容器...
赞
踩
article
Android
Studio
说:使用
HashMap
不如使用
SparseArray
?_androids...
!最后放上一个大概的
Android
学习方向及思路(详细的内容太多了~),提供给大家:对于程序员来说,要学习的知识内容、技...
赞
踩
article
android
替代
map
,
Android
为什么推荐
使用
SparseArray
来替代 Hash...
Android
为什么推荐
使用
SparseArray
来替代
HashMap
?
SparseArray
也许你没听过, ...
赞
踩
article
Android
Studio
说:使用
HashMap
不如使用
SparseArray
?,12年高级
工程师
...
那我们该怎么做才能做到年薪60万+呢,对于程序员来说,只有不断学习,不断提升自己的实力。我之前有篇文章提到过,感兴趣的可...
赞
踩
article
Android
基础
SparseArray
和
ArrayMap
(
HashMap
替代)_andr...
在某些情况下他们比
HashMap
更加高效,对内存也进行了优化,所有可以用来代替
HashMap
使用例子:SparseArr...
赞
踩
article
数据结构
HashMap
(
Android
SparseArray
和
ArrayMap
)_growing...
HashMap
也是我们使用非常多的Collection,它是基于哈希表的 Map 接口的实现,以key-value的形式...
赞
踩
article
Android
SparseArray
与
HashMap
与
ArrayMap
的性能差别_
android
...
google官方推荐,当使用
HashMap
时,Key值为整数类型时,建议使用
SparseArray
的效率更高下面我们来见...
赞
踩
article
Android
Studio
说:使用
HashMap
不如使用
SparseArray
?
,
Android
岗...
/如果目标位置还未赋值
,
则直接存入数据即可
,
对应的情况是 2.1return;//以下操作对应 2.1、2.2 两种情况...
赞
踩
article
android
老年
机
系统,打造最实用
的
老年
机
:
安卓篇
...
打造最实用
的
老年
机
:
安卓篇
小米 手
机
青春版
老年
机
一些回忆手上有一台小米手
机
1青春版,2012年中旬
的
一次活动中偶尔抢...
赞
踩
article
android
自定义
dialog
背景
透明及
显示
位置设置,
android
自定义
Dialog
背景
透明...
先贴一下
显示
效果图,仅作参考:代码如下:1、
自定义
Dialog
publicclassSelect
Dialog
extend...
赞
踩
article
Android
-自定义
dialog
_
android
自定义
dialog
...
在项目中, app没有用原生的Dialog去弹起一个弹窗,在本地new 一个 PhoneWindow去实现
dialog
的...
赞
踩
article
android
如何
自定义
dialog
,Android—
自定义
Dialog
...
在 Android 日常的开发中,
Dialog
使用是比较广泛的。无论是提示一个提示语,还是确认信息,还是有一定交互的(...
赞
踩
article
android
自定义
dialog
样式
,Android
自定义
dialog
类...
首先定制style
样式
styles.xml 加入
自定义
样式
@nulltruetruetrue@color/transp...
赞
踩
article
[
trouble
-
shooting
]
android
无法启动X86模式
虚拟机
的
问题解决。...
最近使用
android
模拟器
的
时候遇到了一个问题,
android
原生
的
x86架构模式
的
虚拟机
无法启动,提示不支持int...
赞
踩
article
深度剖析
Comate
智能
产品:科技巧思,实用至上_
baidu
comate
android
stud...
市面上现在有很多
智能
代码助手,当时互联网头部大厂百度也不例外,百度也有员工都在用并且都说好的 Baidu
Comate
。...
赞
踩
article
android
studio
安装
lombok
插件
_
android
studio
中引入
lombok
...
由于 AS 不是基于 IDEA release 版本进行开发的,因此
lombok
对idea的
插件
可能再as中无法查看到。...
赞
踩
相关标签
kivy
buildozer
android
python
activity
res/raw
assets
使用场景
区别
java
hashmap
源码
sparsearray
android studio
算法
android 替代map
array
map