linux 下获取本机地址和掩码

获取本机地址的源码

结果

源码为:

#include <iostream>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <ifaddrs.h>

using namespace std;

int main(void) {
    struct ifaddrs* myaddrs;
    struct sockaddr_in *ss, *kk;
    if (getifaddrs(&myaddrs) == 0) {
        for (struct ifaddrs* ifa = myaddrs; ifa != NULL; ifa = ifa->ifa_next) {
        ss = (struct sockaddr_in*) ifa->ifa_addr;
        kk = (struct sockaddr_in*) ifa->ifa_netmask;
        if (ss->sin_family == AF_INET)
            cout << "sa_family:" << ss->sin_family << " " << ifa->ifa_name << ":" << inet_ntoa(ss->sin_addr) << " netmask:" << inet_ntoa(kk->sin_addr) << endl;
        }
    }
    return 0;
}

为什么得到的ip地址和子网掩码一样?

阅读 3.7k
2 个回答

我感觉linux下的inet_ntoa打印子网掩码有问题,这段程序在Mac系统上可以正确输出。
我自己写了个函数,可以输出正确结果。

#include <iostream>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <ifaddrs.h>
#include <sstream>

using namespace std;

string getip(const sockaddr_in* addr)
{
    ostringstream s;
    int a = ntohl(addr->sin_addr.s_addr);
    s << ((a >> 24) & 0xFF) << '.' << ((a >> 16) & 0xFF) << '.'
      << ((a >> 8) & 0xFF) << '.' << (a & 0xFF);
    return s.str();
}


int main(void) 
{
    struct ifaddrs* myaddrs;
    struct sockaddr_in *ss, *kk;
    char buf[100];
    if (getifaddrs(&myaddrs) == 0) {
        for (struct ifaddrs* ifa = myaddrs; ifa != NULL; ifa = ifa->ifa_next) {
            ss = (struct sockaddr_in*) ifa->ifa_addr;
            kk = (struct sockaddr_in*) ifa->ifa_netmask;
            if (ss->sin_family == AF_INET)
                cout << ifa->ifa_name << ":" << getip(ss) << " netmask:" << getip(kk) << endl;
        }
    }
    return 0;
}

利用inet_ntop函数可以得到正确的结果

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题