国产探花免费观看_亚洲丰满少妇自慰呻吟_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://www.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://www.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ā)表
主站蜘蛛池模板: 沙雅县| 无锡市| 株洲市| 湖州市| 云林县| 额尔古纳市| 枣强县| 华亭县| 杭锦旗| 秭归县| 岳普湖县| 德化县| 大悟县| 乌鲁木齐县| 札达县| 东宁县| 友谊县| 衢州市| 房山区| 佛学| 嘉义市| 沾化县| 延寿县| 黎平县| 同江市| 灵璧县| 西昌市| 喀喇沁旗| 鹤峰县| 榆中县| 高尔夫| 定日县| 都江堰市| 榕江县| 扬中市| 迁西县| 江源县| 郴州市| 开鲁县| 新巴尔虎右旗| 布拖县|