免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1893 | 回复: 1
打印 上一主题 下一主题

stl自定义容器与迭代器使用问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-05-05 11:49 |只看该作者 |倒序浏览
#include <set>
struct setItem
{
        setItem()
        {
                a = b = 0;
        }
        int a;
        int b;
};

struct insertRule: public binary_function<setItem, setItem, bool>
{
        bool operator ()(const setItem& pre, const setItem& aft)
        {
                if(pre.a == aft.a)
                        return pre.b < aft.b;
                else
                        return pre.a < aft.a;
        }
};


int main
{
        std::set<setItem, insertRule> mySet;

        //插入
        for(int i = 0; i < 20; i++)
        {
                setItem tmp;
                tmp.a = i;
                tmp.b = i+1;
                mySet.insert(tmp);
        }


        for(std::set<setItem, insertRule>::iterator it = mySet.begin(); it != mySet.end(); it++)
        {
                /*  有问题的代码
                        it->a += 20+1;
                        it->b += it->a + 20 + 1;

                   */
                //改成这样就没有问题
                setItem* p = const_cast<setItem*>(&(*it));
                p->a += 20+1;
                p->b += p->a + 20 + 1;
        }

        return 0;
}


请问高人有什么方法不做从const到非const的强制转换直接操作迭代器??

论坛徽章:
2
青铜圣斗士
日期:2015-11-26 06:15:59数据库技术版块每日发帖之星
日期:2016-07-24 06:20:00
2 [报告]
发表于 2009-05-05 15:17 |只看该作者

回复 #1 nick811125 的帖子

std:: set和std:: map插入某项(set是key, map是key-value的pair)之后, key是不能修改的, 只能修改value。

在楼主的代码里:
std:: set< setItem, insertRule > mySet;

mySet的元素类型是 const setItem 。
std::set<setItem, insertRule>::iterator it = mySet.begin()
就不能通过it去修改setItem。
使用const_cast将破坏set内部结构。


如果真的需要“修改key”, 只能
1. 取得item的副本
2. 将item从容器中删除, 修改item的副本中的key
3. 将修改后的副本插入容器
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP