C++實(shí)踐IP地址類項(xiàng)目參考
【項(xiàng)目-IP地址類】
在互聯(lián)網(wǎng)中使用的IP地址占4字節(jié),可以用四段法表示,每段值的范圍為0-255,中間用“.”隔開,例如202.194.116.97。其實(shí),也可以看看一個(gè)有4字節(jié)的無符號(hào)整型值3401741409。
現(xiàn)設(shè)計(jì)一個(gè)IP地址類,用于保存IP地址,并實(shí)施在IP地址上的一些操作。如下所示:
class IP
{
private:
  union //由此匿名聯(lián)合體可以看出,IP地址共占4個(gè)字節(jié)
  {
    struct //這是一個(gè)由4個(gè)字節(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地址可以看成一個(gè)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ò)
};
//實(shí)現(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<<"兩個(gè)IP在同一子網(wǎng)"<<endl;
  else
    cout<<"兩個(gè)IP不在同一子網(wǎng)"<<endl;
  cout<<"ip1屬于"<<ip1.whatKind()<<"類網(wǎng)絡(luò)"<<endl;
  return 0;
}
相關(guān)的背景知識(shí)請(qǐng)通過搜索引擎找到。在給出的代碼中,也通過注釋給了一些背景知識(shí)的介紹。
如果覺得寫出來太難,可以將本題作為代碼閱讀題看待。
參考解答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; //或者看成一個(gè)整體
  };
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ù)存儲(chǔ)結(jié)構(gòu),參考[《整型數(shù)據(jù)在內(nèi)存中存儲(chǔ)方式的講解》](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)掩碼按位與,是計(jì)算機(jī)內(nèi)部的操作,直接以一個(gè)整體操作更方便
  unsigned int i1, i2;
  i1=address&mark.address; //和子網(wǎng)掩碼作邏輯與運(yùn)算
  i2=ip.address&mark.address; //和子網(wǎng)掩碼作邏輯與運(yùn)算
  return (i1==i2); //與子網(wǎng)掩碼的邏輯與運(yùn)算結(jié)果相同,則屬于同一子網(wǎng)
}
char IP::whatKind()
{
  //IP地址的類型,請(qǐng)到百度百科中搜索《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<<"兩個(gè)IP在同一子網(wǎng)"<<endl;
  else
    cout<<"兩個(gè)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é),或者看成無符號(hào)字符數(shù)組所指4部分
    unsigned int address; //或者看成一個(gè)整體
  };
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ù)存儲(chǔ)結(jié)構(gòu),參考[《整型數(shù)據(jù)在內(nèi)存中存儲(chǔ)方式的講解》](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)掩碼按位與,是計(jì)算機(jī)內(nèi)部的操作,直接以一個(gè)整體操作更方便
  unsigned int i1, i2;
  i1=address&mark.address; //和子網(wǎng)掩碼作邏輯與運(yùn)算
  i2=ip.address&mark.address; //和子網(wǎng)掩碼作邏輯與運(yùn)算
  return (i1==i2); //與子網(wǎng)掩碼的邏輯與運(yùn)算結(jié)果相同,則屬于同一子網(wǎng)
}
char IP::whatKind()
{
  //IP地址的類型,請(qǐng)到百度百科中搜索《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<<"兩個(gè)IP在同一子網(wǎng)"<<endl;
  else
    cout<<"兩個(gè)IP不在同一子網(wǎng)"<<endl;
  cout<<"ip1屬于"<<ip1.whatKind()<<"類網(wǎng)絡(luò)"<<endl;
  return 0;
}
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)我們的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
上一篇:C++實(shí)踐排序函數(shù)模板項(xiàng)目的參考方法
欄 目:C語(yǔ)言
下一篇:整型數(shù)據(jù)在內(nèi)存中存儲(chǔ)方式的講解
本文標(biāo)題:C++實(shí)踐IP地址類項(xiàng)目參考
本文地址:http://www.jygsgssxh.com/a1/Cyuyan/435.html
您可能感興趣的文章
- 04-02c語(yǔ)言沒有round函數(shù) round c語(yǔ)言
 - 01-10深入理解C++中常見的關(guān)鍵字含義
 - 01-10使用C++實(shí)現(xiàn)全排列算法的方法詳解
 - 01-10c++中inline的用法分析
 - 01-10用C++實(shí)現(xiàn)DBSCAN聚類算法
 - 01-10全排列算法的非遞歸實(shí)現(xiàn)與遞歸實(shí)現(xiàn)的方法(C++)
 - 01-10C++大數(shù)模板(推薦)
 - 01-10淺談C/C++中的static與extern關(guān)鍵字的使用詳解
 - 01-10深入C/C++浮點(diǎn)數(shù)在內(nèi)存中的存儲(chǔ)方式詳解
 - 01-10深入理解C/C++混合編程
 


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
 - 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
 - 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
 - 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
 - 5c語(yǔ)言計(jì)算三角形面積代碼
 - 6什么是 WSH(腳本宿主)的詳細(xì)解釋
 - 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
 - 8正則表達(dá)式匹配各種特殊字符
 - 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
 - 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
 
本欄相關(guān)
- 04-02c語(yǔ)言函數(shù)調(diào)用后清空內(nèi)存 c語(yǔ)言調(diào)用
 - 04-02func函數(shù)+在C語(yǔ)言 func函數(shù)在c語(yǔ)言中
 - 04-02c語(yǔ)言的正則匹配函數(shù) c語(yǔ)言正則表達(dá)
 - 04-02c語(yǔ)言用函數(shù)寫分段 用c語(yǔ)言表示分段
 - 04-02c語(yǔ)言中對(duì)數(shù)函數(shù)的表達(dá)式 c語(yǔ)言中對(duì)
 - 04-02c語(yǔ)言編寫函數(shù)冒泡排序 c語(yǔ)言冒泡排
 - 04-02c語(yǔ)言沒有round函數(shù) round c語(yǔ)言
 - 04-02c語(yǔ)言分段函數(shù)怎么求 用c語(yǔ)言求分段
 - 04-02C語(yǔ)言中怎么打出三角函數(shù) c語(yǔ)言中怎
 - 04-02c語(yǔ)言調(diào)用函數(shù)求fibo C語(yǔ)言調(diào)用函數(shù)求
 
隨機(jī)閱讀
- 04-02jquery與jsp,用jquery
 - 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
 - 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
 - 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
 - 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
 - 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
 - 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
 - 01-10delphi制作wav文件的方法
 - 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
 - 01-10C#中split用法實(shí)例總結(jié)
 


