子网掩码

子网掩码(java)

一. 问题描述

【问题描述】

子网掩码是用来判断任意两台计算机的IP地址是否属于同一子网络的根据。子网掩码与 IP 地址结构相同,是32 位二进制数,其中网络号部分全为
“1” 和主机号部分全为 “0” 。利用子网掩码可以判断两台主机是否中同一子网中。若两台主机的IP 地址分别与它们的子网掩码相 “与”
后的结果相同,则说明这两台主机在同一子网中。示例:IP
地址192.168.0.1子网掩码255.255.255.0转化为二进制进行运算:IP地址11010000.10101000.00000000.00000001子网掩码11111111.11111111.11111111.00000000 AND运算11010000.10101000.00000000.00000000转化为十进制后为:192.168.0.0 IP 地址
192.168.0.254子网掩码 255.255.255.0转化为二进制进行运算:IP地址11010000.10101000.00000000.11111110子网掩码11111111.11111111.11111111.00000000 AND运算11010000.10101000.00000000.00000000 转化为十进制后为:192.168.0.0
通过以上对两台计算机IP 地址与子网掩码的 AND
运算后,我们可以看到它运算结果是一样的。均为192.168.0.0,所以这二台计算机可视为是同一子网络。

【输入形式】

输入子网掩码、两个地址

【输出形式】

得到计算结果,如不在同一子网,则输出0

【样例输入】

 255.255.255.0 
 192.168.224.254 
 192.168.10.4 

【样例输出】

 0

二 处理过程

输入处理:
输入三个点分十进制形式的ip地址。

使用sc.nextLine().split("\\.")即可以得到四个对应的字符串;
**split()** 方法用于把一个字符串分割成字符串数组。
var str="How are you doing today?";
var n=str.split(" ");
n 输出一个数组的值:
How,are,you,doing,today?
再将字符串转为十进制即得到ip地址中对应的十进制数。
trim() 方法用于删除字符串的头尾空白符,空白符包括:空格、制表符 tab、换行符等其他空白符等。
trim() 方法不会改变原始字符串。
parseInt() 
该方法用于将字符串参数作为有符号的十进制整数进行解析。
如果方法有两个参数, 使用第二个参数指定的基数,将字符串参数解析为有符号的整数。
static int parseInt(String s)
static int parseInt(String s, int radix)

逻辑关系

分别得到ip地址的四个十进制数之后,再按照逻辑关系,
让两个ip地址与子网掩码进行相与,判断结果是否一致,
一致即这两台计算机可以看作位于同一个子网络中,
否则,不在同一子网络。

输出

设置一个标记flag,通过上述逻辑关系判断是否位于同一子网络,
flag为1,则是,输出1,否则输出0.

三. 源代码

源码:


```java
import java.util.Scanner;

public class SubnetMaskPro{
	public static void main(String[] argv){
		Scanner sc=new Scanner(System.in);
		String[] subnetMask=sc.nextLine().split("\\.");
		String[] ip1=sc.nextLine().split("\\.");
		String[] ip2=sc.nextLine().split("\\.");
		int lenSubnetMask=subnetMask.length;
		int lenIp1=ip1.length;
		int lenIp2=ip2.length;
		boolean flag=true;
		// 输入不正确的ip地址
		if(lenSubnetMask!=4 && lenIp1!=4 || lenIp2!=4){
			System.out.println("please input correct ipv4 address");
		}
		
		// 输入合法
		else{
			for(int i=0;i<4;i++){
				int decSubnetMask=Integer.parseInt(subnetMask[i].trim());
				int decIp1=Integer.parseInt(ip1[i].trim());
				int decIp2=Integer.parseInt(ip2[i].trim());
				if((decSubnetMask&decIp1)!=(decSubnetMask&decIp2)){
					flag=false;
					break;
				}
				
			}
			if(flag==true){
				System.out.println("1");
			}
			else{
				System.out.println("0");
			}
		}
		
	}
}

“在我遇见你以前,总以为爱不能太表面。”
– 《彩券》

嘿嘿嘿这句歌词什么意思呢?

延续传统!
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值