雷火电竞-中国电竞赛事及体育赛事平台

歡迎來到入門教程網(wǎng)!

C語(yǔ)言

當(dāng)前位置:主頁(yè) > 軟件編程 > C語(yǔ)言 >

C++實(shí)踐IP地址類項(xiàng)目參考

來源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:C語(yǔ)言|點(diǎn)擊:

【項(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

網(wǎng)頁(yè)制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語(yǔ)言數(shù)據(jù)庫(kù)服務(wù)器

如果侵犯了您的權(quán)利,請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有