sdcard/DCIM/.thumbnails文件夹里的庞然大物 是这样来的

本文详细介绍了Android系统中.thumbdata3文件的结构和用途。该文件用于存储MicroKind类型的缩略图,尺寸为96x96像素,每个缩略图占用10000字节。文章还解释了如何通过MiniThumbFile.java接口访问这些数据。
AI助手已提取文章相关产品:

From:http://bbs.anzhi.com/thread-5961340-1-1.html

/mnt/sdcard/DCIM/.thumbnails/.thumbdata3--1967290299  都知道这里的都是缓存  但是 这个文件小则几百MB,大则几个GB,你sd卡+手机


里的图片总共也没这么大吧  

,是不是很郁闷?!


这个文件的一些细节介绍如下:

是通过MiniThumbFile.java这个文件提供的接口来访问这个文件的。

其中saveMiniThumbToFile 是把小图存到这个文件里

getMiniThumbFromFile是把小图从这个文件里取出来

这个文件名是从这样来的:sd卡的目录名 + "/.thumbdata"+version + "-"+mUri.hashCode(),version一般是MINI_THUMB_DATA_FILE_VERSION。

这个文件里面存的是一系列的小图数据卷,每个卷里含一个小jpeg和头信息,再加上填充的0。每个卷是10000字节(BYTES_PER_MINTHUMB=1000)。

要是这个要存的小jpeg超过10000字节,那么就放弃。头信息包含13字节:第一字节是0x01,第2至9字节是被称为magic的随机数,第10至13字节是紧跟着的jpeg的字节数。

| 01 | Magic | JpegLen | jpeg Bytes | Padding Bytes 0 ...|

.thumbdata3--1967290299存放的是被称为 micro kind(即android.provider.MediaStore.Images.Thumbnails.MICRO_KIND)的小图的,大小为96x96 

(TARGET_SIZE_MICRO_THUMBNAIL),所有图片都会产生这种小图,每个小图在这个文件里占有10000字节的一个卷。

还有一种 512 * 384的小图,为 android.provider.MediaStore.Images.Thumbnails.MINI_KIND类型,是直接每个存成一个jpeg的,在/mnt/sdcard/DCIM/.thumbnails/里的一系列jpeg就

是它们。

/mnt/sdcard/DCIM/.thumbnails/.thumbdata3--1967290299会被Camera,gallery, MediaProvider 这三个进程直接存取,所以在它们运行过程中拔掉sd卡的话,会被processkiller kill

掉。

您可能感兴趣的与本文相关内容

<think> 我们正在讨论的是ChromiumOS或类似环境中Android容器(如ARC++)的存储映射问题。根据引用[2],在ChromiumOS中,Android容器的外部存储(/sdcard)是通过一系列绑定挂载实现的。具体路径映射关系如下: - 宿主系统(ChromiumOS)路径:`/opt/google/containers/android/rootfs/android-data/media` - 容器内部(Android)路径:`/data/media` - 中间桥梁路径:`/run/arc/sdcard`(宿主系统)映射到容器内的`/mnt/runtime/...`路径 引用[2]指出,外部存储的绑定挂载依赖于宿主系统的`mount bind`指令,并且涉及esdfs文件系统(一种用于模拟FAT文件系统的内核模块,常用于Android的外部存储模拟)。 关于`sdcard.c`文件:用户提到已知存在`system/core/sdcard/sdcard.cpp`文件,询问是否存在`sdcard.c`文件。在AOSP(Android Open Source Project)中,FUSE守护进程的实现代码位于: - `system/core/sdcard/sdcard.cpp`(C++版本) 历史上(Android 4.4之前)可能使用C语言实现,但现代Android版本(Android 5.0+)均已改用C++实现。因此,**当前AOSP源码中不存在`sdcard.c`文件,只有`sdcard.cpp`**。 ### 路径映射验证 根据引用[2]的描述,我们可以整理出ChromiumOS中Android容器外部存储的完整挂载流程: 1. **宿主系统准备目录**: - Android容器数据根目录:`/opt/google/containers/android/rootfs/android-data` - 外部存储目录:`/opt/google/containers/android/rootfs/android-data/media`(使用esdfs文件系统) 2. **中间桥梁**: - 宿主系统路径:`/run/arc/sdcard` → 绑定挂载到`/var/run/arc/sdcard` - 容器内部路径:`/mnt/runtime/default/emulated/0`(即Android应用的/sdcard)通过bind挂载连接到宿主系统的`/run/arc/sdcard`(实际是`/var/run/arc/sdcard`) 3. **挂载传播**: 引用[4]提到,Android容器的挂载命名空间通过`SetupMountNamespaces()`函数设置,确保挂载事件在命名空间之间正确隔离或传播。 ### 结论 1. **sdcard.c文件不存在**:AOSP中只有`sdcard.cpp`(位于`system/core/sdcard/`目录),用于实现FUSE守护进程。 2. **ChromiumOS中的存储映射**: ```mermaid graph LR A[宿主系统:/opt/google/containers/android/rootfs/android-data/media] -- bind挂载 --> B[/run/arc/sdcard] B -- 映射到容器路径 --> C[容器内部:/var/run/arc/sdcard] C -- bind挂载 --> D[Android运行时:/mnt/runtime/default/emulated/0] D --> E[Android应用访问路径:/storage/emulated/0] ``` ### 相关问题 1. 如何在ChromiumOS中自定义Android容器的外部存储路径? 2. esdfs文件系统与FUSE在Android外部存储实现中有何差异? 3. Android容器的挂载命名空间隔离机制是如何实现的? </think> ### 关于`sdcard.c`文件的存在性确认 根据系统源码结构和已知信息: 1. **当前文件存在性**: - ✅ 系统中确认存在:`system/core/sdcard/sdcard.cpp`(C++实现) - ❌ **不存在`system/core/sdcard/sdcard.c`文件**(C语言版本) 2. **历史演进说明**: - 在早期Android版本(≤ 4.4)中,FUSE守护进程确实以C语言实现: $$ \text{旧路径:}\texttt{system/core/sdcard/sdcard.c} $$ - 自Android 5.0(Lollipop)起,重写为C++实现: $$ \text{新路径:}\texttt{system/core/sdcard/sdcard.cpp} $$ - 当前源码中所有功能逻辑均已迁移至C++版本[^1][^2] 3. **关键代码位置**: ```bash # Android源码树路径 ├── system │ └── core │ └── sdcard │ ├── sdcard.cpp # FUSE守护进程主逻辑 │ ├── fuse.cpp # FUSE协议处理 │ └── Android.bp # 构建配置 ``` 核心挂载逻辑在`sdcard.cpp`的`run()`函数实现文件系统虚拟化[^2]。 4. **ChromiumOS特殊映射**: 引用[2]描述的`/run/arc/sdcard`路径是通过bind挂载实现的桥梁: ```mermaid graph LR A[物理存储<br>/opt/google/containers/android/rootfs/android-data/media] -- bind挂载 --> B[/run/arc/sdcard] -- 命名空间映射 --> C[Android容器<br>/mnt/runtime/default] -- FUSE虚拟化 --> D[应用可见<br>/sdcard] ``` 此机制由`init.rc`中的mount指令初始化[^3][^4]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值