2.3开始android就提供来这个类的API,这样我们就可以方便的用他来实现统计手机流量来。这个类其实也很简单,我贴上他的几个方法,大家一看就知道怎么用了。

static long getMobileRxBytes() //获取通过Mobile连接收到的字节总数,不包含WiFi
static long getMobileRxPackets() //获取Mobile连接收到的数据包总数
static long getMobileTxBytes() //Mobile发送的总字节数
static long getMobileTxPackets() //Mobile发送的总数据包数
static long getTotalRxBytes() //获取总的接受字节数,包含Mobile和WiFi等
static long getTotalRxPackets() //总的接受数据包数,包含Mobile和WiFi等
static long getTotalTxBytes() //总的发送字节数,包含Mobile和WiFi等
static long getTotalTxPackets() //发送的总数据包数,包含Mobile和WiFi等
static long getUidRxBytes(int uid) //获取某个网络UID的接受字节数,某一个进程的总接收量
static long getUidTxBytes(int uid) //获取某个网络UID的发送字节数,某一个进程的总发送量

下面说我做实时网速的思路:

1.获得当前的总接受数据,getTotalRxPackets()

2.每隔几秒再获取一次总接收的数据

3.讲最新获取的数据减去之前获取的数据并且除以间隔的秒数,就得到了每秒平均的网速b/s,最后进行单位转换为kb、Mb等等

实现:

1.得到当前网速的方法

初始时给total_data一个值:

private long total_data = TrafficStats.getTotalRxBytes();

之后每次获取的数值要减去total_data再除以间隔秒数,并且将total重新赋值为最新的。

    /**
* 核心方法,得到当前网速
* @return
*/
private int getNetSpeed() {
long traffic_data = TrafficStats.getTotalRxBytes() - total_data;
total_data = TrafficStats.getTotalRxBytes();
return (int)traffic_data /count ;
}

2.周期性的获取网速

/**
* 定义线程周期性地获取网速
*/
private Runnable mRunnable = new Runnable() {
@Override
public void run() {
//定时器
mHandler.postDelayed(mRunnable, count * 1000);
Message msg = mHandler.obtainMessage();
msg.what = 1;
msg.arg1 = getNetSpeed();
mHandler.sendMessage(msg);
}
};

3.单位转换

@Override
public void onCreate() {
super.onCreate(); mHandler = new Handler(){
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
if (msg.what == 1) {
//float real_data = (float)msg.arg1;
if(msg.arg1 > 1024 ){
System.out.println(msg.arg1 / 1024 + "kb/s");
}
else{
System.out.println(msg.arg1 + "b/s");
}
}
}
}; }

4.启动handler和停止handler

PS:服务开始就执行runnable中的方法,并且runnable中设置handler循环执行。执行runnable中run()方法时,将网速包装到message中,交给handler进行单位转换并显示(这里在handler中进行单位转换是为了方便显示到ui中)

/**
* 启动服务时就开始启动线程获取网速
*/
@Override
public void onStart(Intent intent, int startId) {
mHandler.postDelayed(mRunnable, 0);
}; /**
* 在服务结束时删除消息队列
*/
@Override
public void onDestroy() {
mHandler.removeCallbacks(mRunnable);
super.onDestroy();
};
@Override
public void onCreate() {
super.onCreate(); mHandler = new Handler(){
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
if (msg.what == 1) {
//float real_data = (float)msg.arg1;
if(msg.arg1 > 1024 ){
System.out.println(msg.arg1 / 1024 + "kb/s");
}
else{
System.out.println(msg.arg1 + "b/s");
}
}
}
};

最后,全部代码

Service:

package com.kale.netspeed;

import android.app.Service;
import android.content.Intent;
import android.net.TrafficStats;
import android.os.Handler;
import android.os.IBinder;
import android.os.Message; /**
* @author:Jack Tony
* @tips :实时获取当前网速的service
* @date :2014-9-24
*/
public class Net_Service extends Service { private long total_data = TrafficStats.getTotalRxBytes();
private Handler mHandler;
//几秒刷新一次
private final int count = 5; /**
* 定义线程周期性地获取网速
*/
private Runnable mRunnable = new Runnable() {
@Override
public void run() {
//定时器
mHandler.postDelayed(mRunnable, count * 1000);
Message msg = mHandler.obtainMessage();
msg.what = 1;
msg.arg1 = getNetSpeed();
mHandler.sendMessage(msg);
}
}; @Override
public void onCreate() {
super.onCreate(); mHandler = new Handler(){
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
if (msg.what == 1) {
//float real_data = (float)msg.arg1;
if(msg.arg1 > 1024 ){
System.out.println(msg.arg1 / 1024 + "kb/s");
}
else{
System.out.println(msg.arg1 + "b/s");
}
}
}
}; } /**
* 核心方法,得到当前网速
* @return
*/
private int getNetSpeed() {
long traffic_data = TrafficStats.getTotalRxBytes() - total_data;
total_data = TrafficStats.getTotalRxBytes();
return (int)traffic_data /count ;
} /**
* 启动服务时就开始启动线程获取网速
*/
@Override
public void onStart(Intent intent, int startId) {
mHandler.postDelayed(mRunnable, 0);
}; /**
* 在服务结束时删除消息队列
*/
@Override
public void onDestroy() {
mHandler.removeCallbacks(mRunnable);
super.onDestroy();
}; @Override
public IBinder onBind(Intent intent) {
return null;
} }
<service android:name="com.kale.netspeed.Net_Service"/>

Activity:

package com.kale.netspeed;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle; public class MainActivity extends Activity { @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); startService(new Intent(MainActivity.this,Net_Service.class));
}
}

参考自:http://gundumw100.iteye.com/blog/1294167

TrafficStats——流量统计类的范例,获取实时网速的更多相关文章

  1. Android中获取实时网速(2)

    一.实现思路: 1.Android提供有获取当前总流量的方法 2.上一秒 减去 下一面的流量差便是网速 3.注意计算 二.计算网速的工具类: package imcs.cb.com.viewappli ...

  2. 【Linux环境编程】获取网卡的实时网速

    在windows以下.我们能够看到360或者是qq安全卫士的"安全球".上面显示实时的网速情况.那么在linux里面怎样获取网卡的实时网速?事实上原理非常easy,读取须要获取网速 ...

  3. proc/net/dev实时网速统计实例【转】

    转自:https://blog.csdn.net/dosthing/article/details/80384541 前言 网络编程是程序连接网络拓展的基础,尤其是在物联网.互联网加等概念火热的当下, ...

  4. C# 实现实时网速

    前言 最近参加了一个项目,所以写博客的时间就少了,项目中有一个功能就是在窗体上显示实时网速,用了半天的时间写了出来,想想今天时间蛮充足,就把它分享到博客上吧. 项目展示 项目核心代码: private ...

  5. python检测当前网卡流量信息,用于查看实时网速

    可以用来检测是否有挖矿程序在运行的一个子条件 # coding:utf-8 __author__ = 'chenhuachao' import wmi import time import platf ...

  6. proc/net/dev实时网速统计实例

    https://blog.csdn.net/dosthing/article/details/80384541 http://www.l99.com/EditText_view.action?text ...

  7. Ubuntu 16.04安装基于nethogs衍生的网络监控软件(应用实时网速监控)

    基于nethogs衍生的网络监控软件有如下所列举的: nettop显示数据包类型,按数据包的大小或数量排序. ettercap是以太网的网络嗅探器/拦截器/记录器 darkstat通过主机,协议等方式 ...

  8. nload 实时网速查看

    nload eth0 -u K Device eth0 [192.168.0.33] (1/1):=================================================== ...

  9. Ubuntu显示实时网速CPU内存等参数

    添加库 sudo add-apt-repository ppa:fossfreedom/indicator-sysmonitor 更新软件列表 sudo apt-get update 安装indica ...

随机推荐

  1. Oracle-查询最近更新的前10条数据

    在实际用途中,常常会要求取最近的几条纪录,这就需要先对纪录进行排序后再取rownum <= 一般常见的 SELECT * FROM (SELECT a.* FROM torderdetail a ...

  2. Nginx服务状态的监控

    https://www.cnblogs.com/beginner-boy/p/8052908.html

  3. L3-004 肿瘤诊断 dfs bfs

    在诊断肿瘤疾病时,计算肿瘤体积是很重要的一环.给定病灶扫描切片中标注出的疑似肿瘤区域,请你计算肿瘤的体积. 输入格式: 输入第一行给出4个正整数:M.N.L.T,其中M和N是每张切片的尺寸(即每张切片 ...

  4. git使用姿势

    IDEA 整合Git 可以在IDEA中Terminal中进行git操作 下面所说的快捷键操作都只是对于IDEA中 拉取提交代码 git pull 从远程仓库更新代码 (ctrl+t) git comm ...

  5. Java持久化之 -- 傲娇的NIO

    NIO: Jdk 1.4+ New IO 面向通道和缓冲区 所在包:java.nio 执行流程: 数据总数由通道写入到buffer , 或者是从buffer写入通道 完全替换IO(面向流  单向的) ...

  6. Android-Start方式和Bind方式混合开启Service

    Android-Start方式和Bind方式混合开启Service 需求如下 需要开发一个音乐APP,需要满足以下的需求: 当退出所有的Activity后仍然能够播放音乐 能够控制音乐的播放比如说,暂 ...

  7. 【WIN10】移植opencc到WIN10-UWP,實現自己的繁簡轉換工具

    花了週末兩天時間,將opencc移植成WIN10-UWP可用的庫,並完成自己的繁簡轉換工具. 我的繁簡轉換工具下載地址為:https://www.microsoft.com/store/apps/9n ...

  8. BZOJ.1034.[ZJOI2008]泡泡堂(贪心)

    题目链接 容易想到田忌赛马.但是是不对的,比如2 3对1 3,按田忌赛马策略会3->1 2->3,但是3->3 2->1显然更优. 而如果按己方最强>=对方最强则开打,也 ...

  9. 【Codechef FRBSUM】【FJOI2016】【BZOJ4299】【BZOJ 4408】 可持久化线段树

    4408: [Fjoi 2016]神秘数 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 475  Solved: 287[Submit][Status ...

  10. ==与equals与hashCode的区别联系。

    前言:对于引用类型的变量,它涉及到两块内存,一块是堆中的内存,用于存放new出来的对象(就是对象的具体内容):另一块是栈内存,用来存放变量在堆内存中的地址. 1,“==” 判断两个变量是否是同一个变量 ...