鱼C论坛

 找回密码
 立即注册
查看: 2733|回复: 1

在这里定义为什么一移动到类外就报错;

[复制链接]
发表于 2019-2-25 18:57:19 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
算是解决一个bug又出现了新的bug吧。。
起因是想写一个小游戏,为了能方便地遍历所有的Object,在Obj基类的构造函数中添加了一个把自身的指针加入一个set的语句;
然后发现在调用基类的构造函数时,因为类并没有构造完成,多态没有启用,所以set的排序没法实现。。
于是想重新实现一个能排序的set,

想法是两个set,一个未排序完成的,一个排序完成的;
添加元素时,全部添加到未排序完成的set中,
在调用时才把元素全部移动到排序完成的set中

代码是这样的
PostSortSet.h
#pragma once
//PostSortSet.h
//后排序set
//插入的元素是无序的,在调用时才进行排序;
//解决在基类的构造函数中,将自身的指针插入集合时,因多态尚未启用,无法正确排序的问题;

#include <set>

template <typename T, typename _SortT = std::less<T>> 
class PostSortSet{
private:
        std::set<T> unsorted;
        std::set<T, _SortT> sorted;
        void sort();
public:
        void insert(T);
        void erase(T);
        std::iterator begin();
        std::iterator end() {
                this->sort();                 //end()定义在类中,没有报错
                return sorted.end();
        }
};

PostSortSet.cpp
#include "PostSortSet.h"

template<typename T, typename _SortT>
inline void PostSortSet<T, _SortT>::sort()
{
        if (unsorted.empty()) return;
        for (auto i : unsorted) {
                sorted.insert(i);
        }
        unsorted.clear();
}

template<typename T, typename _SortT>
void PostSortSet<T, _SortT>::insert(T t)
{
        unsorted.insert(t);
}

template<typename T, typename _SortT>
void PostSortSet<T, _SortT>::erase(T t)
{
        unsorted.erase(t);
        sorted.erase(t);
}

template<typename T, typename _SortT>
inline std::set<T, _SortT>::iterator PostSortSet<T, _SortT>::begin() {  //begin()定义在类外,报错:
                                                                                                                                            //缺少类模板std::iterator的参数列表
                                                                                                                //声明与 "std::iterator<_Category, _Ty, _Diff, _Pointer, _Reference> PostSortSet<T, _SortT>::begin()" 不兼容
                                                                                                                
                                                                                                                                //把std::iterator改为std::set<T,_SortT>::iterator后仍然报错
                                                                                                                                //在依赖上下文中使用"typename"关键字将非类型"std::set<_Kty,_Pr,_Alloc>::iterator视为类型

        this->sort();
        return sorted.begin();
}

然后发现。。这个begin()和end()的返回类型怎么写都有问题。。。
报错的信息都写在注释中了。。所以这个该怎么改才能行?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2019-2-25 19:01:01 | 显示全部楼层
而且是同样的代码,在类中没有报错,使用vs的移动定义功能一移动到类外就报错。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-17 07:46

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表