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. 【算法】后缀自动机(SAM) 初探

    [自动机] 有限状态自动机的功能是识别字符串,自动机A能识别字符串S,就记为$A(S)$=true,否则$A(S)$=false. 自动机由$alpha$(字符集),$state$(状态集合),$in ...

  2. python程序后台运行的实现

    后台运行work()方法. work.py # -*- coding:utf-8 -*- def work(): print "running" import time time. ...

  3. 主动学习——active learning

    阅读目录 1. 写在前面 2. 什么是active learning? 3. active learning的基本思想 4. active learning与半监督学习的不同 5. 参考文献   1. ...

  4. linux 检测远程端口是否打开

    linux 检测远程端口是否打开   检测远程端口是否打开   常用telnet 110.101.101.101 80方式测试远程主机端口是否打开.   除此之外还可以使用:   方法1.nmap i ...

  5. Anaconda完全入门指南

    Anaconda完全入门指南 参考文章: 致Python初学者:Anaconda入门使用指南 Anaconda使用总结 概述 很多学习python的初学者甚至学了有一段时间的人接触到anaconda或 ...

  6. pip 安装包提速

    豆瓣源 pip3 install 第三方库名 -i https://pypi.doubanio.com/simple/ --trusted-host pypi.doubanio.com

  7. C#并行编程(5):需要知道的异步

    异步与并行的联系 大家知道"并行"是利用CPU的多个核心或者多个CPU同时执行不同的任务,我们不关心这些任务之间的依赖关系. 但是在我们实际的业务中,很多任务之间是相互影响的,比如 ...

  8. [HDU4348]To the moon(主席树+标记永久化)

    学可持久化treap的时候才发现自己竟然没写过需要标记下传的主席树,然而现在发现大部分操作都可以标记永久化,下传会增大占用空间. 这题一种写法是和普通的线段树一样标记下传,注意所有修改操作(包括put ...

  9. bzoj 2753: [SCOI2012]滑雪与时间胶囊 -- 最小生成树

    2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec  Memory Limit: 128 MB Description a180285非常喜欢滑雪.他来到一座雪山,这 ...

  10. CentOS添加环境变量的三种方式

    CentOS添加环境变量的三种方式,以添加php环境变量为例,假定php的安装目录为 /usr/local/php5 一.仅对当前会话临时生效 [root@bogon ~]# export PATH= ...