程序员应该懂的ip地址知识汇总

1.A类ip由1字节(1字节是8位2进制数)的网络地址和3字节的主机地址组成,网络地址最高位必须是0,地址范围是从1.0.0.0到126.0.0.0,所以A类网络地址有126个,每个网络能容纳至少2^24(是32-8得来)-2(去掉全0和全1)

   B类ip由2字节网络地址和2字节的主机地址组成,网络地址最高为必须是10,地址范围从128.0.0.0到191.255.255.255,所以B类地址的网络数2^14(16位再去掉10两位),每个网络能容纳的主机数2^16-2

   C类ip由3字节的网络地址和1字节的主机地址组成,网络地址最高必须是110,范围从192.0.0.0到223.255.255.255,所以B类地址的网络数2^21(24位再去掉110三位),每个网络能容纳主机2^8-2

   D类,E类就先不看了。。。感觉网络知识道这一步就OK了。

2.只有在一个网络号下的计算机之间才能“直接”互通,不同网络号的计算机要通过网关(Gateway)才能互通。

3.子网将ip网络划分成更小的网络,而子网掩码,是判断两个ip地址是否处在同一个网络中,这里引用一下百度百科中对于子网掩码的解释:

前面讲到IP地址分网络号和主机号,要将一个网络划分为多个子网,因此网络号将要占用原来的主机位,如对于一个C类地址,它用24位来标识网络号,要将其划分为2个子网则需要占用1位原来的主机标识位。此时网络号位变为25位,主机标示变为7位。同理借用2个主机位则可以将一个C类网络划分为4个子网……那计算机是怎样才知道这一网络是否划分了子网呢?这就可以从子网掩码中看出。子网掩码和IP地址一样有32bit,确定子网掩码的方法是其与IP地址中标识网络号的所有对应位都用"1",而与主机号对应的位都是"0"。如分为2个子网的C类IP地址用25位来标识网络号,则其子网掩码为:11111111 11111111 11111111 10000000即255.255.255.128。于是我们可以知道,A类地址的缺省子网掩码为255.0.0.0,B类为255.255.0.0,C类为255.255.255.0。

总结一下就是子网掩码可以看出对这个网络分了几个子网,每个子网中又有多少个主机,而分配的方式是通过网络位置1,主机位置0这样得到的32位二进制数的十进制表示形式。

4.CIDR表示法:IP地址/网络ID的位数(网段的划分更加灵活)

这个表示法可以判断出所表示的网络的子网掩码和起止ip地址

例如192.168.23.35/21这个表示法得出的子网掩码和ip起止地址:

子网掩码是前21位为1,后11位为0,得到的十进制数是255.255.248.0

起始ip地址:可以看到这个ip是C类地址,192.168是固定的,拿23即00010111与21位减去16位得到的五位加三位主机位的子网掩码即11111000进行与计算,得到00010000,那么起始ip即为192.168.16.1

结束ip地址:即为主机位从起始IP地址变为全为1的状态,即192.168.00001000.0变为网络位21位后全为1的情况,192.168.00001111.11111111,即192.168.23.254。

原文地址:https://www.cnblogs.com/junshijie/p/10234499.html