C++實踐IP地址類項目參考
【項目-IP地址類】
在互聯(lián)網中使用的IP地址占4字節(jié),可以用四段法表示,每段值的范圍為0-255,中間用“.”隔開,例如202.194.116.97。其實,也可以看看一個有4字節(jié)的無符號整型值3401741409。
現(xiàn)設計一個IP地址類,用于保存IP地址,并實施在IP地址上的一些操作。如下所示:
class IP { private: union //由此匿名聯(lián)合體可以看出,IP地址共占4個字節(jié) { struct //這是一個由4個字節(jié)構成的匿名結構體 { 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); //構造函數(shù) void showIP(); //用四段法顯示IP地址 bool sameSubnet(const IP &ip, const IP &mark); //判斷是否處于同一子網 char whatKind(); //返回屬于哪一類網絡 }; //實現(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在同一子網"<<endl; else cout<<"兩個IP不在同一子網"<<endl; cout<<"ip1屬于"<<ip1.whatKind()<<"類網絡"<<endl; return 0; }
相關的背景知識請通過搜索引擎找到。在給出的代碼中,也通過注釋給了一些背景知識的介紹。
如果覺得寫出來太難,可以將本題作為代碼閱讀題看待。
參考解答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é),或者看成結構體所指4部分 unsigned int address; //或者看成一個整體 }; public: IP(int=0,int=0,int=0,int=0); //構造函數(shù) void showIP(); //用四段法顯示IP地址 bool sameSubnet(const IP &ip, const IP &mark); //判斷是否處于同一子網 char whatKind(); //返回屬于哪一類網絡 }; IP::IP(int s0,int s1,int s2,int s3) { //下面賦值的順序,涉及整型數(shù)據存儲結構,參考[《整型數(shù)據在內存中存儲方式的講解》](https://www.jb51.net/article/156606.htm) 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; }
參考解答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ù)據存儲結構,參考[《整型數(shù)據在內存中存儲方式的講解》](https://www.jb51.net/article/156606.htm) seg[0]=s3; seg[1]=s2; seg[2]=s1; seg[3]=s0; } void IP::showIP() { //顯示結果,是給人看的,分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) { //與子網掩碼按位與,是計算機內部的操作,直接以一個整體操作更方便 unsigned int i1, i2; i1=address&mark.address; //和子網掩碼作邏輯與運算 i2=ip.address&mark.address; //和子網掩碼作邏輯與運算 return (i1==i2); //與子網掩碼的邏輯與運算結果相同,則屬于同一子網 } 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在同一子網"<<endl; else cout<<"兩個IP不在同一子網"<<endl; cout<<"ip1屬于"<<ip1.whatKind()<<"類網絡"<<endl; return 0; }
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對我們的支持。如果你想了解更多相關內容請查看下面相關鏈接
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
- 01-10深入理解C++中常見的關鍵字含義
- 01-10使用C++實現(xiàn)全排列算法的方法詳解
- 01-10c++中inline的用法分析
- 01-10用C++實現(xiàn)DBSCAN聚類算法
- 01-10全排列算法的非遞歸實現(xiàn)與遞歸實現(xiàn)的方法(C++)
- 01-10C++大數(shù)模板(推薦)
- 01-10淺談C/C++中的static與extern關鍵字的使用詳解
- 01-10深入C/C++浮點數(shù)在內存中的存儲方式詳解
- 01-10深入理解C/C++混合編程


閱讀排行
本欄相關
- 04-02c語言函數(shù)調用后清空內存 c語言調用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調用函數(shù)求fibo C語言調用函數(shù)求
隨機閱讀
- 04-02jquery與jsp,用jquery
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10delphi制作wav文件的方法
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-10C#中split用法實例總結