ip地址类
来源:互联网 发布:sql 2005 sa 默认密码 编辑:程序博客网 时间:2024/06/06 07:51
问题及描述;
/* *Copyright (c) 2016,烟台大学计算机学院 *All rights reserved. *文件名称;test.cpp *作者;邱凯 *完成日期;2016年4月13号 *版本号;v6.0 *问题描述; IP地址类 *输入描述; 无 *输出描述; 输出答案*/#include <iostream>using namespace std;class IP{private: union { struct { unsigned char seg0; unsigned char seg1; unsigned char seg2; unsigned char seg3; }; //IP地址共4字节,或者看成结构体所指4部分 unsigned int address; //或者看成一个整体 };public: IP(int=0,int=0,int=0,int=0); //构造函数 void showIP(); //用四段法显示IP地址 bool sameSubnet(const IP &ip, const IP &mark); //判断是否处于同一子网 char whatKind(); //返回属于哪一类网络};IP::IP(int s0,int s1,int s2,int s3){ //下面赋值的顺序,涉及整型数据存储结构,参考[《整型数据在内存中如何存储?》](http://blog.csdn.net/sxhelijian/article/details/51015706) seg3=s0; seg2=s1; seg1=s2; seg0=s3;}void IP::showIP(){ //显示结果,是给人看的,分4段合适 cout<<int(seg3)<<"."<<int(seg2)<<"."<<int(seg1)<<"."<<int(seg0)<<endl; return;}bool IP::sameSubnet(const IP &ip, const IP &mark){ //与子网掩码按位与,是计算机内部的操作,直接以一个整体操作更方便 unsigned int i1, i2; i1=address&mark.address; //和子网掩码作逻辑与运算 i2=ip.address&mark.address; //和子网掩码作逻辑与运算 return (i1==i2); //与子网掩码的逻辑与运算结果相同,则属于同一子网}char IP::whatKind(){ //IP地址的类型,请到百度百科中搜索《IP地址》 if(seg3<128) return 'A'; else if(seg3<192) return 'B'; else if(seg3<224) return 'C'; else if(seg3<240) return 'D'; else return 'E';}int main(){ IP ip1(202,194,116,97), ip2(202,194,119,102), mark(255,255,248,0); cout<<"ip1: "; ip1.showIP(); cout<<"ip2: "; ip2.showIP(); if(ip1.sameSubnet(ip2,mark)) cout<<"两个IP在同一子网"<<endl; else cout<<"两个IP不在同一子网"<<endl; cout<<"ip1属于"<<ip1.whatKind()<<"类网络"<<endl; return 0;}
0 0
- IP地址类
- IP地址类
- IP地址类
- IP地址类
- IP地址类
- IP地址类
- IP地址类
- ip地址类
- IP地址类
- IP地址类
- IP地址类
- IP地址类
- IP地址类
- ip地址类
- 五类IP地址
- 私有IP,A类IP地址,B类IP地址,C类IP地址
- [网络TCP/IP]五类IP地址
- IP五类地址划分
- Bencode的编码与解码
- 高流量站点NGINX与PHP-fpm配置优化
- 获取控件的高度
- 双网卡双ip设置(转载)
- Git详解之四 服务器上的Git
- ip地址类
- IDEA UL pom.xml报错,加载不了maven依赖库
- c语言字符串函数总结(超级全)
- Git详解之五 分布式Git
- 关于android混淆
- 剑指offer 从尾到头打印链表
- 推荐一个压缩图片,但是品质影响不大的网站(二)之原理探索
- CQOI2016 bzoj4519 不同的最小割cuts
- CSRF攻击方式