青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 183,  comments - 10,  trackbacks - 0

前綴匹配

網(wǎng)絡(luò)層的數(shù)據(jù)報(bào)網(wǎng)絡(luò),在路由器轉(zhuǎn)發(fā)功能實(shí)現(xiàn)中會(huì)用到前綴匹配,即是對(duì) IP 地址與路由表中的目的地址范圍的公共部分進(jìn)行前綴匹配。
由于有的前綴存在包含的問題,對(duì)有些 IP 地址會(huì)造成多重匹配,短的匹配會(huì)造成 IP 的轉(zhuǎn)發(fā)錯(cuò)誤。
所以可以遵循 最長前綴匹配原則 進(jìn)行匹配。

首先做一個(gè) ip 轉(zhuǎn)換的實(shí)現(xiàn)
從 unsigned int 32 位整型數(shù)到 ip 字符串的轉(zhuǎn)換
從 ip 字符串到 unsigned int 32 位整型數(shù)的轉(zhuǎn)換

 1 #include <cstdio>
 2 #include <iostream>
 3 #include <string>
 4 using namespace std;
 5 
 6 string uintToIp(unsigned nip)
 7 {
 8     int t[4];
 9     for (int i = 3; i >= 0--i)
10     {
11         t[i] = nip % 256;
12         nip /= 256;
13     }
14     string ret;
15     char s[4];
16     for (int i = 0; i < 3++i)
17     {
18         ret += itoa(t[i], s, 10);
19         ret += '.';
20     }
21     return ret += itoa(t[3], s, 10);
22 }
23 
24 unsigned ipToUint(const string& ip)
25 {
26     unsigned ret = 0;
27     string::size_type st1 = 0, st2 = 0;
28     string t;
29     while ((st2 = ip.find('.', st1)) != string::npos)
30     {
31         t = ip.substr(st1, st2 - st1);
32         ret = ret * 256 + atoi(t.c_str());
33         st1 = st2 + 1;
34     }
35     t = ip.substr(st1, ip.size() - st2);
36     return ret = ret * 256 + atoi(t.c_str());
37 }
38 
39 int main()
40 {
41     unsigned nip;
42     string   ip;
43     while (cin >> nip)
44     {
45         cout << uintToIp(nip) << endl;
46 
47         cin >> ip;
48         cout << ipToUint(ip)  << endl;
49     }
50     return 0;
51 }

 

ip 的形式有三種
·點(diǎn)式十進(jìn)制
·二進(jìn)制
·unsigned
它們之間的轉(zhuǎn)換以 unsigned 為橋梁

前綴匹配的實(shí)現(xiàn)
利用異或,與前綴進(jìn)行異或,如果得到的結(jié)果的相應(yīng)位都為 0 則說明匹配成功,否則沒有匹配成功。
------------------------------
前綴匹配   鏈路接口
xxxxxxxxxxx   0
xxxxxxxxxxxxxx  1
xxxxxxxxxxx   2
其他    3
------------------------------
前綴匹配也可以直接尋找在轉(zhuǎn)發(fā)表里的排序前綴中,第一個(gè)大于待匹配的 ip 的那個(gè)前綴即是前綴匹配成功的。

 

  1 #include <cstdio>
  2 #include <iostream>
  3 #include <string>
  4 #include <map>
  5 using namespace std;
  6 
  7 string uintToIp(unsigned nip)
  8 {
  9     int t[4];
 10     for (int i = 3; i >= 0--i)
 11     {
 12         t[i] = nip % 256;
 13         nip /= 256;
 14     }
 15     string ret;
 16     char s[4];
 17     for (int i = 0; i < 3++i)
 18     {
 19         ret += itoa(t[i], s, 10);
 20         ret += '.';
 21     }
 22     return ret += itoa(t[3], s, 10);
 23 }
 24 
 25 unsigned ipToUint(const string& ip)
 26 {
 27     unsigned ret = 0;
 28     string::size_type st1 = 0, st2 = 0;
 29     string t;
 30     while ((st2 = ip.find('.', st1)) != string::npos)
 31     {
 32         t = ip.substr(st1, st2 - st1);
 33         ret = ret * 256 + atoi(t.c_str());
 34         st1 = st2 + 1;
 35     }
 36     t = ip.substr(st1, ip.size() - st2);
 37     return ret = ret * 256 + atoi(t.c_str());
 38 }
 39 
 40 unsigned binaryIpToUint(const string& bip)
 41 {
 42     unsigned ret = 0;
 43     for (string::size_type i = 0; i != bip.size(); ++i)
 44     {
 45         ret = ret * 2 + (bip[i] - '0');
 46     }
 47     return ret;
 48 }
 49 
 50 string uintToBinaryIp(unsigned uip)
 51 {
 52     string ret;
 53     for (int i = 0; i != 32++i)
 54     {
 55         if (uip >= (1 << 31))
 56         {
 57             ret += '1';
 58         }
 59         else
 60         {
 61             ret += '0';
 62         }
 63         uip <<= 1;
 64     }
 65     return ret;
 66 }
 67 
 68 string binaryIpToIp(const string& bip)
 69 {
 70     return uintToIp(binaryIpToUint(bip));
 71 }
 72 
 73 string ipToBinaryIp(const string& ip)
 74 {
 75     return uintToBinaryIp(ipToUint(ip));
 76 }
 77 
 78 //unsigned findNonZeroBitNo(unsigned prefix)
 79 //{
 80 //    unsigned ret = 0;
 81 //    unsigned mask = 1 << 31;
 82 //    while ((prefix & mask) == 0)
 83 //    {
 84 //        ++ret;
 85 //        prefix <<= 1;
 86 //    }
 87 //    return ret;
 88 //}
 89 
 90 bool marchPrefix(unsigned nip, const string& prefix)
 91 {
 92     string ip = uintToBinaryIp(nip);
 93     return ip.substr(0, prefix.size()) == prefix;
 94 }
 95 
 96 struct Prefix
 97 {
 98     string bip;
 99     Prefix(const string& s) : bip(s) {}
100 };
101 
102 bool operator < (const Prefix& lhs, const Prefix& rhs)
103 {
104     if (lhs.bip < rhs.bip)
105     {
106         if (rhs.bip.find(lhs.bip) != string::npos)
107         {
108             return false;
109         }
110         else
111         {
112             return true;
113         }
114     }
115     else if (lhs.bip > rhs.bip)
116     {
117         if (lhs.bip.find(rhs.bip) != string::npos)
118         {
119             return true;
120         }
121         else
122         {
123             return false;
124         }
125     }
126     else
127     {
128         return false;
129     }
130 }
131 
132 bool operator == (const Prefix& lhs, const Prefix& rhs)
133 {
134     return lhs.bip == rhs.bip;
135 }
136 
137 int main()
138 {
139     map<Prefix, unsigned> forwardingtable;
140     forwardingtable[Prefix("110010000001011100010")] = 0;
141     forwardingtable[Prefix("110010000001011100011000")] = 1;
142     forwardingtable[Prefix("110010000001011100011")] = 2;
143 
144     for (map<Prefix, unsigned>::const_iterator cit = forwardingtable.begin(); cit != forwardingtable.end(); ++cit)
145     {
146         cout << cit->first.bip << '\t' << cit->second << endl;
147     }
148 
149     unsigned nip;
150     string   ip;
151     while (cin >> ip)
152     {
153         nip = ipToUint(ip);
154         //cout << nip << endl;
155         unsigned linkinterface = 3;
156         for (map<Prefix, unsigned>::const_iterator cit = forwardingtable.begin(); cit != forwardingtable.end(); ++cit)
157         {
158             if (marchPrefix(nip, cit->first.bip) == true)
159             {
160                 linkinterface = cit->second;
161                 break;
162             }
163         }
164         cout << linkinterface << endl;
165     }
166     return 0;
167 }



posted on 2011-06-17 14:36 unixfy 閱讀(813) 評(píng)論(0)  編輯 收藏 引用

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美一区二区三区精品电影| 欧美日韩高清免费| 欧美福利视频网站| 欧美激情第五页| 亚洲乱亚洲高清| 亚洲综合精品四区| 久久精品人人做人人爽| 久久综合狠狠综合久久激情| 欧美高清一区| 国产精品久久久久天堂| 国产免费亚洲高清| 亚洲国产精品ⅴa在线观看 | 永久域名在线精品| 亚洲电影视频在线| 亚洲午夜电影| 欧美不卡高清| 一本色道88久久加勒比精品| 国产喷白浆一区二区三区| 欧美一区二区三区久久精品| 久久精品国产精品亚洲精品| 久久久国产视频91| 国产精品久久久免费| 一区二区三区在线视频播放| av成人福利| 久久夜色精品国产| 亚洲免费观看高清完整版在线观看熊 | 免费看的黄色欧美网站| 欧美小视频在线观看| 亚洲精品影视| 久久久国产亚洲精品| 欧美午夜无遮挡| 亚洲电影视频在线| 欧美在线观看一二区| 亚洲日本中文字幕免费在线不卡| 中文精品一区二区三区| 欧美成人久久| 在线精品亚洲| 久久久人成影片一区二区三区观看 | 亚洲狼人精品一区二区三区| 久久九九电影| 国产亚洲观看| 午夜精品久久| 一本久道久久综合中文字幕| 欧美国产一区二区| 亚洲国产婷婷综合在线精品| 久久久久久久综合狠狠综合| 中文国产亚洲喷潮| 欧美日韩精品综合在线| 亚洲精品免费电影| 欧美成人首页| 久久午夜精品一区二区| 永久555www成人免费| 老**午夜毛片一区二区三区| 久久国产精品72免费观看| 国产一区美女| 久久亚洲影院| 老牛国产精品一区的观看方式| 亚洲二区视频在线| 亚洲国产精品成人| 欧美激情国产精品| 一本色道婷婷久久欧美| 日韩视频一区二区| 国产精品九九久久久久久久| 欧美一二三区精品| 欧美一区二区三区在线免费观看 | 亚洲韩国日本中文字幕| 老牛嫩草一区二区三区日本| 欧美日韩国产小视频| 亚洲六月丁香色婷婷综合久久| 免费成人激情视频| 欧美成人在线免费观看| 99视频有精品| 亚洲伊人第一页| 一本到12不卡视频在线dvd| 欧美精品在线视频观看| 亚洲一区二区三区成人在线视频精品| 99视频国产精品免费观看| 国产精品成人一区二区| 性8sex亚洲区入口| 久久精品视频网| 艳女tv在线观看国产一区| 一区二区三区欧美在线| 国产一区二区三区的电影| 欧美大尺度在线| 欧美色欧美亚洲高清在线视频| 亚洲免费中文| 欧美中文字幕不卡| 亚洲国产成人在线| 一区二区三区蜜桃网| 好吊成人免视频| 亚洲精品一区二区在线| 国产一区白浆| 亚洲美女啪啪| 国产精品一区二区你懂得| 久久精品一区四区| 欧美激情1区2区| 欧美一级网站| 欧美精品亚洲二区| 久久视频在线免费观看| 欧美日本不卡高清| 久久九九久久九九| 欧美涩涩网站| 亚洲国产另类久久久精品极度| 国产日韩欧美二区| 99re66热这里只有精品3直播| 国产亚洲一级高清| 一区二区三区视频在线观看| 伊人蜜桃色噜噜激情综合| 亚洲视频每日更新| 亚洲理论在线观看| 久久综合伊人| 快射av在线播放一区| 国产精品一区二区三区乱码| 牛牛影视久久网| 国产亚洲人成a一在线v站| 999亚洲国产精| 亚洲日产国产精品| 久久午夜视频| 老鸭窝亚洲一区二区三区| 国产精品网红福利| 亚洲欧洲在线免费| 亚洲人成在线观看一区二区| 欧美一区二区视频97| 亚洲欧美在线免费| 国产精品国产| 亚洲最新视频在线播放| 夜夜嗨av色综合久久久综合网| 久久激情婷婷| 久久综合一区| 激情欧美一区| 先锋影音国产精品| 久久精品av麻豆的观看方式| 国产午夜精品全部视频在线播放| 免费av成人在线| 亚洲调教视频在线观看| 亚洲大胆美女视频| 麻豆精品一区二区av白丝在线| 99精品热6080yy久久| 在线看片日韩| 伊人夜夜躁av伊人久久| 伊人久久综合| 在线不卡视频| 亚洲精品久久| 另类图片国产| 黄色精品一区| 久久久国产午夜精品| 麻豆精品一区二区综合av| 在线免费观看视频一区| 欧美成人精品激情在线观看 | 欧美中文字幕| 国产欧美日韩另类一区| 欧美一区二区视频97| 免费久久99精品国产自| 亚洲理伦电影| 国产精品视频精品| 久久久久久尹人网香蕉| 欧美黄在线观看| 宅男噜噜噜66一区二区66| 国产精品婷婷| 免费亚洲电影在线| 日韩一级免费观看| 久久久夜夜夜| 一区二区三区欧美日韩| 国产视频欧美视频| 嫩模写真一区二区三区三州| 日韩视频一区二区在线观看| 欧美一区亚洲| 亚洲肉体裸体xxxx137| 国产精品视频一| 欧美成人免费一级人片100| 亚洲一卡久久| 久久综合色播五月| 亚洲一区二区在线免费观看| 国模精品娜娜一二三区| 欧美日韩三级电影在线| 久久国产毛片| 一本色道久久综合亚洲精品按摩| 久久影院午夜论| 亚洲视频在线观看三级| 伊人成人网在线看| 国产精品久久777777毛茸茸| 久久视频精品在线| 亚洲一区二区三区免费视频| 亚洲国产视频一区| 久久免费偷拍视频| 亚洲自拍偷拍视频| 亚洲国产欧美精品| 国产亚洲精品久久飘花| 欧美日韩一区二区三区在线| 久久亚洲美女| 久久国产精品99久久久久久老狼| 国产精品99久久久久久人| 亚洲国产欧美日韩另类综合| 在线观看欧美一区| 免费观看日韩| 亚洲综合激情| 99re热这里只有精品免费视频| 韩日精品视频| 国产一区二区黄| 国产日韩亚洲欧美精品|