我将 IP地址值存储到字符数组(uint8_t)中,其大小为4个字节,而不是我需要将这些值存储到单整数,该怎么做
uint8_t ip[4];
str = "192.168.1.1";
sscanf(str,"%hhu.%hhu.%hhu.%hhu",&ip[0],&ip[1],&ip[2],&ip[3]);
以上代码用于将 IP地址值存储到 char(uint8_t) array
答案 0 :(得分:1)
即使你的问题已经解决了,我也很喜欢你的问题,所以我决定解决它并为你实施解决方案。希望这能解决您的问题:
/**
* The problem:
*
* 1 9 2 . 1 6 8 . 0 0 0 . 0 0 1
*
* How to store this in an int (32 bits)?
*
* Hum, let's see: 2^8 = 0-255 (stores values from 0 to 255)
*
* 2^(8 + 8 + 8 + 8) = 2^32 = sizeof(int) = 4 => nice!
*
* We can store four numbers from 0 to 255 in it, great!
*
*
* Draft of solution:
*
* int ipaddress = 0; //0x00000000
*
* ipaddress = (192 << 32 - 8*1) || (168 << 32 - 8*2) || (0 << 32 - 8*3) || 1;
*
* classA_part = (ipaddress & 0xff000000) >> (32 - 8*1)
* classB_part = (ipaddress & 0xff0000) >> (32 - 8*2)
* classC_part = (ipaddress & 0xff00) >> (32 - 8*3)
* classD_part = ipaddress & 0xff
*
* Let's implement shall we?!
*/
初始解决方案:
#define UPPER32 24
#define UPPER16 16
#define UPPER8 8
int main(void)
{
int ipaddr = 192 << UPPER32 | 168 << UPPER16 | 0 << UPPER8 | 1; //192 168 000 001
printf("ip address: %d.%d.%d.%d\n",
((ipaddr & 0xff000000) >> UPPER32) & 0xff,
(ipaddr & 0xff0000) >> UPPER16,
(ipaddr & 0xff00) >> UPPER8,
(ipaddr & 0xff)
);
return 0;
}
请注意,因为您正在管理位以控制如何在其中存储内容,所以您需要将位移回最低位的位置,以便实际获取值。
另外要小心这部分((ipaddr & 0xff000000) >> UPPER32) & 0xff
这可以在没有& 0xff
的机器上工作,因为我的机器是64位,而我的64位整数的扩展信号是0,如果你的机器架构碰巧如果是32位,那么这将从位31延伸到位9,这是一个负数,因此你的192将是其他东西,甚至不接近192.
无论如何,通过使用0xff
的最终掩码,我们确保在9到31或63(x64)的位中不会超过0。
顺便说一句,这个输出将是:
ip address: 192.168.0.1
Program ended with exit code: 0
继续,请注意,按原样编写的代码对某些人来说可能很奇怪,并不是每个人都想处理位,所以通过简化我的初始解决方案可以实现更优雅的方法,请查看:
#define UPPER32 24
#define UPPER16 16
#define UPPER8 8
#define IPADDRESS(a,b,c,d) (a << UPPER32 | b << UPPER16 | c << UPPER8 | d)
#define IPADDRESS_CLASS_A(ip) (((ip & 0xff000000) >> UPPER32) & 0xff)
#define IPADDRESS_CLASS_B(ip) ((ip & 0xff0000) >> UPPER16)
#define IPADDRESS_CLASS_C(ip) ((ip & 0xff00) >> UPPER8)
#define IPADDRESS_CLASS_D(ip) (ipaddr & 0xff)
#define IPADDRESS_FORMAT "%d.%d.%d.%d"
#define EXTRACT_IPADDR(ip) IPADDRESS_CLASS_A(ip), IPADDRESS_CLASS_B(ip), IPADDRESS_CLASS_C(ip), IPADDRESS_CLASS_D(ip)
int main(void)
{
int ipaddr = IPADDRESS(192,168,0,1); //192 168 000 001
printf("ip address: " IPADDRESS_FORMAT "\n", EXTRACT_IPADDR(ipaddr));
return 0;
}
干净的版本看起来更好吧! 注意,参数a,b,c,d指的是ip地址的网络类(A,B,C,D类)。
问候。
<强>更新强>
为了完美,用户(使用它的程序员)将不必费心地打扰IP地址的格式,因此,我添加了包含具有公共IP地址格式的字符串文字的IPADDRESS_FORMAT宏;)
答案 1 :(得分:1)
尝试使用此bit-shifting方法将阵列解析为单个内存位置。
uint8_t ip[4];
str = "192.168.1.1";
sscanf(str,"%hhu.%hhu.%hhu.%hhu",&ip[0],&ip[1],&ip[2],&ip[3]);
uint32_t ans = ip[0] << 24 + ip[1] << 16 + ip[2] << 8 + ip[3];
答案 2 :(得分:0)