Android编程之Sdcard相关代码集锦

 更新时间:2015年11月17日 14:42:18   作者:stevenhu_223  
这篇文章主要介绍了Android编程之Sdcard相关代码集锦,包括Android针对sd卡的存取、检测、相关信息获取等操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下

本文实例讲述了Android编程之Sdcard相关代码。分享给大家供大家参考,具体如下:

1. 检测Sdcard是否可用:

public static boolean sdCardIsAvailable() { 
  String status = Environment.getExternalStorageState(); 
  if (!status.equals(Environment.MEDIA_MOUNTED)) { 
   return false; 
  } 
  return true; 
} 

2. 获得程序在sd卡上的cahce目录:

private static boolean hasExternalCacheDir() { 
  return Build.VERSION.SDK_INT >= Build.VERSION_CODES.FROYO; 
} 
/** 
* @param context 上下文 
* @return The external cache dir SD卡路径 
*/ 
private static String getExternalCacheDir(Context context) { 
  // android 2.2 以后才支持的特性 
  if (hasExternalCacheDir()) { 
   return context.getExternalCacheDir().getPath() + File.separator + "gesture"; 
  } 
  // Before Froyo we need to construct the external cache dir ourselves 
  // 2.2以前我们需要自己构造 
  final String cacheDir = "/Android/data/" + context.getPackageName() + "/cache/gesture/"; 
  return Environment.getExternalStorageDirectory().getPath() + cacheDir; 
} 

3. 获取Sdcard的实际空间大小:

public static long getRealSizeOnSdcard() { 
  File path = new File(Environment.getExternalStorageDirectory().getAbsolutePath()); 
  StatFs stat = new StatFs(path.getPath()); 
  long blockSize = stat.getBlockSize(); 
  long availableBlocks = stat.getAvailableBlocks(); 
  return availableBlocks * blockSize; 
} 

----->检测Sdcard是否有足够的空间:

/** 
* @param updateSize 指定的检测空间大小 
* @return True 空间足够返回true,不足返回false 
*/ 
public static boolean enoughSpaceOnSdCard(long updateSize) { 
  String status = Environment.getExternalStorageState(); 
  if (!status.equals(Environment.MEDIA_MOUNTED)) 
   return false; 
  return (updateSize < getRealSizeOnSdcard()); 
} 

4. 获取手机的存储大小:

public static long getRealSizeOnPhone() { 
  File path = Environment.getDataDirectory(); 
  StatFs stat = new StatFs(path.getPath()); 
  long blockSize = stat.getBlockSize(); 
  long availableBlocks = stat.getAvailableBlocks(); 
  long realSize = blockSize * availableBlocks; 
  return realSize; 
} 

---->检测手机存储是否有足够的空间:

/** 
* @param updateSize 指定的检测空间大小 
* @return 空间足够返回true,不足返回false 
*/ 
public static boolean enoughSpaceOnPhone(long updateSize) { 
  return getRealSizeOnPhone() > updateSize; 
} 

附带点很久之前的记忆小赠品:

1. 在Android.mk中加入LOCAL_CERTIFICATE := platform就可以使用系统隐藏api(@hide)。

2.Activity的启动模式总结:

1). standard:

堆栈(task):与应用程序的其他已启动过的Activity在同一个堆栈

实例创建:每次启动都会创建新的实例

2). singleTop:

堆栈(task):与应用程序的其他已启动过的Activity在同一个堆栈

实例创建:启动时,检查是否有该Activity的实例在当前的栈顶(启动过的记录)。若有,则不再创建新实例,若无,则重新创建新实例,置于栈顶。

3). singleTask:

堆栈(task): 与应用程序的其他已启动过的Activity在同一个堆栈

实例创建:启动时,检查task中是否有该Activity的实例。若有,则将task中在该Activity实例之上的所有其他Activity实例统统出栈(pop),
 使其在栈顶。若无,则重新创建该Activity实例,置于栈顶。

4). singleInstance:

堆栈(task):与另外其他三种模式不同,会新建一个task,将Acitvity放置于这个新的task中,并保证不再有其他Activity实例进入.

实例创建:第一次创建时,会新建一个task,将其至于新的task中。若实例已存在,在启动时,无需再创建新实例,复用之前已创建的实例。

3.设置Activity的背景为手机桌面的背景:

在setContentView方法之前添加getWindow().setFlags(WindowManager.LayoutParams.FLAG_SHOW_WALLPAPER, WindowManager.LayoutParams.FLAG_SHOW_WALLPAPER),

然后在AndroidManifest.xml文件中添加android:theme="@android:style/Theme.Translucent"属性,实现将该Activity设置为透明。

4.查看手机内存空间代码long freeMemory = Runtime.getRuntime().freeMemory();

5.关于Android主线程:

android中的主线程是UI线程,它是针对android中的UI组件操作的线程,而android中UI组件操作要求是非线程安全的,

毕竟UI组件的更新操作要求快速响应,如果更新时考虑线程安全,同步锁等待响应之类的,那么UI组件的更新响应就有可能会延迟,
  这样话就不符合Android要求尽可能规避的ANR异常。

6.Android4.4系统发布了一个ART运行时,准备用来替换掉之前一直使用的Dalvik虚拟机,希望籍此解决饱受诟病的性能问题。

7. 引用相关:

SoftReference<T>:软引用-->当虚拟机内存不足时,将会回收它指向的对象;需要获取对象时,可以调用get方法。

WeakReference<T>:弱引用-->随时可能会被垃圾回收器回收。

softReference多用作来实现cache机制,weakReference一般用来防止内存泄漏,要保证内存被VM回收 .

8.TCP和UDP

由于面向连接的TCP协议在发生数据丢包时,会要求重传,这会

影响视频的实时性。UDP由于其是面向事务的,且简单不可靠的传输协议,

在传输视频数据当中具有快捷,消耗资源小的特点,简单的传输过程中产生的

丢包和乱序是可以在视频接收端处理的。所以一般采用UDP协议作为多媒体通信的传输层协议。

9.内存相关:

1). 一个进程的内存可以由2个部分组成:java 使用内存 ,C 使用内存 ,

这两个内存的和必须小于16M(16M是怎么来的?算是实验来的吧,每个机型不一样,模拟器不同版本也不一样,可以通过:
Runtime.getMaxMemory() 来查看。),不然就会出现大家熟悉的OOM,这个就是第一种OOM的情况。

2). 更加奇怪的是这个:一旦内存分配给Java后,以后这块内存即使释放后,也只能给Java的使用,这个估计跟java虚拟机里把内存分成好几块进行缓存的原因有关,反正C就别想用到这块的内存了。

10.获取底部虚拟按键高度(针对没有物理按键的手机):

/** 
* 获取底部虚拟按键高度(针对没有物理按键的手机) 
* @return 
*/ 
private int getNavigationBarHeight() { 
  int resourceId = getResources().getIdentifier("navigation_bar_height", "dimen", "android"); 
  if (resourceId > 0) { 
   return getResources().getDimensionPixelSize(resourceId); 
  } 
  return 0; 
}

希望本文所述对大家Android程序设计有所帮助。

相关文章

  • Android实现取消GridView中Item选中时默认的背景色

    Android实现取消GridView中Item选中时默认的背景色

    这篇文章主要介绍了Android实现取消GridView中Item选中时默认的背景色,涉及Android GridView中Item属性设置的相关技巧,需要的朋友可以参考下
    2016-02-02
  • Android仿微信语音对讲录音功能

    Android仿微信语音对讲录音功能

    这篇文章主要为大家详细介绍了Android仿微信语音对讲录音,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-11-11
  • Flutter自定义实现神奇动效的卡片切换视图的示例代码

    Flutter自定义实现神奇动效的卡片切换视图的示例代码

    这篇文章主要介绍了Flutter自定义实现神奇动效的卡片切换视图的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-04-04
  • flutter实现底部导航栏

    flutter实现底部导航栏

    这篇文章主要为大家详细介绍了flutter实现底部导航栏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • Android 横竖屏处理的知识小结

    Android 横竖屏处理的知识小结

    这篇文章主要介绍了Android 横竖屏处理的知识小结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-03-03
  • Flutter检查连接网络connectivity_plus实现步骤

    Flutter检查连接网络connectivity_plus实现步骤

    这篇文章主要为大家介绍了Flutter检查连接网络connectivity_plus实现步骤,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • C/C++在Java、Android和Objective-C三大平台下实现混合编程

    C/C++在Java、Android和Objective-C三大平台下实现混合编程

    本文主要介绍C/C++在Java、Android和Objective-C三大平台下实现混合编程,这里举例说明实现不同平台用C/C++实现编程的方法,有兴趣的小伙伴可以参考下
    2016-08-08
  • Android开发中比较耗时的一些操作小结

    Android开发中比较耗时的一些操作小结

    这篇文章主要介绍了Android开发中比较耗时的一些操作小结,本文根据实际开发经验总结了6条比较耗时的编程操作,请大家注意下,需要的朋友可以参考下
    2015-06-06
  • Android组件实现长按弹出上下文菜单功能的方法

    Android组件实现长按弹出上下文菜单功能的方法

    这篇文章主要介绍了Android组件实现长按弹出上下文菜单功能的方法,结合实例形式分析了Android实现长按弹出上下文菜单的具体步骤与相关操作技巧,需要的朋友可以参考下
    2017-07-07
  • Android事件分发机制 ViewGroup分析

    Android事件分发机制 ViewGroup分析

    这篇文章主要介绍了Android事件分发机制 ViewGroup分析,事件分发从手指触摸屏幕开始,即产生了触摸信息,被底层系统捕获后会传递给Android的输入系统服务IMS,更多相关介绍,需要的朋友可以参考一下
    2022-09-09

最新评论