C++中怎么實現(xiàn)一個IP地址類,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
在朗縣等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供網(wǎng)站制作、網(wǎng)站建設(shè) 網(wǎng)站設(shè)計制作定制設(shè)計,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站制作,營銷型網(wǎng)站建設(shè),成都外貿(mào)網(wǎng)站建設(shè),朗縣網(wǎng)站建設(shè)費用合理。
【項目-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)存中存儲方式的講解》](https://www.jb51.net/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)存中存儲方式的講解》](https://www.jb51.net/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; }
看完上述內(nèi)容,你們掌握C++中怎么實現(xiàn)一個IP地址類的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
本文名稱:C++中怎么實現(xiàn)一個IP地址類
文章起源:http://muchs.cn/article48/pjpohp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作、定制網(wǎng)站、手機網(wǎng)站建設(shè)、網(wǎng)站策劃、做網(wǎng)站、外貿(mào)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)