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

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

?? qvector.h

?? QT 開發(fā)環(huán)境里面一個很重要的文件
?? H
?? 第 1 頁 / 共 2 頁
字號:
/******************************************************************************** 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 QVECTOR_H#define QVECTOR_H#include <QtCore/qiterator.h>#include <QtCore/qatomic.h>#include <QtCore/qalgorithms.h>#include <QtCore/qlist.h>#ifndef QT_NO_STL#include <iterator>#include <vector>#endif#include <stdlib.h>#include <string.h>QT_BEGIN_HEADERQT_MODULE(Core)struct Q_CORE_EXPORT QVectorData{    QBasicAtomic ref;    int alloc;    int size;    uint sharable : 1;    static QVectorData shared_null;    static QVectorData *malloc(int sizeofTypedData, int size, int sizeofT, QVectorData *init);    static int grow(int sizeofTypedData, int size, int sizeofT, bool excessive);};template <typename T>struct QVectorTypedData{    QBasicAtomic ref;    int alloc;    int size;    uint sharable : 1;    T array[1];};template <typename T>class QVector{    typedef QVectorTypedData<T> Data;    union { QVectorData *p; QVectorTypedData<T> *d; };public:    inline QVector() : p(&QVectorData::shared_null) { d->ref.ref(); }    explicit QVector(int size);    QVector(int size, const T &t);    inline QVector(const QVector<T> &v) : d(v.d) { d->ref.ref(); if (!d->sharable) detach_helper(); }    inline ~QVector() { if (!d) return; if (!d->ref.deref()) free(d); }    QVector<T> &operator=(const QVector<T> &v);    bool operator==(const QVector<T> &v) const;    inline bool operator!=(const QVector<T> &v) const { return !(*this == v); }    inline int size() const { return d->size; }    inline bool isEmpty() const { return d->size == 0; }    void resize(int size);    inline int capacity() const { return d->alloc; }    void reserve(int size);    inline void squeeze() { realloc(d->size, 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 T *data() { detach(); return d->array; }    inline const T *data() const { return d->array; }    inline const T *constData() const { return d->array; }    void clear();    const T &at(int i) const;    T &operator[](int i);    const T &operator[](int i) const;    void append(const T &t);    void prepend(const T &t);    void insert(int i, const T &t);    void insert(int i, int n, const T &t);    void replace(int i, const T &t);    void remove(int i);    void remove(int i, int n);    QVector<T> &fill(const T &t, int size = -1);    int indexOf(const T &t, int from = 0) const;    int lastIndexOf(const T &t, int from = -1) const;    bool contains(const T &t) const;    int count(const T &t) const;#ifdef QT_STRICT_ITERATORS    class iterator {    public:        T *i;        typedef std::random_access_iterator_tag  iterator_category;        typedef ptrdiff_t difference_type;        typedef T value_type;        typedef T *pointer;        typedef T &reference;        inline iterator() : i(0) {}        inline iterator(T *n) : i(n) {}        inline iterator(const iterator &o): i(o.i){}        inline T &operator*() const { return *i; }        inline T *operator->() const { return i; }        inline T &operator[](int j) const { return *(i + j); }        inline bool operator==(const iterator &o) const { qDebug("1"); return i == o.i; }        inline bool operator!=(const iterator &o) const { return i != o.i; }        inline bool operator<(const iterator& other) const { return i < other.i; }        inline bool operator<=(const iterator& other) const { return i <= other.i; }        inline bool operator>(const iterator& other) const { return i > other.i; }        inline bool operator>=(const iterator& other) const { return i >= other.i; }        inline iterator &operator++() { ++i; return *this; }        inline iterator operator++(int) { T *n = i; ++i; return n; }        inline iterator &operator--() { i--; return *this; }        inline iterator operator--(int) { T *n = i; i--; return n; }        inline iterator &operator+=(int j) { i+=j; return *this; }        inline iterator &operator-=(int j) { i-=j; return *this; }        inline iterator operator+(int j) const { return iterator(i+j); }        inline iterator operator-(int j) const { return iterator(i-j); }        inline int operator-(iterator j) const { return i - j.i; }    };    friend class iterator;    class const_iterator {    public:        T *i;        typedef std::random_access_iterator_tag  iterator_category;        typedef ptrdiff_t difference_type;        typedef T value_type;        typedef const T *pointer;        typedef const T &reference;        inline const_iterator() : i(0) {}        inline const_iterator(T *n) : i(n) {}        inline const_iterator(const const_iterator &o): i(o.i) {}        inline explicit const_iterator(const iterator &o): i(o.i) {}        inline const T &operator*() const { return *i; }        inline const T *operator->() const { return i; }        inline const T &operator[](int j) const { return *(i + j); }        inline bool operator==(const const_iterator &o) const { qDebug("3"); return i == o.i; }        inline bool operator!=(const const_iterator &o) const { return i != o.i; }        inline bool operator<(const const_iterator& other) const { return i < other.i; }        inline bool operator<=(const const_iterator& other) const { return i <= other.i; }        inline bool operator>(const const_iterator& other) const { return i > other.i; }        inline bool operator>=(const const_iterator& other) const { return i >= other.i; }        inline const_iterator &operator++() { ++i; return *this; }        inline const_iterator operator++(int) { T *n = i; ++i; return n; }        inline const_iterator &operator--() { i--; return *this; }        inline const_iterator operator--(int) { T *n = i; i--; return n; }        inline const_iterator &operator+=(int j) { i+=j; return *this; }        inline const_iterator &operator-=(int j) { i+=j; return *this; }        inline const_iterator operator+(int j) const { return const_iterator(i+j); }        inline const_iterator operator-(int j) const { return const_iterator(i-j); }        inline int operator-(const_iterator j) const { return i - j.i; }    };    friend class const_iterator;#else    // STL-style    typedef T* iterator;    typedef const T* const_iterator;#endif    inline iterator begin() { detach(); return d->array; }    inline const_iterator begin() const { return d->array; }    inline const_iterator constBegin() const { return d->array; }    inline iterator end() { detach(); return d->array + d->size; }    inline const_iterator end() const { return d->array + d->size; }    inline const_iterator constEnd() const { return d->array + d->size; }    iterator insert(iterator before, int n, const T &x);    inline iterator insert(iterator before, const T &x) { return insert(before, 1, x); }    iterator erase(iterator begin, iterator end);    inline iterator erase(iterator pos) { return erase(pos, pos+1); }    // more Qt    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(); }    inline T& last() { Q_ASSERT(!isEmpty()); return *(end()-1); }    inline const T &last() const { Q_ASSERT(!isEmpty()); return *(end()-1); }    QVector<T> mid(int pos, int length = -1) const;    T value(int i) const;    T value(int i, const T &defaultValue) const;    // STL compatibility    typedef T value_type;    typedef value_type* pointer;    typedef const value_type* const_pointer;    typedef value_type& reference;    typedef const value_type& const_reference;#ifndef QT_NO_STL    typedef ptrdiff_t difference_type;#else    typedef int difference_type;#endif    typedef iterator Iterator;    typedef const_iterator ConstIterator;    typedef int size_type;    inline void push_back(const T &t) { append(t); }    inline void push_front(const T &t) { prepend(t); }    void pop_back() { Q_ASSERT(!isEmpty()); erase(end()-1); }    void pop_front() { Q_ASSERT(!isEmpty()); erase(begin()); }    inline bool empty() const    { return d->size == 0; }    inline T& front() { return first(); }    inline const_reference front() const { return first(); }    inline reference back() { return last(); }    inline const_reference back() const { return last(); }    // comfort    QVector<T> &operator+=(const QVector<T> &l);    inline QVector<T> operator+(const QVector<T> &l) const    { QVector n = *this; n += l; return n; }    inline QVector<T> &operator+=(const T &t)    { append(t); return *this; }    inline QVector<T> &operator<< (const T &t)    { append(t); return *this; }    inline QVector<T> &operator<<(const QVector<T> &l)    { *this += l; return *this; }    QList<T> toList() const;    static QVector<T> fromList(const QList<T> &list);#ifndef QT_NO_STL    static inline QVector<T> fromStdVector(const std::vector<T> &vector)    { QVector<T> tmp; qCopy(vector.begin(), vector.end(), std::back_inserter(tmp)); return tmp; }    inline std::vector<T> toStdVector() const    { std::vector<T> tmp; qCopy(constBegin(), constEnd(), std::back_inserter(tmp)); return tmp; }#endifprivate:    void detach_helper();    QVectorData *malloc(int alloc);    void realloc(int size, int alloc);    void free(Data *d);};template <typename T>void QVector<T>::detach_helper(){ realloc(d->size, d->alloc); }template <typename T>void QVector<T>::reserve(int asize){ if (asize > d->alloc) realloc(d->size, asize); }template <typename T>void QVector<T>::resize(int asize){ realloc(asize, (asize > d->alloc || (asize < d->size && asize < (d->alloc >> 1))) ?          QVectorData::grow(sizeof(Data), asize, sizeof(T), QTypeInfo<T>::isStatic)          : d->alloc); }template <typename T>inline void QVector<T>::clear(){ *this = QVector<T>(); }template <typename T>inline const T &QVector<T>::at(int i) const{ Q_ASSERT_X(i >= 0 && i < d->size, "QVector<T>::at", "index out of range");  return d->array[i]; }template <typename T>inline const T &QVector<T>::operator[](int i) const{ Q_ASSERT_X(i >= 0 && i < d->size, "QVector<T>::operator[]", "index out of range");  return d->array[i]; }template <typename T>inline T &QVector<T>::operator[](int i){ Q_ASSERT_X(i >= 0 && i < d->size, "QVector<T>::operator[]", "index out of range");  return data()[i]; }template <typename T>inline void QVector<T>::insert(int i, const T &t){ Q_ASSERT_X(i >= 0 && i <= d->size, "QVector<T>::insert", "index out of range");  insert(begin() + i, 1, t); }template <typename T>inline void QVector<T>::insert(int i, int n, const T &t){ Q_ASSERT_X(i >= 0 && i <= d->size, "QVector<T>::insert", "index out of range");  insert(begin() + i, n, t); }template <typename T>inline void QVector<T>::remove(int i, int n){ Q_ASSERT_X(i >= 0 && n >= 0 && i + n <= d->size, "QVector<T>::remove", "index out of range");  erase(begin() + i, begin() + i + n); }template <typename T>inline void QVector<T>::remove(int i){ Q_ASSERT_X(i >= 0 && i < d->size, "QVector<T>::remove", "index out of range");  erase(begin() + i, begin() + i + 1); }template <typename T>inline void QVector<T>::prepend(const T &t){ insert(begin(), 1, t); }template <typename T>inline void QVector<T>::replace(int i, const T &t){    Q_ASSERT_X(i >= 0 && i < d->size, "QVector<T>::replace", "index out of range");    const T copy(t);    data()[i] = copy;}template <typename T>QVector<T> &QVector<T>::operator=(const QVector<T> &v){    typename QVector::Data *x = v.d;    x->ref.ref();    x = qAtomicSetPtr(&d, x);    if (!x->ref.deref())        free(x);    if (!d->sharable)        detach_helper();    return *this;}template <typename T>inline QVectorData *QVector<T>::malloc(int aalloc){    return static_cast<QVectorData *>(qMalloc(sizeof(Data) + (aalloc - 1) * sizeof(T)));}template <typename T>QVector<T>::QVector(int asize){    p = malloc(asize);    d->ref.init(1);    d->alloc = d->size = asize;    d->sharable = true;    if (QTypeInfo<T>::isComplex) {        T* b = d->array;        T* i = d->array + d->size;        while (i != b)            new (--i) T;    } else {        qMemSet(d->array, 0, asize * sizeof(T));    }}template <typename T>QVector<T>::QVector(int asize, const T &t){    p = malloc(asize);    d->ref.init(1);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
理论片日本一区| 亚洲国产高清在线| 日韩av中文字幕一区二区| 欧美三级电影在线看| 免费在线观看成人| 久久精品日产第一区二区三区高清版 | 欧美性欧美巨大黑白大战| 亚洲午夜久久久久中文字幕久| 欧美三级视频在线播放| 免费的国产精品| 国产日韩亚洲欧美综合| 91视频免费看| 热久久一区二区| 国产人成亚洲第一网站在线播放 | 欧美日韩亚洲综合| 狠狠色狠狠色综合日日91app| 国产欧美一区二区在线观看| 日本精品一区二区三区高清| 日韩精品免费专区| 欧美激情一区二区三区蜜桃视频| 99re66热这里只有精品3直播| 五月天亚洲婷婷| 国产精品免费久久| 欧美精品1区2区3区| 国产精品一区在线观看乱码| 亚洲精品免费在线| 精品国产乱码久久久久久蜜臀| 成人一级视频在线观看| 亚洲成人免费av| 国产精品免费人成网站| 日韩亚洲欧美在线| 91在线国内视频| 毛片av一区二区三区| 亚洲欧美影音先锋| 日韩精品中文字幕在线不卡尤物| 暴力调教一区二区三区| 美女免费视频一区| 亚洲在线免费播放| 国产人妖乱国产精品人妖| 欧美老肥妇做.爰bbww视频| 成人免费视频视频| 久久精品国产精品青草| 亚洲一区二区三区四区五区黄| 欧美精品一区二区久久久| 欧美无砖砖区免费| 成人18视频日本| 国产精品一二三四区| 日韩国产一区二| 亚洲第一二三四区| 中文字幕视频一区| 久久亚洲精品国产精品紫薇| 7777精品伊人久久久大香线蕉超级流畅 | 在线观看日韩电影| 成人精品免费看| 欧洲国产伦久久久久久久| 国产一区91精品张津瑜| 日本不卡中文字幕| 日日噜噜夜夜狠狠视频欧美人 | 欧美国产欧美综合| 精品久久免费看| 日韩精品在线网站| 日韩欧美亚洲国产另类| 91精品国模一区二区三区| 欧美日韩免费高清一区色橹橹| 色哟哟一区二区| 色综合久久久久综合| 99久久国产综合色|国产精品| 国产成人精品免费看| 国产在线精品不卡| 国产麻豆一精品一av一免费| 精品一区二区三区在线视频| 久久激五月天综合精品| 精品一区二区国语对白| 麻豆精品视频在线观看免费| 美女网站色91| 久久99国产乱子伦精品免费| 激情五月婷婷综合| 国产一区二区三区免费播放| 精品一区二区三区日韩| 国产毛片精品视频| 成人免费不卡视频| av电影天堂一区二区在线观看| 91在线porny国产在线看| 99精品视频一区二区三区| 色诱亚洲精品久久久久久| 色综合亚洲欧洲| 欧美女孩性生活视频| 欧美一区二区久久久| 久久综合久久久久88| 国产精品电影一区二区三区| 亚洲免费视频成人| 亚洲国产人成综合网站| 五月婷婷色综合| 韩国三级在线一区| jlzzjlzz欧美大全| 欧美在线免费观看亚洲| 日韩一区二区免费在线观看| www激情久久| |精品福利一区二区三区| 亚洲成人av一区二区| 激情综合网天天干| 99久久伊人精品| 欧美高清性hdvideosex| wwww国产精品欧美| 综合久久久久综合| 奇米综合一区二区三区精品视频| 国内成人免费视频| 在线观看日韩高清av| 亚洲精品在线免费播放| 亚洲欧洲精品一区二区三区不卡| 亚洲一二三四区不卡| 精品亚洲国内自在自线福利| 色综合中文字幕国产| 欧美另类久久久品| 中文字幕av一区二区三区免费看| 亚洲综合久久av| 国产精品亚洲一区二区三区妖精| 久久久亚洲午夜电影| 亚洲女人的天堂| 精品一区二区三区影院在线午夜| 91女人视频在线观看| 日韩女同互慰一区二区| 一区二区三区在线免费播放| 国内精品伊人久久久久影院对白| 91首页免费视频| 久久久久久亚洲综合影院红桃| 一区二区成人在线视频| 国产精品一卡二卡在线观看| 欧美日韩国产免费一区二区| 中文在线资源观看网站视频免费不卡| 亚洲mv大片欧洲mv大片精品| 懂色av中文一区二区三区| 日韩午夜av一区| 亚洲综合一区二区精品导航| 国产91丝袜在线播放0| 欧美一区二区三区在线观看视频 | 欧美日韩精品欧美日韩精品一综合| 2023国产精品| 免费观看30秒视频久久| 欧美日韩久久久久久| 中文字幕在线观看不卡| 国产毛片精品国产一区二区三区| 欧美一区二区三区日韩| 亚洲观看高清完整版在线观看| av在线不卡电影| 国产人久久人人人人爽| 国产一区二区三区不卡在线观看| 欧美日韩一区二区三区四区五区| 自拍偷拍亚洲激情| 成人激情免费电影网址| 久久精品视频免费| 国产伦精品一区二区三区免费迷 | 久久久久久毛片| 免费观看30秒视频久久| 欧美日韩久久久久久| 亚洲影院在线观看| 日本乱码高清不卡字幕| 亚洲精品乱码久久久久久日本蜜臀| 成人av网站免费| 国产日韩影视精品| 国产不卡视频在线观看| 国产喷白浆一区二区三区| 国产一区中文字幕| 久久久精品国产免费观看同学| 国产一区不卡视频| 欧美国产精品劲爆| 91在线小视频| 亚洲三级在线观看| 在线日韩av片| 天天色天天操综合| 日韩一区二区免费高清| 国产在线国偷精品免费看| 国产视频一区二区在线观看| 国产成人亚洲综合a∨婷婷| 国产欧美日产一区| 91碰在线视频| 天堂成人国产精品一区| 日韩天堂在线观看| 国产成人啪免费观看软件| 国产精品久久久久aaaa樱花| 一本色道久久综合亚洲aⅴ蜜桃 | 国产精品美女一区二区三区| 99r国产精品| 亚洲成人自拍偷拍| 日韩精品一区二区三区在线观看 | 国产欧美日韩在线视频| 91在线精品一区二区三区| 亚洲一区二区偷拍精品| 日韩区在线观看| 风间由美性色一区二区三区| 亚洲色图欧洲色图婷婷| 欧美性大战久久久| 激情五月激情综合网| 中文字幕一区在线| 91.com视频| k8久久久一区二区三区| 丝袜a∨在线一区二区三区不卡| 337p日本欧洲亚洲大胆精品| 99re这里只有精品6| 麻豆视频观看网址久久|