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

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>
            亚洲电影自拍| 亚洲国产va精品久久久不卡综合| 久久爱另类一区二区小说| 欧美片第一页| 性欧美暴力猛交69hd| 欧美福利影院| 久久久久久久久久久久久久一区| 午夜精品美女久久久久av福利| 久久久久久久一区二区三区| 亚洲国产91| 欧美日韩中文在线| 久久精品1区| 亚洲激精日韩激精欧美精品| 夜夜狂射影院欧美极品| 国产亚洲欧美色| 欧美日韩一区在线视频| 亚洲午夜精品17c| 国产精品福利影院| 美女脱光内衣内裤视频久久影院| 亚洲国产日韩综合一区| 欧美在线视频观看| 亚洲色诱最新| 亚洲人成小说网站色在线| 欧美午夜精品久久久久久孕妇 | 99精品欧美一区二区三区| 国产精品免费网站在线观看| 老司机成人在线视频| 欧美一区免费视频| 亚洲午夜国产成人av电影男同| 久久综合中文| 欧美中文日韩| 欧美一区二区免费观在线| 国产精品99久久99久久久二8| 亚洲国产精品毛片| 欧美成人中文字幕在线| 亚洲资源av| 欧美96在线丨欧| 宅男66日本亚洲欧美视频 | 在线视频你懂得一区| 亚洲国产日韩欧美在线动漫| 久久日韩粉嫩一区二区三区| 亚洲欧美999| 日韩视频在线观看免费| 亚洲人成毛片在线播放| 亚洲韩国精品一区| 亚洲国产一区二区三区a毛片| 欧美国产国产综合| 亚洲成在线观看| 亚洲国产精品一区二区三区| 亚洲国产va精品久久久不卡综合| 欧美激情亚洲自拍| 欧美一级网站| 性做久久久久久免费观看欧美| 国产精品一区二区在线观看| 美女91精品| 欧美成人免费网| 永久555www成人免费| 一本久久a久久精品亚洲| 亚洲精品一二区| 一区二区三区久久| 蜜桃av一区| 亚洲大胆av| 米奇777超碰欧美日韩亚洲| 亚洲人成在线观看一区二区| 欧美视频中文字幕| 最近中文字幕mv在线一区二区三区四区| 黑人中文字幕一区二区三区| 欧美一级专区免费大片| 欧美日韩在线大尺度| 国产精品免费一区豆花| 亚洲图片你懂的| 久久精品国产99精品国产亚洲性色| 亚洲人成网站影音先锋播放| 在线观看成人小视频| 夜夜嗨av一区二区三区免费区| 欧美激情精品久久久久久免费印度| 亚洲国产一区二区三区在线播| 亚洲一级片在线观看| 亚洲福利视频专区| 亚洲资源在线观看| 国产精品色网| 99亚洲视频| 午夜精品成人在线视频| 国产精品一区免费在线观看| 久久亚洲一区二区三区四区| 国产日韩一区二区三区在线播放 | 欧美日韩在线一区二区| 国产一区二区剧情av在线| 日韩亚洲不卡在线| 91久久精品一区二区三区| 亚洲国产mv| 久久国产精品亚洲va麻豆| 欧美日韩国产经典色站一区二区三区| 国产亚洲人成a一在线v站 | 久久这里有精品视频| 欧美日韩免费观看一区| 在线观看的日韩av| 午夜精品网站| 欧美www视频| 欧美制服第一页| 国产精品第一区| 一区二区日韩精品| 亚洲午夜久久久久久久久电影院 | 国产一区二三区| 亚洲自拍偷拍福利| 亚洲欧洲一区二区三区| 久久精品五月| 国产亚洲女人久久久久毛片| 亚洲伊人伊色伊影伊综合网| 亚洲国产aⅴ天堂久久| 久久琪琪电影院| 国产亚洲成年网址在线观看| 亚洲欧美综合国产精品一区| 日韩一级精品视频在线观看| 欧美jizz19hd性欧美| 久久久久亚洲综合| 欧美色图麻豆| 亚洲精品国产精品久久清纯直播| 亚洲午夜影视影院在线观看| 老司机午夜精品视频| 亚洲午夜未删减在线观看| 欧美精品一区三区在线观看| 伊伊综合在线| 亚洲午夜三级在线| 亚洲国产精品毛片| 欧美jizzhd精品欧美巨大免费| 国产亚洲一区二区三区| 欧美一级久久| 亚洲视频电影图片偷拍一区| 久久精品欧美日韩精品| 亚洲欧美一区二区三区在线| 国产精品免费网站在线观看| 亚洲精品一区二区三区樱花| 欧美3dxxxxhd| 欧美日韩精品| 亚洲欧美日韩天堂| 欧美不卡视频| 欧美一级理论片| 国产深夜精品福利| 理论片一区二区在线| 另类专区欧美制服同性| 亚洲激情一区| 亚洲精品日韩在线| 欧美日韩午夜视频在线观看| 亚洲在线观看免费视频| 性色av一区二区三区在线观看 | 在线性视频日韩欧美| 欧美亚一区二区| 黄色亚洲免费| 欧美激情一区在线观看| 1024精品一区二区三区| 欧美精品黄色| 宅男精品导航| 久久久久国色av免费看影院| 亚洲人人精品| 亚洲欧美日本视频在线观看| 国产亚洲高清视频| 亚洲二区在线观看| 国产精品久久久久aaaa九色| 久久这里有精品15一区二区三区| 欧美1区2区| 欧美综合国产| 欧美日韩免费观看一区三区| 久久九九全国免费精品观看| 欧美成人dvd在线视频| 久久蜜桃香蕉精品一区二区三区| 亚洲综合精品| 久久亚洲视频| 亚洲综合视频1区| 亚洲夫妻自拍| 国产伦精品一区二区三区视频黑人| 久久精品电影| 欧美日韩综合久久| 欧美成人精品1314www| 国产精品国产三级欧美二区| 亚洲欧洲视频在线| 欧美激情按摩| 亚洲一区二区3| 欧美日韩视频在线第一区| 亚洲欧美中文在线视频| 午夜精品视频在线| 国产精品久久久久久久久久妞妞| 欧美黄色免费| 国产欧美在线观看| 美女国产一区| 欧美搞黄网站| 亚洲精品精选| 亚洲欧美在线视频观看| 亚洲黄色免费电影| 亚洲精品国产精品国产自| 噜噜噜躁狠狠躁狠狠精品视频| 蜜桃av一区| 老司机aⅴ在线精品导航| 亚洲一区二区三区四区视频| 亚洲图片欧洲图片日韩av| 国产精品wwwwww| 亚洲少妇中出一区| 欧美激情网站在线观看| 日韩小视频在线观看专区| 欧美日韩视频在线|