国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

C++實踐IP地址類項目參考

2020-01-26 13:31:38
字體:
供稿:網(wǎng)友

【項目-IP地址類】

在互聯(lián)網(wǎng)中使用的IP地址占4字節(jié),可以用四段法表示,每段值的范圍為0-255,中間用“.”隔開,例如202.194.116.97。其實,也可以看看一個有4字節(jié)的無符號整型值3401741409。

現(xiàn)設(shè)計一個IP地址類,用于保存IP地址,并實施在IP地址上的一些操作。如下所示:

class IP{private:  union //由此匿名聯(lián)合體可以看出,IP地址共占4個字節(jié)  {    struct //這是一個由4個字節(jié)構(gòu)成的匿名結(jié)構(gòu)體    {      unsigned char seg0;      unsigned char seg1;      unsigned char seg2;      unsigned char seg3;    }; //4字節(jié)的IP地址可以看作4部分,每部分1字節(jié)    unsigned int address; //4字節(jié)的IP地址可以看成一個4字節(jié)的整體  };public:  IP(int=0,int=0,int=0,int=0); //構(gòu)造函數(shù)  void showIP(); //用四段法顯示IP地址  bool sameSubnet(const IP &ip, const IP &mark); //判斷是否處于同一子網(wǎng)  char whatKind(); //返回屬于哪一類網(wǎng)絡(luò)};//實現(xiàn)成員函數(shù)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在同一子網(wǎng)"<<endl;  else    cout<<"兩個IP不在同一子網(wǎng)"<<endl;  cout<<"ip1屬于"<<ip1.whatKind()<<"類網(wǎng)絡(luò)"<<endl;  return 0;}

相關(guān)的背景知識請通過搜索引擎找到。在給出的代碼中,也通過注釋給了一些背景知識的介紹。

如果覺得寫出來太難,可以將本題作為代碼閱讀題看待。

參考解答1:

#include <iostream>using namespace std;class IP{private:  union  {    struct    {      unsigned char seg0;      unsigned char seg1;      unsigned char seg2;      unsigned char seg3;    }; //IP地址共4字節(jié),或者看成結(jié)構(gòu)體所指4部分    unsigned int address; //或者看成一個整體  };public:  IP(int=0,int=0,int=0,int=0); //構(gòu)造函數(shù)  void showIP(); //用四段法顯示IP地址  bool sameSubnet(const IP &ip, const IP &mark); //判斷是否處于同一子網(wǎng)  char whatKind(); //返回屬于哪一類網(wǎng)絡(luò)};IP::IP(int s0,int s1,int s2,int s3){  //下面賦值的順序,涉及整型數(shù)據(jù)存儲結(jié)構(gòu),參考[《整型數(shù)據(jù)在內(nèi)存中存儲方式的講解》](http://m.survivalescaperooms.com/article/156606.htm)  seg3=s0;  seg2=s1;  seg1=s2;  seg0=s3;}void IP::showIP(){  //顯示結(jié)果,是給人看的,分4段合適  cout<<int(seg3)<<"."<<int(seg2)<<"."<<int(seg1)<<"."<<int(seg0)<<endl;  return;}bool IP::sameSubnet(const IP &ip, const IP &mark){  //與子網(wǎng)掩碼按位與,是計算機內(nèi)部的操作,直接以一個整體操作更方便  unsigned int i1, i2;  i1=address&mark.address; //和子網(wǎng)掩碼作邏輯與運算  i2=ip.address&mark.address; //和子網(wǎng)掩碼作邏輯與運算  return (i1==i2); //與子網(wǎng)掩碼的邏輯與運算結(jié)果相同,則屬于同一子網(wǎng)}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在同一子網(wǎng)"<<endl;  else    cout<<"兩個IP不在同一子網(wǎng)"<<endl;  cout<<"ip1屬于"<<ip1.whatKind()<<"類網(wǎng)絡(luò)"<<endl;  return 0;}

參考解答2:

#include <iostream>using namespace std;class IP{private:  union  {    unsigned char seg[4]; //IP地址共4字節(jié),或者看成無符號字符數(shù)組所指4部分    unsigned int address; //或者看成一個整體  };public:  IP(int=0,int=0,int=0,int=0);  void showIP();  bool sameSubnet(const IP &ip, const IP &mark);  char whatKind();};IP::IP(int s0,int s1,int s2,int s3){  //下面賦值的順序,涉及整型數(shù)據(jù)存儲結(jié)構(gòu),參考[《整型數(shù)據(jù)在內(nèi)存中存儲方式的講解》](http://m.survivalescaperooms.com/article/156606.htm)  seg[0]=s3;  seg[1]=s2;  seg[2]=s1;  seg[3]=s0;}void IP::showIP(){  //顯示結(jié)果,是給人看的,分4段合適  cout<<int(seg[3])<<"."<<int(seg[2])<<"."<<int(seg[1])<<"."<<int(seg[0])<<endl;  return;}bool IP::sameSubnet(const IP &ip, const IP &mark){  //與子網(wǎng)掩碼按位與,是計算機內(nèi)部的操作,直接以一個整體操作更方便  unsigned int i1, i2;  i1=address&mark.address; //和子網(wǎng)掩碼作邏輯與運算  i2=ip.address&mark.address; //和子網(wǎng)掩碼作邏輯與運算  return (i1==i2); //與子網(wǎng)掩碼的邏輯與運算結(jié)果相同,則屬于同一子網(wǎng)}char IP::whatKind(){  //IP地址的類型,請到百度百科中搜索《IP地址》  if(seg[3]<128)    return 'A';  else if(seg[3]<192)    return 'B';  else if(seg[3]<224)    return 'C';  else if(seg[3]<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在同一子網(wǎng)"<<endl;  else    cout<<"兩個IP不在同一子網(wǎng)"<<endl;  cout<<"ip1屬于"<<ip1.whatKind()<<"類網(wǎng)絡(luò)"<<endl;  return 0;}

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對武林網(wǎng)的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 永清县| 镇宁| 安西县| 阿拉尔市| 新绛县| 柳州市| 贺兰县| 昆明市| 友谊县| 虞城县| 峨山| 通河县| 罗甸县| 巧家县| 曲沃县| 杭州市| 新余市| 蒲城县| 衢州市| 青州市| 昌平区| 东光县| 田林县| 宕昌县| 北票市| 焉耆| 海淀区| 沅陵县| 伽师县| 常熟市| 大渡口区| 阿拉善左旗| 藁城市| 赞皇县| 雅江县| 老河口市| 依安县| 安图县| 交城县| 玛纳斯县| 日喀则市|