亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? qlinkedlist.h

?? QT 開發環境里面一個很重要的文件
?? H
字號:
/******************************************************************************** Copyright (C) 1992-2006 Trolltech ASA. All rights reserved.**** This file is part of the QtCore module of the Qt Toolkit.**** This file may be used under the terms of the GNU General Public** License version 2.0 as published by the Free Software Foundation** and appearing in the file LICENSE.GPL included in the packaging of** this file.  Please review the following information to ensure GNU** General Public Licensing requirements will be met:** http://www.trolltech.com/products/qt/opensource.html**** If you are unsure which license is appropriate for your use, please** review the following information:** http://www.trolltech.com/products/qt/licensing.html or contact the** sales department at sales@trolltech.com.**** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.******************************************************************************/#ifndef QLINKEDLIST_H#define QLINKEDLIST_H#include <QtCore/qiterator.h>#include <QtCore/qatomic.h>#ifndef QT_NO_STL#include <iterator>#include <list>#endifQT_BEGIN_HEADERQT_MODULE(Core)struct Q_CORE_EXPORT QLinkedListData{    QLinkedListData *n, *p;    QBasicAtomic ref;    int size;    uint sharable : 1;    static QLinkedListData shared_null;};template <typename T>struct QLinkedListNode{    inline QLinkedListNode(const T &arg): t(arg) { }    QLinkedListNode *n, *p;    T t;};template <class T>class QLinkedList{    typedef QLinkedListNode<T> Node;    union { QLinkedListData *d; QLinkedListNode<T> *e; };public:    inline QLinkedList() : d(&QLinkedListData::shared_null) { d->ref.ref(); }    inline QLinkedList(const QLinkedList<T> &l) : d(l.d) { d->ref.ref(); if (!d->sharable) detach(); }    ~QLinkedList();    QLinkedList<T> &operator=(const QLinkedList<T> &);    bool operator==(const QLinkedList<T> &l) const;    inline bool operator!=(const QLinkedList<T> &l) const { return !(*this == l); }    inline int size() const { return d->size; }    inline void detach()    { if (d->ref != 1) detach_helper(); }    inline bool isDetached() const { return d->ref == 1; }    inline void setSharable(bool sharable) { if (!sharable) detach(); d->sharable = sharable; }    inline bool isEmpty() const { return d->size == 0; }    void clear();    void append(const T &);    void prepend(const T &);    T takeFirst();    T takeLast();    int removeAll(const T &t);    bool contains(const T &t) const;    int count(const T &t) const;    class const_iterator;    class iterator    {    public:        typedef std::bidirectional_iterator_tag  iterator_category;        typedef ptrdiff_t  difference_type;        typedef T value_type;        typedef T *pointer;        typedef T &reference;        Node *i;        inline iterator() : i(0) {}        inline iterator(Node *n) : i(n) {}        inline iterator(const iterator &o) : i(o.i) {}        inline iterator &operator=(const iterator &o) { i = o.i; return *this; }        inline T &operator*() const { return i->t; }        inline T *operator->() const { return &i->t; }        inline bool operator==(const iterator &o) const { return i == o.i; }        inline bool operator!=(const iterator &o) const { return i != o.i; }        inline bool operator==(const const_iterator &o) const            { return i == reinterpret_cast<const iterator &>(o).i; }        inline bool operator!=(const const_iterator &o) const            { return i != reinterpret_cast<const iterator &>(o).i; }        inline iterator &operator++() { i = i->n; return *this; }        inline iterator operator++(int) { Node *n = i; i = i->n; return n; }        inline iterator &operator--() { i = i->p; return *this; }        inline iterator operator--(int) { Node *n = i; i = i->p; return n; }        inline iterator operator+(int j) const        { Node *n = i; if (j > 0) while (j--) n = n->n; else while (j++) n = n->p; return n; }        inline iterator operator-(int j) const { return operator+(-j); }        inline iterator &operator+=(int j) { return *this = *this + j; }        inline iterator &operator-=(int j) { return *this = *this - j; }    };    friend class iterator;    class const_iterator    {    public:        typedef std::bidirectional_iterator_tag  iterator_category;        typedef ptrdiff_t  difference_type;        typedef T value_type;        typedef const T *pointer;        typedef const T &reference;        Node *i;        inline const_iterator() : i(0) {}        inline const_iterator(Node *n) : i(n) {}        inline const_iterator(const const_iterator &o) : i(o.i){}        inline const_iterator(iterator ci) : i(ci.i){}	inline const_iterator &operator=(const const_iterator &o) { i = o.i; return *this; }        inline const T &operator*() const { return i->t; }        inline const T *operator->() const { return &i->t; }        inline bool operator==(const const_iterator &o) const { return i == o.i; }        inline bool operator!=(const const_iterator &o) const { return i != o.i; }        inline const_iterator &operator++() { i = i->n; return *this; }        inline const_iterator operator++(int) { Node *n = i; i = i->n; return n; }        inline const_iterator &operator--() { i = i->p; return *this; }        inline const_iterator operator--(int) { Node *n = i; i = i->p; return n; }        inline const_iterator operator+(int j) const        { Node *n = i; if (j > 0) while (j--) n = n->n; else while (j++) n = n->p; return n; }        inline const_iterator operator-(int j) const { return operator+(-j); }        inline const_iterator &operator+=(int j) { return *this = *this + j; }        inline const_iterator &operator-=(int j) { return *this = *this - j; }    };    friend class const_iterator;    // stl style    inline iterator begin() { detach(); return e->n; }    inline const_iterator begin() const { return e->n; }    inline const_iterator constBegin() const { return e->n; }    inline iterator end() { detach(); return e; }    inline const_iterator end() const { return e; }    inline const_iterator constEnd() const { return e; }    iterator insert(iterator before, const T &t);    iterator erase(iterator pos);    iterator erase(iterator first, iterator last);    // more Qt    typedef iterator Iterator;    typedef const_iterator ConstIterator;    inline int count() const { return d->size; }    inline T& first() { Q_ASSERT(!isEmpty()); return *begin(); }    inline const T& first() const { Q_ASSERT(!isEmpty()); return *begin(); }    T& last() { Q_ASSERT(!isEmpty()); return *(--end()); }    const T& last() const { Q_ASSERT(!isEmpty()); return *(--end()); }    inline void removeFirst() { Q_ASSERT(!isEmpty()); erase(begin()); }    inline void removeLast() { Q_ASSERT(!isEmpty()); erase(--end()); }    // stl compatibility    inline void push_back(const T &t) { append(t); }    inline void push_front(const T &t) { prepend(t); }    inline T& front() { return first(); }    inline const T& front() const { return first(); }    inline T& back() { return last(); }    inline const T& back() const { return last(); }    inline void pop_front() { removeFirst(); }    inline void pop_back() { removeLast(); }    inline bool empty() const { return isEmpty(); }    typedef int size_type;    typedef T value_type;    typedef value_type *pointer;    typedef const value_type *const_pointer;    typedef value_type &reference;    typedef const value_type &const_reference;    typedef ptrdiff_t difference_type;#ifndef QT_NO_STL    static inline QLinkedList<T> fromStdList(const std::list<T> &list)    { QLinkedList<T> tmp; qCopy(list.begin(), list.end(), std::back_inserter(tmp)); return tmp; }    inline std::list<T> toStdList() const    { std::list<T> tmp; qCopy(constBegin(), constEnd(), std::back_inserter(tmp)); return tmp; }#endif#ifdef QT3_SUPPORT    // compatibility    inline QT3_SUPPORT iterator remove(iterator pos) { return erase(pos); }    inline QT3_SUPPORT int findIndex(const T& t) const    { int i=0; for (const_iterator it = begin(); it != end(); ++it, ++i) if(*it == t) return i; return -1;}    inline QT3_SUPPORT iterator find(iterator from, const T& t)    { while (from != end() && !(*from == t)) ++from; return from; }    inline QT3_SUPPORT iterator find(const T& t)    { return find(begin(), t); }    inline QT3_SUPPORT const_iterator find(const_iterator from, const T& t) const    { while (from != end() && !(*from == t)) ++from; return from; }    inline QT3_SUPPORT const_iterator find(const T& t) const    { return find(begin(), t); }#endif    // comfort    QLinkedList<T> &operator+=(const QLinkedList<T> &l);    QLinkedList<T> operator+(const QLinkedList<T> &l) const;    inline QLinkedList<T> &operator+=(const T &t) { append(t); return *this; }    inline QLinkedList<T> &operator<< (const T &t) { append(t); return *this; }    inline QLinkedList<T> &operator<<(const QLinkedList<T> &l) { *this += l; return *this; }private:    void detach_helper();    void free(QLinkedListData*);};template <typename T>inline QLinkedList<T>::~QLinkedList(){    if (!d)        return;    if (!d->ref.deref())        free(d);}template <typename T>void QLinkedList<T>::detach_helper(){    union { QLinkedListData *d; Node *e; } x;    x.d = new QLinkedListData;    x.d->ref.init(1);    x.d->size = d->size;    x.d->sharable = true;    Node *i = e->n, *j = x.e;    while (i != e) {        j->n = new Node(i->t);        j->n->p = j;        i = i->n;        j = j->n;    }    j->n = x.e;    x.e->p = j;    x.d = qAtomicSetPtr(&d, x.d);    if (!x.d->ref.deref())        free(x.d);}template <typename T>void QLinkedList<T>::free(QLinkedListData *x){    Node *y = reinterpret_cast<Node*>(x);    Node *i = y->n;    if (x->ref == 0) {        while(i != y) {            Node *n = i;            i = i->n;            delete n;        }        delete x;    }}template <typename T>void QLinkedList<T>::clear(){    *this = QLinkedList<T>();}template <typename T>QLinkedList<T> &QLinkedList<T>::operator=(const QLinkedList<T> &l){    if (d != l.d) {        QLinkedListData *x = l.d;        x->ref.ref();        x = qAtomicSetPtr(&d, x);        if (!x->ref.deref())            free(x);        if (!d->sharable)            detach_helper();    }    return *this;}template <typename T>bool QLinkedList<T>::operator== (const QLinkedList<T> &l) const{    if (d->size != l.d->size)        return false;    if (e == l.e)        return true;    Node *i = e->n;    Node *il = l.e->n;    while (i != e) {        if (! (i->t == il->t))            return false;        i = i->n;        il = il->n;    }    return true;}template <typename T>void QLinkedList<T>::append(const T &t){    detach();    Node *i = new Node(t);    i->n = e;    i->p = e->p;    i->p->n = i;    e->p = i;    d->size++;}template <typename T>void QLinkedList<T>::prepend(const T &t){    detach();    Node *i = new Node(t);    i->n = e->n;    i->p = e;    i->n->p = i;    e->n = i;    d->size++;}template <typename T>int QLinkedList<T>::removeAll(const T &_t){    detach();    const T t = _t;    Node *i = e->n;    int c = 0;    while (i != e) {        if (i->t == t) {            Node *n = i;            i->n->p = i->p;            i->p->n = i->n;            i = i->n;            delete n;            c++;        } else {            i = i->n;        }    }    d->size-=c;    return c;}template <typename T>inline T QLinkedList<T>::takeFirst(){    T t = first();    removeFirst();    return t;}template <typename T>inline T QLinkedList<T>::takeLast(){    T t = last();    removeLast();    return t;}template <typename T>bool QLinkedList<T>::contains(const T &t) const{    Node *i = e;    while ((i = i->n) != e)        if (i->t == t)            return true;    return false;}template <typename T>int QLinkedList<T>::count(const T &t) const{    Node *i = e;    int c = 0;    while ((i = i->n) != e)        if (i->t == t)            c++;    return c;}template <typename T>typename QLinkedList<T>::iterator QLinkedList<T>::insert(iterator before, const T &t){    Node *i = before.i;    Node *m = new Node(t);    m->n = i;    m->p = i->p;    m->p->n = m;    i->p = m;    d->size++;    return m;}template <typename T>typename QLinkedList<T>::iterator QLinkedList<T>::erase(typename QLinkedList<T>::iterator afirst,                                                         typename QLinkedList<T>::iterator alast){    while (afirst != alast)        erase(afirst++);    return alast;}template <typename T>typename QLinkedList<T>::iterator QLinkedList<T>::erase(iterator pos){    detach();    Node *i = pos.i;    if (i != e) {        Node *n = i;        i->n->p = i->p;        i->p->n = i->n;        i = i->n;        delete n;        d->size--;    }    return i;}template <typename T>QLinkedList<T> &QLinkedList<T>::operator+=(const QLinkedList<T> &l){    detach();    int n = l.d->size;    d->size += n;    Node *o = l.e->n;    while (n--) {        Node *i = new Node(o->t);        o = o->n;        i->n = e;        i->p = e->p;        i->p->n = i;        e->p = i;    }    return *this;}template <typename T>QLinkedList<T> QLinkedList<T>::operator+(const QLinkedList<T> &l) const{    QLinkedList<T> n = *this;    n += l;    return n;}Q_DECLARE_SEQUENTIAL_ITERATOR(LinkedList)Q_DECLARE_MUTABLE_SEQUENTIAL_ITERATOR(LinkedList)QT_END_HEADER#endif // QLINKEDLIST_H

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区三区在线观看视频 | 日韩亚洲欧美一区二区三区| 日韩免费看的电影| 国产精品视频一区二区三区不卡| 一级日本不卡的影视| 韩国av一区二区三区四区| 91偷拍与自偷拍精品| 久久久三级国产网站| 日韩激情视频在线观看| 99re亚洲国产精品| 久久久久久黄色| 美国欧美日韩国产在线播放| 色悠久久久久综合欧美99| 久久这里只有精品6| 蜜臀av性久久久久蜜臀aⅴ四虎| 在线观看一区不卡| 亚洲素人一区二区| 成人爽a毛片一区二区免费| 日韩精品一区二区三区中文精品| 一区二区三区欧美久久| 99久久久免费精品国产一区二区| 国产欧美精品一区二区三区四区| 美女网站一区二区| 91精品久久久久久久99蜜桃| 亚洲国产成人av好男人在线观看| 色综合久久综合网欧美综合网| 国产精品丝袜久久久久久app| 久久99精品国产91久久来源| 欧美一区二区免费| 免费观看91视频大全| 日韩一区二区三区视频在线观看| 午夜精品免费在线| 欧美日韩国产综合视频在线观看| 亚洲综合偷拍欧美一区色| 91视频免费观看| 玉足女爽爽91| 精品视频一区二区三区免费| 亚洲一区二区欧美日韩 | 国产成人自拍高清视频在线免费播放| 欧美一区二区大片| 精品在线一区二区三区| 久久影院午夜片一区| 国产精品一二三四| 国产精品成人一区二区三区夜夜夜 | 精一区二区三区| 久久综合九色综合97_久久久| 韩国av一区二区三区| 精品国产一区二区三区不卡| 粉嫩一区二区三区在线看| 中文欧美字幕免费| 91丨porny丨在线| 亚洲在线成人精品| 宅男噜噜噜66一区二区66| 另类人妖一区二区av| 久久久噜噜噜久久中文字幕色伊伊| 国精产品一区一区三区mba视频| 国产日本亚洲高清| 色婷婷精品久久二区二区蜜臂av | 亚洲成人资源网| 精品日本一线二线三线不卡| 国产精品一区不卡| 中文字幕亚洲电影| 91精品欧美一区二区三区综合在 | 日本一区二区三区四区在线视频| 91蝌蚪porny九色| 日日欢夜夜爽一区| 久久精品一区二区三区av| 色乱码一区二区三区88| 毛片不卡一区二区| 中文字幕在线不卡国产视频| 欧美美女bb生活片| 福利一区福利二区| 日韩精品色哟哟| 中文字幕日本乱码精品影院| 8x8x8国产精品| 高清不卡一区二区| 免费三级欧美电影| 最新久久zyz资源站| 精品久久久久久久久久久久久久久久久 | 欧美一级黄色录像| www.欧美日韩| 久久成人综合网| 一级做a爱片久久| 久久久久久97三级| 欧美日韩免费观看一区二区三区| 国产另类ts人妖一区二区| 亚洲成a人片在线观看中文| 国产欧美日韩视频在线观看| 欧美丰满一区二区免费视频| 99热99精品| 国产一区二区在线观看视频| 亚洲一区av在线| 国产精品美女久久久久av爽李琼| 日韩欧美一二三区| 欧美日韩一区二区在线视频| 成人av电影在线播放| 久草这里只有精品视频| 午夜精品久久久久久久 | 黄色小说综合网站| 午夜不卡在线视频| 亚洲一区二区三区四区不卡| 亚洲欧美另类久久久精品2019| 欧美激情综合五月色丁香小说| 精品国产第一区二区三区观看体验| 欧美日韩专区在线| 91福利在线看| 日本大香伊一区二区三区| 99国产精品99久久久久久| 成人久久视频在线观看| 国产成人啪午夜精品网站男同| 看片的网站亚洲| 精品在线播放免费| 久久精品国产成人一区二区三区| 性做久久久久久| 天堂午夜影视日韩欧美一区二区| 亚洲小说欧美激情另类| 一二三区精品视频| 亚洲成人中文在线| 欧美a级一区二区| 久久不见久久见中文字幕免费| 久久精品国产久精国产| 国内精品国产成人国产三级粉色| 老司机精品视频导航| 国产乱一区二区| 成人污污视频在线观看| av电影在线观看不卡| 91网站在线观看视频| 精品视频全国免费看| 欧美一级国产精品| 欧美成人福利视频| 国产欧美一区二区在线| 亚洲视频图片小说| 亚洲国产成人tv| 麻豆精品蜜桃视频网站| 国产成人综合网站| 色综合天天综合网天天看片| 欧美在线小视频| 日韩欧美亚洲国产精品字幕久久久| 26uuu久久天堂性欧美| 欧美国产成人在线| 亚洲国产日日夜夜| 精品一区二区三区日韩| 成人久久18免费网站麻豆| 91久久精品国产91性色tv| 欧美精品第1页| 国产亚洲欧美激情| 亚洲靠逼com| 久久99国产精品免费网站| 成人国产在线观看| 欧美军同video69gay| 久久久久久久综合| 亚洲一区二区三区在线看| 香蕉久久一区二区不卡无毒影院 | 久久精品噜噜噜成人88aⅴ| 狠狠色丁香婷综合久久| 99精品在线免费| 日韩欧美国产三级电影视频| 国产精品拍天天在线| 亚洲国产一区在线观看| 国产 欧美在线| 91麻豆精品国产91久久久资源速度 | 男人操女人的视频在线观看欧美| 国产精品1024| 在线播放中文字幕一区| 国产精品视频一区二区三区不卡| 亚洲成a人v欧美综合天堂下载| 国产成人亚洲综合a∨婷婷图片| 欧美午夜片在线看| 中文无字幕一区二区三区| 日韩av网站免费在线| 99久久综合色| 久久久久久久综合| 日韩av一区二区在线影视| 色激情天天射综合网| 欧美国产日韩精品免费观看| 日韩在线观看一区二区| 日本久久一区二区三区| 国产亚洲午夜高清国产拍精品 | 国产福利精品一区| 日韩一区二区三区在线| 亚洲一区二区三区中文字幕在线| 成人在线综合网站| 欧美成人a∨高清免费观看| 亚洲一区二区三区四区在线观看| 成人激情免费电影网址| 欧美不卡123| 乱中年女人伦av一区二区| 欧美人狂配大交3d怪物一区| 亚洲人成在线观看一区二区| 国产成人午夜精品影院观看视频| 欧美一区二区免费观在线| 午夜在线电影亚洲一区| 91久久精品一区二区三区| 亚洲视频精选在线| 99热这里都是精品| 亚洲色图在线播放| 91丨九色丨黑人外教| 综合自拍亚洲综合图不卡区| 成人av电影免费在线播放| 欧美国产丝袜视频|