IP地址字符串与整数互转可通过手动位运算或标准库函数实现,前者使用stringstream解析并移位组合字节,后者调用inet_addr和inet_ntoa处理更安全。
在c++中,IP地址字符串(如”192.168.1.1″)和整数之间的相互转换是网络编程中的常见需求。这种转换通常用于简化IP地址的存储、比较或传输。下面介绍如何实现IP地址字符串与32位无符号整数之间的相互转换。
IP字符串转整数
将点分十进制的IP地址字符串转换为32位整数,需要按字节解析每一部分,并组合成一个整数。
可以使用std::stringstream或sscanf来拆分字符串,然后将四个字节合并为一个uint32_t类型的值。
示例代码:
#include <iostream> #include <sstream> #include <string> #include <cstdint> uint32_t ipToInteger(const std::string& ip) { uint32_t a, b, c, d; char dot; std::stringstream ss(ip); ss >> a >> dot >> b >> dot >> c >> dot >> d; return (a << 24) | (b << 16) | (c << 8) | d; }
这个函数读取IP的四个部分,然后通过位移操作组合成一个32位整数。注意:这种方式假设输入格式正确,实际使用中应加入错误检查。
立即学习“C++免费学习笔记(深入)”;
整数转IP字符串
将32位整数还原为点分十进制字符串,需要提取每个字节并格式化输出。
通过位运算分别取出高到低的四个字节,再拼接成字符串。
示例代码:
std::string integerToIp(uint32_t num) { std::stringstream ss; ss << ((num >> 24) & 0xFF) << "." << ((num >> 16) & 0xFF) << "." << ((num >> 8) & 0xFF) << "." << (num & 0xFF); return ss.str(); }
每次右移8位并与0xFF进行与操作,确保只取一个字节的值,避免符号扩展等问题。
使用标准库函数(推荐方式)
C++中也可以借助POSIX标准提供的网络函数进行更安全的转换。
inet_addr可将IP字符串转为整数(返回in_addr_t),而inet_ntoa则将整数转为字符串。
示例代码:
#include <iostream> #include <string> #include <arpa/inet.h> // linux/macos // #include <winsock2.h> // windows uint32_t ipToIntegerLib(const std::string& ip) { return static_cast<uint32_t>(inet_addr(ip.c_str())); } std::string integerToIpLib(uint32_t num) { in_addr addr; addr.s_addr = num; return std::string(inet_ntoa(addr)); }
这些函数自动处理字节序问题,且对输入有一定校验能力,适合实际项目使用。注意在Windows平台需初始化Winsock。
基本上就这些。手动实现有助于理解原理,标准库函数更适合生产环境。根据平台和需求选择合适的方法即可。