• iOS开发——实时监控网速(仅作参考,发现一点问题)


      开发中用到获取网速的地方,应该就两种:

      1、下载速度,这种可以直接在接受数据的地方统计计算。这个就不讲了。
      2、获取手机网卡的数据,可以监控网卡的进出流量,下面就是。

    #import "ViewController.h"

    #include <ifaddrs.h>

    #include <arpa/inet.h>

    #include <net/if.h>

    @interface ViewController ()

    @end

    @implementation ViewController

    - (void)viewDidLoad {

        [super viewDidLoad];

            

        NSTimer *timer = [NSTimer scheduledTimerWithTimeInterval:1.0 target:self selector:@selector(getInternetface) userInfo:nil repeats:YES];

        [timer fireDate];

    }

    - (void)getInternetface {

        long long hehe = [self getInterfaceBytes];

        

        NSLog(@"hehe:%lld",hehe);

    }

    /*获取网络流量信息*/

    - (long long) getInterfaceBytes

    {

        struct ifaddrs *ifa_list = 0, *ifa;

        if (getifaddrs(&ifa_list) == -1)

        {

            return 0;

        }

        

        uint32_t iBytes = 0;

        uint32_t oBytes = 0;

        

        for (ifa = ifa_list; ifa; ifa = ifa->ifa_next)

        {

            if (AF_LINK != ifa->ifa_addr->sa_family)

                continue;

            

            if (!(ifa->ifa_flags & IFF_UP) && !(ifa->ifa_flags & IFF_RUNNING))

                continue;

            

            if (ifa->ifa_data == 0)

                continue;

            

            /* Not a loopback device. */

            if (strncmp(ifa->ifa_name, "lo", 2))

            {

                struct if_data *if_data = (struct if_data *)ifa->ifa_data;

                

                iBytes += if_data->ifi_ibytes;

                oBytes += if_data->ifi_obytes;

            }

        }

        freeifaddrs(ifa_list);

        

        NSLog(@" [getInterfaceBytes-Total]%d,%d",iBytes,oBytes);

        return iBytes + oBytes;

    }

    @end

  • 相关阅读:
    《构建之法》第四章读后感
    复利计算-单元测试
    hadoop 不同URLTitle文件提取关联URL
    全角转半角-半角转全角
    leetcode unique binary search Tree
    leetcode validBST
    leetcode -- Flatten Binary Tree to Linked List
    堆排序
    比较字符串总结:如果计算两个字符串的相似度或者距离
    leetcode Populating Next Right Pointers in Each Node
  • 原文地址:https://www.cnblogs.com/yyt-hehe-yyt/p/5954009.html
Copyright © 2020-2023  润新知