- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有类的迭代器模板和用于 for 语句的类。
template<class T>
class Itr2 {
public:
Itr2() { }
~Itr2() { }
typedef typename Itr2 type;
typedef typename T& reference;
virtual type& operator++() { return *this; }
virtual T& operator*() { return ((reference)*((type*)this)); }
virtual bool operator==(const type& o) const { return true; }
virtual bool operator!=(const type& o) const { return false; }
};
template<class T>
class I2
{
public:
typedef I2<T> type;
typedef T value;
typedef T& reference;
typedef typename Itr2<T> iterator;
virtual iterator& begin() { return *(new iterator()); }
virtual iterator& end() { return *(new iterator()); }
};
接下来,我为标准 std::vector<> 创建了类。
template<class T>
class ItrSTD : public Itr2<T> {
public:
typedef typename Itr2<T> base_type;
typedef typename ItrSTD<T> type;
typedef typename T& reference;
typedef typename std::vector<T>::iterator std_itr;
protected:
std_itr itr_;
public:
ItrSTD(const type& o) { itr_ = o.itr_; }
ItrSTD(const std_itr& o) { itr_ = o; }
virtual base_type& operator++() { itr_++; return *this; }
virtual T& operator*() { return ((reference)(*this->itr_)); }
bool operator==(const base_type& o) const override { return (((const type&)o).itr_ == this->itr_); }
bool operator!=(const base_type& o) const override { return (((const type&)o).itr_ != this->itr_); }
};
template<class T>
class VSTD : public I2<T> {
protected:
std::vector<T> arr_;
public:
typedef typename ItrSTD<T> iterator;
VSTD(const VSTD& o) { arr_ = o.arr_; }
template<typename ...E> VSTD(E&&...e) : arr_({ std::forward<T>(e)... }) { }
iterator& begin() _NOEXCEPT override{ return (*new iterator(arr_.begin())); }
iterator& end() _NOEXCEPT override{ return (*new iterator(arr_.end())); }
};
如果我使用直接语句 for(int i:v)。它工作正常,但是当我尝试从指针编译器执行此操作时,使用基类运算符!=(不覆盖运算符!=)并且代码不起作用:(。
int v_i = 0;
VSTD<int> vstd_a = { 1, 2, 3 };
I2<int> *i2 = &vstd_a;
for (int j : *i2) //DOESN't work :( use operator!= from base class
{
v_i += j;
}
for (int j : vstd_a) //work fine :) use operator!= from VSTD.
{
v_i += j;
}
如果我简化代码:
template<typename T>
class I3
{
public:
T i;
virtual bool operator==(const I3& o) const { return false; }
};
template<typename T>
class I3O : public I3<T>
{
public:
virtual bool operator==(const I3& o) const override { return true; }
};
I3O<int> i3_a, i3_b; I3<int> *i3_ap, *i3_bp;
i3_ap = &i3_a; i3_bp = &i3_b; bool i3_c;
i3_c = (i3_a == i3_b);
i3_c = ((*i3_ap) == (*i3_bp));
两个结果都很好(返回 true)并与重写类进行比较(仅对于( : )工作不好 :( :
为什么会这样。模板指针可以用于语句吗?begin()、end() 函数工作正常。只有运营商工作不同。
附言我使用 VS2013 编译器。
最佳答案
我没有看过你代码中的细节,但是......看起来像您正在尝试使迭代器多态。标准然而,不断地按值传递它们,而按值传递不会支持多态;它切片。因此(我假设),在:
for ( int j : *i2 )
编译器为迭代器创建局部变量,其类型为静态地确定。尽管它调用了正确的 begin()
,它将结果分配给这个局部变量,从而对其进行切片。
如果你需要多态迭代器,你需要实现信/信封成语:
class Iterator
{
Iterator* myImpl;
virtual Iterator* clone() const { abort(); }
virtual T& current() const { abort(); }
virtual bool isEqual( Iterator const* other ) { abort(); }
virtual void next() { abort(); }
protected:
Iterator() : myImpl( nullptr ) {}
public:
Iterator( Iterator* impl ) : myImpl( impl ) {}
Iterator( Iterator const& other ) : myImpl( other.clone() ) {}
virtual ~Iterator() { delete myImpl; }
T& operator*() const
{
return myImpl->current();
}
bool operator==( Iterator const& other ) const
{
return myImpl->isEqual( other.myImpl );
}
Iterator& operator++()
{
myImpl->next();
return *this;
}
// ...
};
class DerivedIterator : public Iterator
{
Iterator* clone() const override { return new DerivedIterator( *this ); }
T& current() const override { ... }
bool isEqual( Iterator const* other ) override { ... }
virtual void next() { ... }
public:
DerivedIterator(...) ...
};
然后,您派生的 begin
和 end
返回如下内容:
Iterator( new DerivedIterator(...) );
这在运行时相当昂贵,但它确实是唯一的方法提供多态性并且仍然具有迭代器。
关于c++ - 为什么重写类的指针使用基类的 operator== 和 operator!=,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26995999/
我习惯于使用 Apache 服务器,所以当启用 mod_rewrite 时,我可以创建一个 htaccess 文件并使用 URL 重写。 这是我的 htaccess 文件: RewriteEngine
我正在尝试编写一个 mixin 来修改输出的父选择器。这个想法是,在调用 mixin 的情况下,父选择器需要对其进行字符串替换。我有大部分工作,但我不知道如何吞下 & . .test { @inc
我有一个本地目录(上传)和一个 S3 桶设置。 当用户上传图片时,文件存储在本地目录:/uploads/member_id/image_name30 分钟后,系统将文件上传到 S3 使用相同的路径:s
我正在尝试使用以下内容重写代理页面的正文链接: sub_filter http://proxied.page.come http://local.page.com; sub_filte
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 1年前关闭。 Improve this questi
我尝试在我的 JSF 应用程序中使用“重写”(http://ocpsoft.org/rewrite/)。 一切都很好,我已经创建了规则: .addRule(Join.path("/profile/{p
我可以在 AEM 中大致看到两种 URL 重写方法: /etc/map/http(s)下的Sling映射(sling:Mapping) 使用链接重写器/TransformerFactory 重写 UR
我有一个 onclick 函数,我想将 anchor 添加到 href 值。我不想更改 URL,因为我需要该网站仍然可以为没有 javascript 的人/出于 SEO 目的而运行。所以这是我尝试使用
我必须在 UILabel 中显示货币和价格。在一个标签中,但使用不同的字体大小。现在看起来像这样: ...我这样做是重写drawTextInRect:,如下所示: - (void)drawTextIn
我正在尝试使用以下内容进行重定向: RewriteRule ^reviews/area/Santa-Barbara%2F$"/reviews/area/santa-barbara" [R=301,NC
我使用 FOSUserBundle 并且我想覆盖他的 registerAction Controller 。我阅读了与覆盖 FOSUserBundle Controller 相关的文档,但它不起作用。
我正在尝试让 URL 重写在我的网站上运行。这是我的 .htaccess 的内容: RewriteEngine On RewriteRule ^blog/?$ index.php?page=blog
好吧,这让我发疯了......我正在尝试像这样重写我的网址: Now: http://www.somedomain.com/Somepage.aspx http://www.somedomain.co
final方法不能在子类中重写。但凭借 Scala 的魔力,这似乎是可能的。 考虑以下示例: trait Test { final def doIt(s: String): String = s
我有一个类似下面的查询: Select ser.key From dbo.Enrlmt ser Where ser.wd >= @FromDate AND ser.wd ser.wd
我是 nginx 的新手,只是想做一些我认为应该很简单的事情。如果我这样做:- curl http://localhost:8008/12345678 我希望返回 index.html 页面。但是我得
我们的一位客户创建了一个二维码,其中 url 中包含一个空格。 我将如何编写处理此问题的 nginx 重定向? 在字符串中使用诸如“%20”之类的东西的几次尝试似乎会导致 nginx 出错或使 con
我正在尝试覆盖 appendChild 方法,以便我可以控制动态创建的元素并在插入页面之前根据需要修改它们。我尝试了这个示例代码,只是为了看看它是否可以完成: var f = Element.prot
我目前正在使用以下功能,当用户单击某处以确定是否隐藏下拉菜单(在 react 中)。一切正常,但当我单击正文时,它会记录以下内容。 我尝试重写它几次,但我找不到解决这个问题的方法。 Uncaught
我正在开发一个 Spring Integration/Boot 应用程序。我使用多文档 application.yml (src/main/resources/application.yml) 来设置
我是一名优秀的程序员,十分优秀!