金慶的專欄
C++博客
::
首頁
::
新隨筆
::
聯(lián)系
::
聚合
::
管理
::
423 隨筆 :: 0 文章 :: 454 評論 :: 0 Trackbacks
公告
我的隨筆
我的評論
我參與的隨筆
留言簿
(12)
給我留言
查看公開留言
查看私人留言
隨筆分類
(502)
1. C/C++(166)
(rss)
2. 網(wǎng)游開發(fā)(108)
(rss)
3. Golang(20)
(rss)
4. Linux/Unix(30)
(rss)
5. 軟工與管理(44)
(rss)
6. Python(23)
(rss)
7. Erlang(18)
(rss)
8. Rust(16)
(rss)
9. 其它(77)
(rss)
隨筆檔案
(423)
2023年1月 (1)
2022年11月 (1)
2022年10月 (2)
2022年9月 (1)
2022年4月 (6)
2022年1月 (2)
2021年12月 (4)
2021年11月 (6)
2021年10月 (2)
2021年9月 (2)
2021年8月 (7)
2021年7月 (2)
2021年5月 (2)
2021年3月 (1)
2021年2月 (2)
2021年1月 (1)
2020年12月 (1)
2020年10月 (1)
2020年9月 (5)
2020年8月 (1)
2020年7月 (1)
2020年6月 (1)
2020年4月 (2)
2020年3月 (3)
2020年2月 (3)
2020年1月 (1)
2019年12月 (1)
2019年9月 (2)
2019年4月 (2)
2019年1月 (1)
2018年12月 (1)
2018年11月 (3)
2018年10月 (1)
2018年9月 (3)
2018年8月 (3)
2018年7月 (2)
2018年6月 (4)
2018年5月 (4)
2018年4月 (4)
2018年3月 (1)
2018年1月 (2)
2017年12月 (2)
2017年11月 (3)
2017年10月 (3)
2017年8月 (7)
2017年7月 (1)
2017年6月 (1)
2017年5月 (3)
2017年4月 (3)
2017年3月 (3)
2017年2月 (2)
2017年1月 (2)
2016年12月 (5)
2016年11月 (2)
2016年10月 (2)
2016年9月 (1)
2016年8月 (6)
2016年7月 (3)
2016年6月 (2)
2016年5月 (4)
2016年4月 (2)
2016年3月 (2)
2016年1月 (3)
2015年12月 (2)
2015年11月 (2)
2015年10月 (1)
2015年8月 (2)
2015年7月 (1)
2015年6月 (1)
2015年5月 (4)
2015年4月 (3)
2015年3月 (4)
2015年2月 (5)
2015年1月 (4)
2014年12月 (3)
2014年11月 (3)
2014年10月 (2)
2014年9月 (3)
2014年8月 (1)
2014年4月 (4)
2014年3月 (1)
2014年2月 (4)
2014年1月 (5)
2013年12月 (5)
2013年11月 (5)
2013年9月 (2)
2013年8月 (2)
2013年7月 (2)
2013年6月 (2)
2013年5月 (1)
2013年1月 (2)
2012年12月 (1)
2012年11月 (1)
2012年9月 (1)
2012年8月 (3)
2012年7月 (2)
2012年6月 (1)
2012年4月 (3)
2012年3月 (2)
2012年2月 (3)
2012年1月 (2)
2011年11月 (2)
2011年10月 (3)
2011年9月 (2)
2011年8月 (2)
2011年7月 (3)
2011年6月 (2)
2011年5月 (3)
2011年1月 (2)
2010年12月 (1)
2010年11月 (2)
2010年10月 (2)
2010年9月 (3)
2010年8月 (2)
2010年7月 (3)
2010年6月 (1)
2010年5月 (3)
2010年4月 (3)
2010年3月 (5)
2010年2月 (4)
2010年1月 (4)
2009年12月 (2)
2009年11月 (3)
2009年10月 (4)
2009年9月 (3)
2009年8月 (2)
2009年7月 (4)
2009年6月 (1)
2009年5月 (3)
2009年4月 (4)
2009年3月 (2)
2009年2月 (5)
2009年1月 (1)
2008年12月 (7)
2008年11月 (4)
2008年10月 (1)
2008年9月 (3)
2008年8月 (4)
2008年7月 (3)
2008年6月 (4)
2008年5月 (6)
2008年4月 (7)
2008年3月 (6)
2008年1月 (5)
2007年12月 (7)
2007年11月 (4)
2007年10月 (5)
2007年9月 (6)
2007年8月 (8)
2007年7月 (5)
相冊
公告照片
搜索
積分與排名
積分 - 656592
排名 - 25
最新評論
1.?re: boost::asio::spawn 將一統(tǒng)C++網(wǎng)絡(luò)庫
asio 成為C++首選網(wǎng)絡(luò)庫
--linda
2.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評論內(nèi)容較長,點(diǎn)擊標(biāo)題查看
--金慶
3.?re: mingw編譯OrzNet
能發(fā)送一個(gè)mingw編譯好的OrzNet庫給我嗎? liuweiqcxy@163.com
謝謝!
--劉威
4.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評論內(nèi)容較長,點(diǎn)擊標(biāo)題查看
--bigbad
5.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評論內(nèi)容較長,點(diǎn)擊標(biāo)題查看
--bigbad
閱讀排行榜
1.?"multiple definition of" 錯(cuò)誤(11032)
2.?SVN中邪惡的replace(10955)
3.?VS2005編譯libevent(10413)
4.?混音算法的學(xué)習(xí)與研究(10203)
5.?C調(diào)用lua腳本的效率測試(9007)
評論排行榜
1.?VC6正在被拋棄(35)
2.?VS2005編譯libevent(21)
3.?"multiple definition of" 錯(cuò)誤(18)
4.?C++引用優(yōu)于指針(17)
5.?ACE與ASIO之間關(guān)于Socket編程的比較(16)
公平隊(duì)列的實(shí)現(xiàn)
公平隊(duì)列的實(shí)現(xiàn)
(金慶的專欄)
公平隊(duì)列(Fair Queuing)是一種調(diào)度算法,與先進(jìn)先出隊(duì)列不同,
公平隊(duì)列分成幾個(gè)子隊(duì)列,每個(gè)子隊(duì)列公平地得到處理。
例如上海地鐵站充值窗口有兩個(gè),一個(gè)站外,一個(gè)站內(nèi),由同一位服務(wù)人員受理,
服務(wù)人員會輪流處理兩個(gè)窗口的請求,兩個(gè)窗口的隊(duì)列將公平地得到處理。
公平隊(duì)列應(yīng)用于路由器,保證不同的數(shù)據(jù)流得到公平處理。
Zeromq的消息處理也應(yīng)用了公平隊(duì)列,不會因?yàn)楦邤?shù)據(jù)量的連接阻塞其他連接的處理。
在網(wǎng)游服務(wù)器中,公平隊(duì)列應(yīng)用于消息的處理,解決場景局部擁擠造成整服都卡的問題。
例如消息處理按地圖排隊(duì),這樣某個(gè)地圖的消息擁塞不會影響其他地圖的消息處理。
fair_queue 仿 std::priority_queue 實(shí)現(xiàn)
1
2
/*
Fair queue gives each sub queue a fair share.
3
Author: Jin Qing (
http://blog.csdn.net/jq0123
)
4
5
Example:
6
fair_queue<int, int> fq;
7
fq.push(1, 11);
8
fq.push(1, 12);
9
fq.push(1, 13);
10
fq.push(2, 21);
11
VERIFY(11 == fq.top()); fq.pop();
12
VERIFY(21 == fq.top()); fq.pop();
13
VERIFY(12 == fq.top()); fq.pop();
14
VERIFY(13 == fq.top()); fq.pop();
15
*/
16
17
#ifndef _FAIR_QUEUE_H_
18
#define
_FAIR_QUEUE_H_
19
20
#include
<
queue
>
21
#include
<
boost
/
assert.hpp
>
22
#include
<
boost
/
unordered_map.hpp
>
23
24
//
TEMPLATE CLASS fair_queue
25
template
<
class
_Kty,
class
_Ty
>
26
class
fair_queue
27
{
28
public
:
29
typedef _Kty key_type;
30
typedef _Ty value_type;
31
32
protected
:
33
typedef std::queue
<
velue_type
>
sub_queue_type;
34
typedef boost::unordered_map
<
key_type, sub_queue_type
>
map_type;
35
typedef std::queue
<
sub_queue_type
*>
ordered_queue_type;
36
typedef boost::unordered_map
<
sub_queue_type
*
, key_type
>
reversed_map_type;
37
38
public
:
39
fair_queue() {};
40
41
bool
empty()
const
42
{
//
test if queue is empty
43
return
m.empty();
44
}
45
46
const
value_type
&
top()
const
47
{
//
return top element
48
BOOST_ASSERT(
!
empty());
49
BOOST_ASSERT(q.front());
50
return
q.front()
->
front();
51
}
52
53
value_type top()
54
{
//
return mutable top element
55
BOOST_ASSERT(
!
empty());
56
BOOST_ASSERT(q.front());
57
return
q.front()
->
front();
58
}
59
60
void
push(
const
key_type
&
k,
const
value_type
&
v)
61
{
//
insert value in k sub queue
62
map_type::iterator itr
=
m.find(k);
63
if
(itr
!=
m.end())
64
{
65
BOOST_ASSERT(
!
(
*
itr).second.empty());
66
(
*
itr).second.push(v);
67
return
;
68
}
69
//
new sub queue
70
sub_queue_type
*
sub_queue
=
&
m[k];
71
sub_queue
->
push(v);
72
BOOST_ASSERT(
1
==
sub_queue
->
size());
73
q.push(sub_queue);
74
rm[sub_queue]
=
k;
75
BOOST_ASSERT(q.size()
==
rm.size());
76
BOOST_ASSERT(m.size()
==
q.size());
77
}
78
79
void
pop()
80
{
//
erase top element
81
BOOST_ASSERT(
!
empty());
82
BOOST_ASSERT(
!
q.empty());
83
sub_queue_type
*
sub_queue
=
q.front();
84
q.pop();
85
BOOST_ASSERT(sub_queue);
86
sub_queue
->
pop();
87
if
(
!
sub_queue
->
empty())
88
{
89
//
move to the end
90
q.push(sub_queue);
91
return
;
92
}
93
94
//
erase empty sub queue
95
const
key_type
&
k
=
rm[sub_queue];
96
m.erase(k);
97
rm.erase(sub_queue);
98
BOOST_ASSERT(q.size()
==
rm.size());
99
BOOST_ASSERT(m.size()
==
q.size())
100
}
101
102
protected
:
103
map_type m;
//
container
104
ordered_queue_type q;
//
to order the queues
105
reversed_map_type rm;
//
to delete key in m
106
107
};
108
109
#endif
//
_FAIR_QUEUE_H_
110
111
posted on 2013-11-25 18:09
金慶
閱讀(1076)
評論(0)
編輯
收藏
引用
所屬分類:
1. C/C++
、
2. 網(wǎng)游開發(fā)
只有注冊用戶
登錄
后才能發(fā)表評論。
【推薦】100%開源!大型工業(yè)跨平臺軟件C++源碼提供,建模,組態(tài)!
相關(guān)文章:
How are dtLinks created in NavMesh
C++ parameter passing rules
Naming Conventions for Accessors
Visual Studio 2019 Compiler Hangs
Fbx File Format Identifier
查找內(nèi)存錯(cuò)誤
std::thread 中的異常會丟失調(diào)用棧
用賦值代替 protobuf CopyFrom()
vs2017 linux 編譯輸出改成 vs 格式
為 LiteIDE 添加選中標(biāo)記
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 金慶
精品久久久久久99人妻
|
亚洲国产一成人久久精品
|
久久婷婷国产综合精品
|
伊人久久五月天
|
久久久久噜噜噜亚洲熟女综合
|
精品一区二区久久
|
久久久久99精品成人片试看
|
精品人妻伦九区久久AAA片69
|
精品久久久久久综合日本
|
久久国产欧美日韩精品
|
亚洲日本va中文字幕久久
|
久久九九兔免费精品6
|
怡红院日本一道日本久久
|
情人伊人久久综合亚洲
|
久久亚洲综合色一区二区三区
|
日本精品久久久久中文字幕
|
国内精品久久久久久野外
|
青青青国产成人久久111网站
|
四虎国产精品免费久久久
|
99热成人精品免费久久
|
久久伊人色
|
亚洲综合精品香蕉久久网
|
777午夜精品久久av蜜臀
|
久久精品中文闷骚内射
|
日韩精品久久久久久
|
日韩va亚洲va欧美va久久
|
亚洲精品乱码久久久久久蜜桃不卡
|
久久国产亚洲精品无码
|
国产精品久久久天天影视
|
久久久久久A亚洲欧洲AV冫
|
奇米影视7777久久精品人人爽
|
蜜臀久久99精品久久久久久小说
|
色婷婷综合久久久久中文一区二区
|
久久夜色精品国产网站
|
亚洲成色999久久网站
|
久久性精品
|
国内精品久久国产大陆
|
亚洲国产小视频精品久久久三级
|
97久久国产亚洲精品超碰热
|
色婷婷久久久SWAG精品
|
久久精品国产亚洲av水果派
|