金慶的專欄
C++博客
::
首頁
::
新隨筆
::
聯系
::
聚合
::
管理
::
423 隨筆 :: 0 文章 :: 454 評論 :: 0 Trackbacks
公告
我的隨筆
我的評論
我參與的隨筆
留言簿
(12)
給我留言
查看公開留言
查看私人留言
隨筆分類
(502)
1. C/C++(166)
(rss)
2. 網游開發(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)
相冊
公告照片
搜索
積分與排名
積分 - 656808
排名 - 25
最新評論
1.?re: boost::asio::spawn 將一統C++網絡庫
asio 成為C++首選網絡庫
--linda
2.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--金慶
3.?re: mingw編譯OrzNet
能發送一個mingw編譯好的OrzNet庫給我嗎? liuweiqcxy@163.com
謝謝!
--劉威
4.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--bigbad
5.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--bigbad
閱讀排行榜
1.?"multiple definition of" 錯誤(11032)
2.?SVN中邪惡的replace(10958)
3.?VS2005編譯libevent(10415)
4.?混音算法的學習與研究(10207)
5.?C調用lua腳本的效率測試(9008)
評論排行榜
1.?VC6正在被拋棄(35)
2.?VS2005編譯libevent(21)
3.?"multiple definition of" 錯誤(18)
4.?C++引用優于指針(17)
5.?ACE與ASIO之間關于Socket編程的比較(16)
STL容器的賦值運算符可以更靈活嗎?
STL容器的賦值運算符可以更靈活嗎?
(轉載請注明來源于金慶的專欄)
STL容器如果元素類型不同是不能相互賦值的,
即使元素類型是兼容的.
如兩個list, 一個存放基類B指針, 一個存放派生類D指針:
class B {};
class D : public B {};
std::list<B*> lB;
std::list<D*> lD;
lB = lD; // ERROR!
編譯報錯
error: no match for 'operator=' in 'lB = lD'|
list.tcc|121|note: candidates are:
std::list<_Tp, _Alloc>& std::list<_Tp, _Alloc>::operator=(
const std::list<_Tp, _Alloc>&)
[with _Tp = B*, _Alloc = std::allocator<B*>]|
而boost::shared_ptr<B>與boost::shared_ptr<D>之間卻可以仍然保持兼容性.
以下賦值與指針賦值一樣是正確的.
boost::shared_ptr<B> pB;
boost::shared_ptr<D> pD;
pB = pD;
因為STL容器與boost::shared_ptr的賦值運算符定義方式不一樣.
boost::shared_ptr賦值運算符中參數的模板參數與類的模板參數不同,
所以支持更靈活的賦值.
boost::shared_ptr<T>& boost::shared_ptr<T>::operator=(
const boost::shared_ptr<Y>&)
只要改寫STL容器的賦值運算符的參數, 同樣可以擴大靈活性.
例如將
list<_Tp,_Alloc>&
list<_Tp,_Alloc>::
operator=(const list& __x)
改為:
list<_Tp,_Alloc>&
list<_Tp,_Alloc>::
operator=(const list<_Tp2, _Alloc2> & __x)
不知為什么STL沒有放開這種靈活性?
posted on 2008-11-12 12:17
金慶
閱讀(2537)
評論(6)
編輯
收藏
引用
所屬分類:
1. C/C++
評論
#
re: STL容器的賦值運算符可以更靈活嗎?
2008-11-12 13:00
ronliu
重載操作符就可以搞定吧
回復
更多評論
#
re: STL容器的賦值運算符可以更靈活嗎?
2008-11-12 23:41
踏雪赤兔
呵呵呵呵~~這個太容易了!
構造:
std::list<B*> lB(lD.begin(), lD.end());
賦值:
lB.assign(lD.begin(), lD.end());
回復
更多評論
#
re: STL容器的賦值運算符可以更靈活嗎?
2008-11-13 12:53
陳梓瀚(vczh)
可以自己寫一個static。話說,提供這樣的東西很不安全。
回復
更多評論
#
re: STL容器的賦值運算符可以更靈活嗎?
2008-12-29 14:27
王維
你說的在VS2005上編譯不過@踏雪赤兔
回復
更多評論
#
re: STL容器的賦值運算符可以更靈活嗎?
2009-10-08 23:52
yisa
LZ 可能是python用爽了吧
C++的特點:
強類型(其實也是基于指針(內存訪問格式))
說到底 也就是為了效率;
當然"虛表"之類的東西避開了這個問題, 也導致了被不少人忌憚的"詬病".
從這方面考慮
我想如果 STL實現了
>>
std::list<B*> lB;
std::list<D*> lD;
lB = lD;
勢必犯下 大不韙的錯誤
結論: STL不是一種為了滿足小范圍需求的庫
最后, 我想如果是在開發網游中遇上了此等問題:
尋找或者開發一種適合網游開發的"STL", 很有必要;
回復
更多評論
#
re: STL容器的賦值運算符可以更靈活嗎?
2009-10-12 14:13
金慶
@yisa
@踏雪赤兔
既然可以這樣賦值: lB.assign(lD.begin(), lD.end());
也應該支持等號運算符賦值: lB = lD;
既然支持元素的隱式類型轉換, 也應該支持容器的隱式類型轉換.
回復
更多評論
刷新評論列表
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
How are dtLinks created in NavMesh
C++ parameter passing rules
Naming Conventions for Accessors
Visual Studio 2019 Compiler Hangs
Fbx File Format Identifier
查找內存錯誤
std::thread 中的異常會丟失調用棧
用賦值代替 protobuf CopyFrom()
vs2017 linux 編譯輸出改成 vs 格式
為 LiteIDE 添加選中標記
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 金慶
久久午夜无码鲁丝片秋霞
|
久久天堂AV综合合色蜜桃网
|
久久久久无码国产精品不卡
|
欧美一区二区久久精品
|
久久久久久亚洲精品成人
|
精品国产综合区久久久久久
|
伊人久久亚洲综合影院
|
99国产欧美精品久久久蜜芽
|
久久只有这里有精品4
|
久久精品国产福利国产秒
|
99久久精品免费看国产一区二区三区
|
精品综合久久久久久98
|
久久国产精品久久精品国产
|
国产欧美久久久精品影院
|
99久久www免费人成精品
|
久久精品国产亚洲AV久
|
久久天天躁狠狠躁夜夜不卡
|
热综合一本伊人久久精品
|
69久久精品无码一区二区
|
色婷婷综合久久久久中文
|
午夜精品久久影院蜜桃
|
国产成人久久精品二区三区
|
国产欧美久久一区二区
|
久久久无码精品亚洲日韩按摩
|
精品国产乱码久久久久软件
|
久久久久人妻精品一区三寸蜜桃
|
狠狠色噜噜狠狠狠狠狠色综合久久
|
久久天天婷婷五月俺也去
|
亚洲午夜无码久久久久小说
|
久久国产精品免费一区二区三区
|
996久久国产精品线观看
|
久久久久亚洲AV成人片
|
久久天天躁狠狠躁夜夜躁2O2O
|
久久久国产精华液
|
久久久精品2019免费观看
|
亚洲AV无码久久
|
亚洲AV乱码久久精品蜜桃
|
老色鬼久久亚洲AV综合
|
精品一区二区久久
|
久久久91人妻无码精品蜜桃HD
|
老司机午夜网站国内精品久久久久久久久
|