欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android 如何獲取手機總內(nèi)存和可用內(nèi)存等信息

 更新時間:2016年07月14日 10:52:34   投稿:lqh  
這篇文章主要介紹了Android系統(tǒng)檢測程序內(nèi)存占用各種方法,并對內(nèi)存信息的詳細介紹,需要的朋友可以參考下

在android開發(fā)中,有時候我們想獲取手機的一些硬件信息,比如android手機的總內(nèi)存和可用內(nèi)存大小。

這個該如何實現(xiàn)呢?

通過讀取文件"/proc/meminfo"的信息能夠獲取手機Memory的總量,而通過ActivityManager.getMemoryInfo(ActivityManager.MemoryInfo)方法可以獲取當前的可用Memory量。
      "/proc/meminfo"文件記錄了android手機的一些內(nèi)存信息,在命令行窗口里輸入"adb shell",進入shell環(huán)境,輸入"cat /proc/meminfo"即可在命令行里顯示meminfo文件的內(nèi)容

具體如下所示。

C:\Users\Figo>adb shell

# cat /proc/meminfo

cat /proc/meminfo

MemTotal:          94096 kB

MemFree:            1684 kB

Buffers:              16 kB

Cached:            27160 kB

SwapCached:            0 kB

Active:            35392 kB

Inactive:          44180 kB

Active(anon):      26540 kB

Inactive(anon):    28244 kB

Active(file):       8852 kB

Inactive(file):    15936 kB

Unevictable:         280 kB

Mlocked:               0 kB

SwapTotal:             0 kB

SwapFree:              0 kB

Dirty:                 0 kB

Writeback:             0 kB

AnonPages:         52688 kB

Mapped:            17960 kB

Slab:               3816 kB

SReclaimable:        936 kB

SUnreclaim:         2880 kB

PageTables:         5260 kB

NFS_Unstable:          0 kB

Bounce:                0 kB

WritebackTmp:          0 kB

CommitLimit:       47048 kB

Committed_AS:    1483784 kB

VmallocTotal:     876544 kB

VmallocUsed:       15456 kB

VmallocChunk:     829444 kB

#

下面先對"/proc/meminfo"文件里列出的字段進行粗略解釋:

MemTotal: 所有可用RAM大小。

MemFree: LowFree與HighFree的總和,被系統(tǒng)留著未使用的內(nèi)存。

Buffers: 用來給文件做緩沖大小。

Cached: 被高速緩沖存儲器(cache memory)用的內(nèi)存的大?。ǖ扔赿iskcache minus SwapCache)。

SwapCached:被高速緩沖存儲器(cache memory)用的交換空間的大小。已經(jīng)被交換出來的內(nèi)存,仍然被存放在swapfile中,用來在需要的時候很快的被替換而不需要再次打開I/O端口。

Active: 在活躍使用中的緩沖或高速緩沖存儲器頁面文件的大小,除非非常必要,否則不會被移作他用。

Inactive: 在不經(jīng)常使用中的緩沖或高速緩沖存儲器頁面文件的大小,可能被用于其他途徑。

SwapTotal: 交換空間的總大小。

SwapFree: 未被使用交換空間的大小。

Dirty: 等待被寫回到磁盤的內(nèi)存大小。

Writeback: 正在被寫回到磁盤的內(nèi)存大小。

AnonPages:未映射頁的內(nèi)存大小。

Mapped: 設備和文件等映射的大小。

Slab: 內(nèi)核數(shù)據(jù)結(jié)構(gòu)緩存的大小,可以減少申請和釋放內(nèi)存帶來的消耗。

SReclaimable:可收回Slab的大小。

SUnreclaim:不可收回Slab的大小(SUnreclaim+SReclaimable=Slab)。

PageTables:管理內(nèi)存分頁頁面的索引表的大小。

NFS_Unstable:不穩(wěn)定頁表的大小。

 要獲取android手機總內(nèi)存大小,只需讀取"/proc/meminfo"文件的第1行,并進行簡單的字符串處理即可。

 下面直接給出詳細步驟,大家可以根據(jù)實際情況進行相應擴展。

 1.新建項目,修改main.xml

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  android:orientation="vertical" 
  android:layout_width="fill_parent" 
  android:layout_height="fill_parent" > 
<TextView  
  android:layout_width="fill_parent"  
  android:layout_height="wrap_content"  
  android:textStyle="bold" 
  android:id="@+id/system_memory" /> 
</LinearLayout> 

 2.完善ReadSystemMemory.java類

package com.figo.readsyememory; 
 
import android.app.Activity; 
import android.os.Bundle; 
import java.io.BufferedReader; 
import java.io.FileReader; 
import java.io.IOException; 
import android.app.ActivityManager; 
import android.app.ActivityManager.MemoryInfo; 
import android.content.Context; 
import android.text.format.Formatter; 
import android.util.Log; 
import android.widget.TextView; 
 
public class ReadSystemMemory extends Activity { 
 
  TextView tv = null; 
 
  private String getAvailMemory() {// 獲取android當前可用內(nèi)存大小 
 
    ActivityManager am = (ActivityManager) getSystemService(Context.ACTIVITY_SERVICE); 
    MemoryInfo mi = new MemoryInfo(); 
    am.getMemoryInfo(mi); 
    //mi.availMem; 當前系統(tǒng)的可用內(nèi)存 
 
    return Formatter.formatFileSize(getBaseContext(), mi.availMem);// 將獲取的內(nèi)存大小規(guī)格化 
  } 
 
  private String getTotalMemory() { 
    String str1 = "/proc/meminfo";// 系統(tǒng)內(nèi)存信息文件 
    String str2; 
    String[] arrayOfString; 
    long initial_memory = 0; 
 
    try { 
      FileReader localFileReader = new FileReader(str1); 
      BufferedReader localBufferedReader = new BufferedReader( 
          localFileReader, 8192); 
      str2 = localBufferedReader.readLine();// 讀取meminfo第一行,系統(tǒng)總內(nèi)存大小 
 
      arrayOfString = str2.split("\\s+"); 
      for (String num : arrayOfString) { 
        Log.i(str2, num + "\t"); 
      } 
 
      initial_memory = Integer.valueOf(arrayOfString[1]).intValue() * 1024;// 獲得系統(tǒng)總內(nèi)存,單位是KB,乘以1024轉(zhuǎn)換為Byte 
      localBufferedReader.close(); 
 
    } catch (IOException e) { 
    } 
    return Formatter.formatFileSize(getBaseContext(), initial_memory);// Byte轉(zhuǎn)換為KB或者MB,內(nèi)存大小規(guī)格化 
  } 
 
  /** Called when the activity is first created. */ 
  @Override 
  public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.main); 
 
    tv = (TextView) findViewById(R.id.system_memory); 
    tv.setText("手機總內(nèi)存: " + this.getTotalMemory() + ", " + "可用內(nèi)存: " 
        + this.getAvailMemory()); 
  } 
} 

 大功告成,順利讀取android手機的總內(nèi)存和當前的可用內(nèi)存。這里只是拋磚引玉,大家可以舉一反三,進行擴展。當然我們還可以通過讀取"/proc/cupinfo"來獲取android手機的CPU參數(shù),通過讀取"/proc/stat"文件來計算CPU的使用率,這里不再贅述。

 第二種方法:手用java的反射機制來獲取手機的內(nèi)存的一些信息。

public class GetFreeMem extends Activity { 
  /** Called when the activity is first created. */ 
  @Override 
  public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.main); 
    Method _readProclines = null; 
    try { 
      Class procClass; 
      procClass = Class.forName("android.os.Process"); 
      Class parameterTypes[]= new Class[] {String.class, String[].class, long[].class }; 
      _readProclines = procClass.getMethod("readProcLines", parameterTypes); 
      Object arglist[] = new Object[3]; 
      final String[] mMemInfoFields = new String[] {"MemTotal:", 
          "MemFree:", "Buffers:", "Cached:"}; 
      long[] mMemInfoSizes = new long[mMemInfoFields.length]; 
      mMemInfoSizes[0] = 30; 
      mMemInfoSizes[1] = -30; 
      arglist[0] = new String("/proc/meminfo"); 
      arglist[1] = mMemInfoFields; 
      arglist[2] = mMemInfoSizes; 
      if(_readProclines!=null){ 
        _readProclines.invoke(null, arglist); 
        for (int i=0; i<mMemInfoSizes.length; i++) { 
          Log.d("GetFreeMem", mMemInfoFields[i]+" : "+mMemInfoSizes[i]/1024); 
        } 
      } 
    } catch (ClassNotFoundException e) { 
      e.printStackTrace(); 
    } catch (SecurityException e) { 
      e.printStackTrace(); 
    } catch (IllegalArgumentException e) { 
      e.printStackTrace(); 
    } catch (IllegalAccessException e) { 
      e.printStackTrace(); 
    } catch (InvocationTargetException e) { 
      e.printStackTrace(); 
    } catch (NoSuchMethodException e) { 
      e.printStackTrace(); 
    } 
  } 
} 

以上就是對 Android 獲取內(nèi)存信息的資料整理,做這塊Android開發(fā)的朋友可以看下。

相關(guān)文章

  • Android設備之間通過Wifi通信的示例代碼

    Android設備之間通過Wifi通信的示例代碼

    本篇文章主要介紹了Android設備之間通過Wifi通信的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • android 手機截取長屏實例代碼

    android 手機截取長屏實例代碼

    本篇文章主要介紹了android 手機截取長屏實例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • Android編程之判斷SD卡狀態(tài)的方法

    Android編程之判斷SD卡狀態(tài)的方法

    這篇文章主要介紹了Android編程之判斷SD卡狀態(tài)的方法,結(jié)合實例分析了Android針對SD卡的權(quán)限操作及狀態(tài)判定技巧,需要的朋友可以參考下
    2016-02-02
  • Flutter使用sqflite處理數(shù)據(jù)表變更的方法詳解

    Flutter使用sqflite處理數(shù)據(jù)表變更的方法詳解

    了解過數(shù)據(jù)庫的同學應該會知道,數(shù)據(jù)表結(jié)構(gòu)是可能發(fā)生改變的。所以本文為大家介紹了Flutter?使用?sqflite?處理數(shù)據(jù)表變更的版本升級處理方法,感興趣的可以了解一下
    2023-04-04
  • Android開發(fā)中PopupWindow用法實例分析

    Android開發(fā)中PopupWindow用法實例分析

    這篇文章主要介紹了Android開發(fā)中PopupWindow用法,結(jié)合實例形式分析了PopupWindow彈出窗口效果的使用技巧,需要的朋友可以參考下
    2016-02-02
  • android2.3.5 CDMA/EVDO撥號APN解決方案

    android2.3.5 CDMA/EVDO撥號APN解決方案

    google提供的android2.3里面,只能在GSM/WCDMA情況下才能從“設置”->“無線和網(wǎng)絡”->“移動網(wǎng)絡”->“接入點名稱”中選擇不同的apn帳號進行撥號連接,而CDMA/EVDO則沒有這個功能,接下來本文介紹一些方法實現(xiàn)這個功能,感興趣的朋友可以了解下
    2013-01-01
  • Android編程連接MongoDB及增刪改查等基本操作示例

    Android編程連接MongoDB及增刪改查等基本操作示例

    這篇文章主要介紹了Android編程連接MongoDB及增刪改查等基本操作,簡單介紹了MongoDB功能、概念、使用方法及Android操作MongoDB數(shù)據(jù)庫的基本技巧,需要的朋友可以參考下
    2017-07-07
  • Android中MPAndroidChart自定義繪制最高點標識的方法

    Android中MPAndroidChart自定義繪制最高點標識的方法

    目前在做一款軟件,要求在展示走勢圖的時候?qū)ψ罡唿c進行自定義繪制,下面這篇文章主要給大家介紹了關(guān)于Android中MPAndroidChart自定義繪制最高點標識的方法,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧。
    2018-03-03
  • Android深入探究自定義View之嵌套滑動的實現(xiàn)

    Android深入探究自定義View之嵌套滑動的實現(xiàn)

    什么是嵌套滑動?當我們向下滑動時,首先是外部的布局向下滑動,然后才是內(nèi)部的RecyclerView滑動,向上滑動也是如此。這就是嵌套滑動的效果
    2021-11-11
  • Android自定義View實現(xiàn)跟隨手指移動

    Android自定義View實現(xiàn)跟隨手指移動

    這篇文章主要為大家詳細介紹了Android自定義View實現(xiàn)跟隨手指移動,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08

最新評論