日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

atomic头文件编译_c++11 多线程(3)atomic 总结

發布時間:2023/12/16 c/c++ 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 atomic头文件编译_c++11 多线程(3)atomic 总结 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、頭文件結構

頭文件:原子類型是封裝了一個值的類型,它的訪問保證不會導致數據的競爭,并且可以用于在不同的線程之間同步內存訪問。

這個頭聲明了兩個c++類,原子和atomic_flag,它實現了自包含類中的原子類型的所有特性。header還聲明了整個C樣式類型和函數與C中的原子支持兼容。頭文件中結構定義查看。

頭文件的結構:

class

用于bool、整數和指針類型的原子類模板和特殊化 (類模板)

無鎖布爾原子類型(類)

Types

為給定的原子操作定義內存排序約束(typedef)

Typedefs

std::atomic_bool

std::atomic

std::atomic_char

std::atomic

std::atomic_schar

std::atomic

std::atomic_uchar

std::atomic

std::atomic_short

std::atomic

std::atomic_ushort

std::atomic

std::atomic_int

std::atomic

std::atomic_uint

std::atomic

std::atomic_long

std::atomic

std::atomic_ulong

std::atomic

std::atomic_llong

std::atomic

std::atomic_ullong

std::atomic

std::atomic_char16_t

std::atomic

std::atomic_char32_t

std::atomic

std::atomic_wchar_t

std::atomic

std::atomic_int_least8_t

std::atomic

std::atomic_uint_least8_t

std::atomic

std::atomic_int_least16_t

std::atomic

std::atomic_uint_least16_t

std::atomic

std::atomic_int_least32_t

std::atomic

std::atomic_uint_least32_t

std::atomic

std::atomic_int_least64_t

std::atomic

std::atomic_uint_least64_t

std::atomic

std::atomic_int_fast8_t

std::atomic

std::atomic_uint_fast8_t

std::atomic

std::atomic_int_fast16_t

std::atomic

std::atomic_uint_fast16_t

std::atomic

std::atomic_int_fast32_t

std::atomic

std::atomic_uint_fast32_t

std::atomic

std::atomic_int_fast64_t

std::atomic

std::atomic_uint_fast64_t

std::atomic

std::atomic_intptr_t

std::atomic

std::atomic_uintptr_t

std::atomic

std::atomic_size_t

std::atomic

std::atomic_ptrdiff_t

std::atomic

std::atomic_intmax_t

std::atomic

std::atomic_uintmax_t

std::atomic

Functions for atomic flags (C-style)

description

Preprocessor macros

description

靜態存儲時間的原子變量的常量初始化(宏)

初始化 std::atomic_flag為 false

Macro constants

// lock-free property

#define ATOMIC_BOOL_LOCK_FREE /*unspecified*/

#define ATOMIC_CHAR_LOCK_FREE /*unspecified*/

#define ATOMIC_CHAR16_T_LOCK_FREE /*unspecified*/

#define ATOMIC_CHAR32_T_LOCK_FREE /*unspecified*/

#define ATOMIC_WCHAR_T_LOCK_FREE /*unspecified*/

#define ATOMIC_SHORT_LOCK_FREE /*unspecified*/

#define ATOMIC_INT_LOCK_FREE /*unspecified*/

#define ATOMIC_LONG_LOCK_FREE /*unspecified*/

#define ATOMIC_LLONG_LOCK_FREE /*unspecified*/

#define ATOMIC_POINTER_LOCK_FREE /*unspecified*/

上面是對頭文件結構的描述;下面具體按照上面的結構分析:

定義 : //類模版

template< class T > struct atomic; (1) (since C++11)

template<> struct atomic; (2) (since C++11)

template<> struct atomic; (3) (since C++11)

template< class T > struct atomic; (4) (since C++11) 指針特化

std::atomic模板的每個實例化和專門化都定義了一個原子類型。如果一個線程在另一個線程讀取它時寫入一個原子對象,那么行為就會被明確定義(參見關于數據競爭的詳細信息的內存模型)。此外,對原子對象的訪問可以建立線程間的同步,并按照std::memoryorder指定非原子性的內存訪問。

std::atomic可以用任何簡單的可復制的t實例化。同時std::atomic是不可復制的,也不是可移動的。

Member functions

atomic() noexcept = default;(1) default (since C++11)

constexpr atomic( T desired ) noexcept;(2) initialization (since C++11)

atomic( const atomic& ) = delete;(3) copy [deleted] (since C++11)

構造新的原子變量。

1)將原子對象放在未初始化的狀態中。一個未初始化的原子對象可以通過調用atomicinit來初始化。

2)用desired 初始化對象。初始化不是原子性的。

3)原子變量不是可復制的。

示例1:

// constructing atomics

#include // std::cout

#include // std::atomic, std::atomic_flag, ATOMIC_FLAG_INIT

#include // std::thread, std::this_thread::yield

#include // std::vector

std::atomic ready (false);

std::atomic_flag winner = ATOMIC_FLAG_INIT;

void count1m (int id) {

while (!ready) { std::this_thread::yield(); } // wait for the ready signal

for (volatile int i=0; i<1000000; ++i) {} // go!, count to 1 million

if (!winner.test_and_set()) { std::cout << "thread #" << id << " won!\n"; }

};

int main ()

{

std::vector<:thread> threads;

std::cout << "spawning 10 threads that count to 1 million...\n";

for (int i=1; i<=10; ++i) threads.push_back(std::thread(count1m,i));

ready = true;

for (auto& th : threads) th.join();

return 0;

}

T operator=( T desired ) noexcept; set value (1)

T operator=( T desired ) volatile noexcept; set value (1)

atomic& operator=( const atomic& ) = delete; copy [deleted] (2)

atomic& operator=( const atomic& ) volatile = delete; copy [deleted] (2)

1 用val替換存儲的值。該操作是原子性的,并使用順序一致性(memoryorderseqcst)。要使用不同的內存排序來修改值,請參見atomic::store。

2 原子對象沒有定義的復制賦值,但是注意它們是可以隱式地轉換為類型T。

注意:與大多數賦值運算符不同,原子類型的賦值運算符不會返回對它們的左參數的引用。它們返回一個存儲值的副本。

示例2:

// atomic::operator=/operator T example:

#include // std::cout

#include // std::atomic

#include // std::thread, std::this_thread::yield

std::atomic foo(0);

void set_foo(int x) {

foo = x;

}

void print_foo() {

while (foo==0) { // wait while foo=0

std::this_thread::yield();

}

std::cout << "foo: " << foo << '\n';

}

int main ()

{

std::thread first (print_foo);

std::thread second (set_foo,10);

first.join();

second.join();

return 0;

}

General atomic operations

bool is_lock_free() const noexcept;

bool is_lock_free() const volatile noexcept;

一個無鎖對象并不會導致其他線程在訪問時被阻塞(可能使用某種類型的事務性內存)。該函數返回的值與相同類型的所有其他對象返回的值一致。

檢查這個類型的所有對象的原子操作是否都是無鎖的。返回true表示lock_free.

示例3:

#include

#include

#include

struct A { int a[100]; };

struct B { int x, y; };

int main()

{

std::cout << std::boolalpha

<< "std::atomic is lock free? "

<< std::atomic{}.is_lock_free() << '\n'

<< "std::atomic is lock free? "

<< std::atomic{}.is_lock_free() << '\n';

return 0;

}

void store (T val, memory_order sync = memory_order_seq_cst) volatile noexcept;

void store (T val, memory_order sync = memory_order_seq_cst) noexcept;

用val替換包含的值。操作是原子的,按照同步所指定的內存順序內存數序包括(std::memory_order_relaxed, std::memory_order_release 和std::memory_order_seq_cst)。

參數sync的描述(后續會介紹memory_order):

memory_order_relaxed: 不同步副作用。

memory_order_release:同步下一個使用或者獲取操作的副作用。

memory_order_seq_cst:同步所有與其他順序一致操作的可見的副作用,并遵循一個完整的順序。

示例4:

// atomic::load/store example

#include // std::cout

#include // std::atomic, std::memory_order_relaxed

#include // std::thread

std::atomic foo (0);

void set_foo(int x) {

foo.store(x,std::memory_order_relaxed); // set value atomically

}

void print_foo() {

int x;

do {

x = foo.load(std::memory_order_relaxed); // get value atomically

} while (x==0);

std::cout << "foo: " << x << '\n';

}

int main ()

{

std::thread first (print_foo);

std::thread second (set_foo,10);

first.join();

second.join();

return 0;

}

T load (memory_order sync = memory_order_seq_cst) const volatile noexcept;

T load (memory_order sync = memory_order_seq_cst) const noexcept;

返回包含值。操作是原子的,按照同步所指定的內存順序。指令必須是std::memory_order_relaxed, std::memory_order_consume, std::memory_order_acquire 和 std::memory_order_seq_cst);否則,行為是沒有定義的。

sync指令描述:

上文已經描述了std::memory_order_relaxed和 std::memory_order_seq_cst,這里只描述memory_order_acquire和memory_order_consume。

memory_order_acquire:同步從最后一個Release或順序一致的操作所有可見的副作用。

memory_order_consume:同步與最后一個Release或順序一致的操作所產生的依賴關系的可見的副作用。

示例5:

// atomic::load/store example

#include // std::cout

#include // std::atomic, std::memory_order_relaxed

#include // std::thread

std::atomic foo (0);

void set_foo(int x) {

foo.store(x,std::memory_order_relaxed); // set value atomically

}

void print_foo() {

int x;

do {

x = foo.load(std::memory_order_relaxed); // get value atomically

} while (x==0);

std::cout << "foo: " << x << '\n';

}

int main ()

{

std::thread first (print_foo);

std::thread second (set_foo,10);

first.join();

second.join();

return 0;

}

operator T() const volatile noexcept;

operator T() const noexcept;

這是一個類型轉換的操作符:這個表達式期望它包含的類型(T)的值,調用這個成員函數,訪問包含的值。

該操作是原子的,并使用順序一致性(memory_order_seq_cst)。要檢索具有不同內存順序的值,相當于std::atomic::load。

示例6:

// atomic::operator=/operator T example:

#include // std::cout

#include // std::atomic

#include // std::thread, std::this_thread::yield

std::atomic foo(0);

std::atomic bar(0);

void set_foo(int x) {

foo = x;

}

void copy_foo_to_bar () {

while (foo==0) std::this_thread::yield();

bar = static_cast(foo);

}

void print_bar() {

while (bar==0) std::this_thread::yield();

std::cout << "bar: " << bar << '\n';

}

int main ()

{

std::thread first (print_bar);

std::thread second (set_foo,10);

std::thread third (copy_foo_to_bar);

first.join();

second.join();

third.join();

return 0;

}

T exchange (T val, memory_order sync = memory_order_seq_cst) volatile noexcept;

T exchange (T val, memory_order sync = memory_order_seq_cst) noexcept;

訪問和修改包含的值

用val替換所包含的值,并返回它之前的值。整個操作是原子性的(一個原子的讀-修改-寫操作):在讀取(返回)值和被該函數修改的那一刻之間,值不會受到其他線程的影響。

sync指令描述:

上文已經描述了std::memory_order_relaxed和 std::memory_order_seq_cst 和memory_order_consume 和 memory_order_acquire,這里只描述memory_order_acq_rel。

memory_order_acq_rel:讀取作為一個獲取操作,并作為一個發布操作寫入。

示例 7:

// atomic::exchange example

#include // std::cout

#include // std::atomic

#include // std::thread

#include // std::vector

std::atomic ready (false);

std::atomic winner (false);

void count1m (int id) {

while (!ready) {} // wait for the ready signal

for (int i=0; i<1000000; ++i) {} // go!, count to 1 million

if (!winner.exchange(true)) { std::cout << "thread #" << id << " won!\n"; }

};

int main ()

{

std::vector<:thread> threads;

std::cout << "spawning 10 threads that count to 1 million...\n";

for (int i=1; i<=10; ++i) threads.push_back(std::thread(count1m,i));

ready = true;

for (auto& th : threads) th.join();

return 0;

}

bool compare_exchange_weak (T& expected, T val,

memory_order sync = memory_order_seq_cst) volatile noexcept; (1)

bool compare_exchange_weak (T& expected, T val,

memory_order sync = memory_order_seq_cst) noexcept; (1)

bool compare_exchange_weak (T& expected, T val,

memory_order success, memory_order failure) volatile noexcept; (2)

bool compare_exchange_weak (T& expected, T val,

memory_order success, memory_order failure) noexcept; (2)

bool compare_exchange_strong (T& expected, T val,

memory_order sync = memory_order_seq_cst) volatile noexcept; (1)

bool compare_exchange_strong (T& expected, T val,

memory_order sync = memory_order_seq_cst) noexcept; (1)

bool compare_exchange_strong (T& expected, T val,

memory_order success, memory_order failure) volatile noexcept; (2)

bool compare_exchange_strong (T& expected, T val,

memory_order success, memory_order failure) noexcept; (2)

* 比較原子對象的包含值與預期的內容:

--1 如果是真的,它會用val替換包含的值(比如存儲)。

--2 如果是假的,它會用所包含的值替換預期,因此調用該函數之后,如果被該原子對象封裝的值與參數 expected 所指定的值不相等,expected 中的內容就是原子對象的舊值。

* 函數總是訪問包含的值來讀取它,如果這個比較是真的,那么它也會替換它。但是整個操作都是原子性的:在讀取值和被替換的時刻之間,它的值不能被其他線程修改。

* 在第(2)種情況下,內存序(Memory Order)的選擇取決于比較操作結果,如果比較結果為 true(即原子對象的值等于 expected),則選擇參數 success 指定的內存序,否則選擇參數 failure 所指定的內存序。

** 注意:

這個函數直接的比較物理內容所包含的價值與預期的內容,這可能導致得到使用operator==比較的結果是一個失敗的結果,因為對象底層的物理內容中可能存在位對齊或其他邏輯表示相同但是物理表示不同的值(比如 true 和 2 或 3,它們在邏輯上都表示"真",但在物理上兩者的表示并不相同)。

不像 compare_exchange_strong,這個弱版本允許(spuriously 地)返回 false(即原子對象所封裝的值與參數 expected 的物理內容相同,但卻仍然返回 false),即使在預期的實際情況與所包含的對象相比較時也是如此。對于某些循環算法來說,這可能是可接受的行為,并且可能會在某些平臺上帶來顯著的性能提升。在這些虛假的失敗中,函數返回false,而不修改預期。

對于非循環算法來說, compare_exchange_strong通常是首選。

示例8:

// atomic::compare_exchange_weak example:

#include // std::cout

#include // std::atomic

#include // std::thread

#include // std::vector

// a simple global linked list:

struct Node { int value; Node* next; };

std::atomic list_head (nullptr);

void append (int val) { // append an element to the list

Node* oldHead = list_head;

Node* newNode = new Node {val,oldHead};

// what follows is equivalent to: list_head = newNode, but in a thread-safe way:

while (!list_head.compare_exchange_weak(oldHead,newNode))

newNode->next = oldHead;

}

int main ()

{

// spawn 10 threads to fill the linked list:

std::vector<:thread> threads;

for (int i=0; i<10; ++i) threads.push_back(std::thread(append,i));

for (auto& th : threads) th.join();

// print contents:

for (Node* it = list_head; it!=nullptr; it=it->next)

std::cout << ' ' << it->value;

std::cout << '\n';

// cleanup:

Node* it; while (it=list_head) {list_head=it->next; delete it;}

return 0;

}

compare_exchange_strong 跟 compare_exchange_week 不同的是:

與compare_exchange_weak 不同, strong版本的 compare-and-exchange 操作不允許(spuriously 地)返回 false,即原子對象所封裝的值與參數 expected 的物理內容相同,比較操作一定會為 true。不過在某些平臺下,如果算法本身需要循環操作來做檢查, compare_exchange_weak 的性能會更好。

特定的操作支持(整形和指針)

if T is integral (1)

T fetch_add (T val, memory_order sync = memory_order_seq_cst) volatile noexcept;

T fetch_add (T val, memory_order sync = memory_order_seq_cst) noexcept;

T fetch_sub (T val, memory_order sync = memory_order_seq_cst) volatile noexcept;

T fetch_sub (T val, memory_order sync = memory_order_seq_cst) noexcept;

if T is pointer (2)

T fetch_add (ptrdiff_t val, memory_order sync = memory_order_seq_cst) volatile noexcept;

T fetch_add (ptrdiff_t val, memory_order sync = memory_order_seq_cst) noexcept;

T fetch_sub (ptrdiff_t val, memory_order sync = memory_order_seq_cst) volatile noexcept;

T fetch_sub (ptrdiff_t val, memory_order sync = memory_order_seq_cst) noexcept;

*將val加或者減去到包含的值并返回在操作之前的值。

*整個操作是原子的(一個原子的讀-修改-寫操作):當在這個函數被修改的時候,讀取的(返回)值被讀取,值不受其他線程的影響。

*這個成員函數是對整數(1)和指針(2)類型(除了bool除外)的原子專門化中定義。

*如果第二個參數使用默認值,則該函數等價于原子::運算符+ =。

示例9:

#include

#include

#include

std::atomic data;

void do_work()

{

data.fetch_add(1, std::memory_order_relaxed);

}

int main()

{

std::thread th1(do_work);

std::thread th2(do_work);

std::thread th3(do_work);

std::thread th4(do_work);

std::thread th5(do_work);

th1.join();

th2.join();

th3.join();

th4.join();

th5.join();

std::cout << "Result:" << data << '\n';

return 0;

}

T fetch_and (T val, memory_order sync = memory_order_seq_cst) volatile noexcept;

T fetch_and (T val, memory_order sync = memory_order_seq_cst) noexcept;

T fetch_or (T val, memory_order sync = memory_order_seq_cst) volatile noexcept;

T fetch_or (T val, memory_order sync = memory_order_seq_cst) noexcept;

T fetch_xor (T val, memory_order sync = memory_order_seq_cst) volatile noexcept;

T fetch_xor (T val, memory_order sync = memory_order_seq_cst) noexcept;

* 讀取包含的值并替換調該值和val執行一個位和操作的結果。

* 整個操作是原子的(一個原子的讀-修改-寫操作):當在這個函數被修改的時候,讀取的(返回)值被讀取,值不受其他線程的影響。

* 這個成員函數只在原子專門化中定義為整數類型(除了bool)。

* 如果第二個參數使用默認值,則該函數等價于原子::operator& =。

T operator++() volatile noexcept;

T operator++() noexcept;

T operator--() volatile noexcept;

T operator--() noexcept;

post-increment (2)

T operator++ (int) volatile noexcept;

T operator++ (int) noexcept;

T operator-- (int) volatile noexcept;

T operator-- (int) noexcept;

* 包含值的值進行增加或減少1,操作(1)返回所得到的包含值,操作(2)返回之前的值。

* 整個操作是原子的(一個原子的讀-修改-寫操作):當在這個函數被修改的時候,讀取的(返回)值被讀取,值不受其他線程的影響。

* 函數只在原子專門化中定義為整數和指針類型(除了bool)。

* 這個函數的行為就像調用std::stomic::fetch_add(1),memory_order_seq_cst作為參數。

if T is integral (1)

T operator+= (T val) volatile noexcept;

T operator+= (T val) noexcept;

T operator-= (T val) volatile noexcept;

T operator-= (T val) noexcept;

T operator&= (T val) volatile noexcept;

T operator&= (T val) noexcept;

T operator|= (T val) volatile noexcept;

T operator|= (T val) noexcept;

T operator^= (T val) volatile noexcept;

T operator^= (T val) noexcept;

if T is pointer (2)

T operator+= (ptrdiff_t val) volatile noexcept;

T operator+= (ptrdiff_t val) noexcept;

T operator-= (ptrdiff_t val) volatile noexcept;

T operator-= (ptrdiff_t val) noexcept;

* 對于整形(1)和指針(2)類型的原子專門化是支持復合賦值的;每一個函數都訪問包含的值,應用合適的操作符,并在操作之前返回包含值的值;所有這些操作都不會受到其他線程的影響。

* 這些函數的行為就像使用memory_order_seq_cst調用std::stomic::fetch_ *函數一樣:

atomic_flag是一個原子布爾類型。不同于std::atomic的所有專門化,它保證是lock_free。不像std::stomic< bool >,std::atomic_flag不提供負載或存儲操作。

示例10:

#include

#include

#include

#include

std::atomic_flag lock = ATOMIC_FLAG_INIT;

void f(int n)

{

for (int cnt = 0; cnt < 100; ++cnt) {

while (lock.test_and_set(std::memory_order_acquire)) // acquire lock

; // spin

std::cout << "Output from thread " << n << '\n';

lock.clear(std::memory_order_release); // release lock

}

}

int main()

{

std::vector<:thread> v;

for (int n = 0; n < 10; ++n) {

v.emplace_back(f, n);

}

for (auto& t : v) {

t.join();

}

return 0;

}

atomic_flag() noexcept = default;

atomic_flag (const atomic_flag&T) = delete;

* atomic_flag在構建(或設置或清除)上處于一個未指定的狀態,除非它被顯式地初始化為ATOMIC_FLAG_INIT。

* ATOMIC_FLAG_INIT初始化是通過簡單地調用默認構造函數或其他方法來實現的,這取決于特定的庫實現。

* atomic_flag值不能復制/移動。

*** 注意: std::atomic_flag::operator= 不可賦值,其賦值操作符被刪除。。

示例11:

// constructing atomics: atomic vs atomic_flag

#include // std::cout

#include // std::atomic, std::atomic_flag, ATOMIC_FLAG_INIT

#include // std::thread, std::this_thread::yield

#include // std::vector

std::atomic ready (false); // can be checked without being set

std::atomic_flag winner = ATOMIC_FLAG_INIT; // always set when checked

void count1m (int id) {

while (!ready) { std::this_thread::yield(); } // wait for the ready signal

for (int i=0; i<1000000; ++i) {} // go!, count to 1 million

if (!winner.test_and_set()) { std::cout << "thread #" << id << " won!\n"; }

};

int main ()

{

std::vector<:thread> threads;

std::cout << "spawning 10 threads that count to 1 million...\n";

for (int i=1; i<=10; ++i) threads.push_back(std::thread(count1m,i));

ready = true;

for (auto& th : threads) th.join();

return 0;

}

bool test_and_set (memory_order sync = memory_order_seq_cst) volatile noexcept;

bool test_and_set (memory_order sync = memory_order_seq_cst) noexcept;

* 設置atomic_flag并返回是否在調用之前已經設置的。

* * 整個操作是原子的(一個原子的讀-修改-寫操作):當在這個函數被修改的時候,讀取的(返回)值被讀取,值不受其他線程的影響。

示例12:

// atomic_flag as a spinning lock

#include // std::cout

#include // std::atomic_flag

#include // std::thread

#include // std::vector

#include // std::stringstream

std::atomic_flag lock_stream = ATOMIC_FLAG_INIT;

std::stringstream stream;

void append_number(int x) {

while (lock_stream.test_and_set()) {}

stream << "thread #" << x << '\n';

lock_stream.clear();

}

int main ()

{

std::vector<:thread> threads;

for (int i=1; i<=10; ++i) threads.push_back(std::thread(append_number,i));

for (auto& th : threads) th.join();

std::cout << stream.str();

return 0;

}

void clear (memory_order sync = memory_order_seq_cst) volatile noexcept;

void clear (memory_order sync = memory_order_seq_cst) noexcept;

清除atomic_flag(即把atomic_flag 設為假)。

清除atomic_flag使下一次調用成員atomic_flag::test_and_set對象返回false。

操作是原子的,按照sync所指定的內存順序。

示例13:

// atomic_flag as a spinning lock

#include // std::cout

#include // std::atomic_flag

#include // std::thread

#include // std::vector

#include // std::stringstream

std::atomic_flag lock_stream = ATOMIC_FLAG_INIT;

std::stringstream stream;

void append_number(int x) {

while (lock_stream.test_and_set()) {}

stream << "thread #" << x << '\n';

lock_stream.clear();

}

int main ()

{

std::vector<:thread> threads;

for (int i=1; i<=10; ++i) threads.push_back(std::thread(append_number,i));

for (auto& th : threads) th.join();

std::cout << stream.str();

return 0;

}

作為用于執行原子操作的函數的參數,用于指定如何同步不同線程上的其他操作。也可參見網址。

定義:

```c

typedef enum memory_order {

memory_order_relaxed, // relaxed

memory_order_consume, // consume

memory_order_acquire, // acquire

memory_order_release, // release

memory_order_acq_rel, // acquire/release

memory_order_seq_cst // sequentially consistent

} memory_order;

* 當多個線程訪問原子對象時,所有原子操作都會對一個原子對象定義良好的行為:在任何其他原子操作能夠訪問該對象之前,每個原子操作都是完全在對象上執行的。這保證了這些對象上沒有數據競爭,而這正是定義原子性的特性。

* 但是,每個線程可能在內存位置上執行操作,而不是原子對象本身:這些操作可能會對其他線程產生可見的副作用。這種類型的參數允許指定操作的內存順序,以確定這些(可能非原子)可見的副作用是如何在線程間同步的,使用原子操作作為同步點:

memory_order_relaxed

該操作在某一時刻被命令進行原子化。這是最寬松的內存順序,無法保證對不同線程的內存訪問是如何根據原子操作進行排序的。

標記為memory_order_relaxed的原子操作不是同步操作;它們不會在并發內存訪問中強制執行順序。它們只保證原子性和修改順序的一致性。

示例14:

#include

#include

#include

#include

std::atomic cnt = {0};

void f()

{

for (int n = 0; n < 1000; ++n) {

cnt.fetch_add(1, std::memory_order_relaxed);

}

}

int main()

{

std::vector<:thread> v;

for (int n = 0; n < 10; ++n) {

v.emplace_back(f);

}

for (auto& t : v) {

t.join();

}

std::cout << "Final counter value is " << cnt << '\n';

return 0;

}

memory_order_consume

如果在這個對釋放操作進行依賴(并且對加載線程有明顯的副作用)的釋放線程上 所有訪問內存 已經發生,那么操作將被命令執行。

帶有這個內存順序的加載操作在受影響的內存位置上執行獲取操作:當前線程依賴于當前裝載的值,在此負載之前,不需要讀取或寫入。在當前線程中可以看到相同的原子變量。在大多數平臺上,這只會影響編譯器優化(參見下面的Release-Consume)。

memory_order_acquire

在釋放線程(對加載線程有明顯的副作用)的情況下,操作被命令進行一次。

帶有這個內存順序的加載操作在受影響的內存位置上執行獲取操作:在此負載之前,在當前線程中不可以重新排序。所有在其他線程中都可以在當前線程中看到相同的原子變量(參見下面的Release-Acquire)

memory_order_release

* 該操作被命令在消費或獲取操作之前發生,作為對內存的其他訪問的同步點,可能對加載線程有可見的副作用。

* 具有這種內存順序的存儲操作執行釋放操作:在當前線程中,在該存儲之后,不可以在當前線程中重新排序。當前線程中所有的寫操作都可以在其他線程中看到,這些線程獲得相同的原子變量(參見下面的Release-Acquire),并且在使用相同原子的其他線程中,將對原子變量的依賴變為可見(參見下面的Release-Consume)。

memory_order_acq_rel

* 該操作加載并存儲釋放(如上所述,用于memory_order_acquire 、memory_order_release)。

memory_order_seq_cst

* 這個操作是按順序一致的方式排序的:所有使用這個內存順序的操作都是在所有可能對其他線程都有可見副作用的內存中執行的。

* 這是最嚴格的內存順序,在非原子內存訪問的情況下,保證了線程交互中最不意外的副作用。

* 對于消費和獲取負載,順序一致的存儲操作被認為是發布操作。

四、Functions

template

T kill_dependency (T y) noexcept;

* 返回y的值而不需要依賴項。

* 使用memory_order_consume 作為內存順序的原子操作,要求編譯器檢查通過訪問存儲的內存位置所帶來的依賴關系。同步這樣的依賴關系可能會導致某些硬件設置被設置,并迫使編譯器放棄涉及這些內存位置的某些潛在優化。

* 調用此函數指示編譯器,任何依賴于y的依賴項都不應被傳遞到返回值,而不需要同步。

extern "C" void atomic_thread_fence (memory_order sync) noexcept;

建立一個多線程的隔離:對這個函數的調用的時間點變成一個獲取或者一個釋放(或者兩者都是)的同步點。

在調用這個函數之前發生的釋放線程的所有可見的副作用都是同步的,在調用這個函數在獲取線程之前。

調用該函數與加載或存儲原子操作具有相同的效果,但不涉及原子值。

extern "C" void atomic_signal_fence (memory_order sync) noexcept;

建立一個單線程的隔離:對這個函數的調用點在一個線程內變成一個獲取或一個釋放點(或者兩者)。

這個函數相當于atomic_thread_fence ,但是沒有因為調用而發生線程間同步。該函數的作用是對編譯器進行指令,以阻止它進行優化,包括將寫操作移動到一個釋放柵欄或在獲取柵欄之前的讀操作。

五、 Functions for atomic objects (C-style)

template (1)

template bool atomic_is_lock_free (const volatile atomic* obj) noexcept;

template bool atomic_is_lock_free (const atomic* obj) noexcept;

overloads (2)

bool atomic_is_lock_free (const volatile A* obj) noexcept;

bool atomic_is_lock_free (const A* obj) noexcept;

是否是lock_free。

注意:

除了std::atomicflag的所有原子類型都可以使用互斥鎖或其他鎖定操作實現,而不是使用無鎖的原子CPU指令。原子類型也被允許有時是無鎖的,例如,如果在給定的體系結構中,只有對齊的內存訪問是自然的,那么相同類型的不一致的對象就必須使用鎖。

C++標準推薦(但不需要)無鎖的原子操作也是無地址的,也就是說,適合于使用共享內存的進程之間的通信。

示例15 (同示例3):

#include

#include

#include

struct A { int a[100]; };

struct B { int x, y; };

int main()

{

std::atomic a;

std::atomic b;

std::cout << std::boolalpha

<< "std::atomic is lock free? "

<< std::atomic_is_lock_free(&a) << '\n'

<< "std::atomic is lock free? "

<< std::atomic_is_lock_free(&b) << '\n';

return 0;

}

template (1)

template void atomic_init (volatile atomic* obj, T val) noexcept;

template void atomic_init (atomic* obj, T val) noexcept;

overloads (2)

void atomic_init (volatile A* obj, T val) noexcept;

void atomic_init (A* obj, T val) noexcept;

用val的一個包含值初始化obj,該函數不是原子性的:來自另一個線程的并發訪問,即使是通過原子操作,也是一種數據競爭。

如果obj不是默認構造,那么這個行為就沒有定義。

如果這個函數在同一個obj上被調用兩次,那么這個行為是沒有定義的。

template (1)

template void atomic_store (volatile atomic* obj, T val) noexcept;

template void atomic_store (atomic* obj, T val) noexcept;

template

void atomic_store_explicit (volatile atomic* obj, T val, memory_order sync) noexcept;

template

void atomic_store_explicit (atomic* obj, T val, memory_order sync) noexcept;

overloads (2)

void atomic_store (volatile A* obj, T val) noexcept;

void atomic_store (A* obj, T val) noexcept;

void atomic_store_explicit (volatile A* obj, T val, memory_order sync) noexcept;

void atomic_store_explicit (A* obj, T val, memory_order sync) noexcept;

用val替換obj中包含的值。該操作是原子性的,atomic_store 使用順序一致性(memory_order_seq_cst), atomic_store_explicit 顯示制定內存順序。參見stomic的等價函數atomic::store和 atomic::operator=。

template (1)

template T atomic_load (const volatile atomic* obj) noexcept;

template T atomic_load (const atomic* obj) noexcept;

template

T atomic_load_explicit (const volatile atomic* obj, memory_order sync) noexcept;

template

T atomic_load_explicit (const atomic* obj, memory_order sync) noexcept;

overloads (2)

T atomic_load (const volatile A* obj) noexcept;

T atomic_load (const A* obj) noexcept;

T atomic_load_explicit (const volatile A* obj, memory_order sync) noexcept;

T atomic_load_explicit (const A* obj, memory_order sync) noexcept;

同上面函數,返回obj中包含的值。該操作是原子性的,并使用順序一致性(memory_order_seq_cst)。要制定內存數序使用顯示調用函數atomic_load_explicit。

template (1)

template T atomic_exchange (volatile atomic* obj, T val) noexcept;

template T atomic_exchange (atomic* obj, T val) noexcept;

template

T atomic_exchange_explicit(volatile atomic* obj, T val, memory_order sync) noexcept;

template

T atomic_exchange_explicit(atomic* obj, T val, memory_order sync) noexcept;

overloads (2)

T atomic_exchange (volatile A* obj, T val) noexcept;

T atomic_exchange (A* obj, T val) noexcept;

T atomic_exchange_explicit(volatile A* obj, T val, memory_order sync) noexcept;

T atomic_exchange_explicit(A* obj, T val, memory_order sync) noexcept;

用val替換obj中包含的值,并返回obj之前的值。

整個操作是原子性的(一個原子的讀-修改-寫操作):在讀取(返回)值和被該函數修改的瞬間之間,obj的值不會受到其他線程的影響。要制定內存數序使用顯示調用函數atomic_exchange_explicit。

注意: 這個顯示代碼網站上有錯誤,本文已經改正。

template (1)

template

bool atomic_compare_exchange_weak (volatile atomic* obj, T* expected, T val) noexcept;

template

bool atomic_compare_exchange_weak (atomic* obj, T* expected, T val) noexcept;

template

bool atomic_compare_exchange_weak_explicit (volatile atomic* obj,

T* expected, T val, memory_order success, memory_order failure) noexcept;

template

bool atomic_compare_exchange_weak_explicit (atomic* obj,

T* expected, T val, memory_order success, memory_order failure) noexcept;

overloads (2)

bool atomic_compare_exchange_weak (volatile A* obj, T* expected, T val) noexcept;

bool atomic_compare_exchange_weak (A* obj, T* expected, T val) noexcept;

bool atomic_compare_exchange_weak_explicit (volatile A* obj,

T* expected, T val, memory_order success, memory_order failure) noexcept;

bool atomic_compare_exchange_weak_explicit (A* obj,

T* expected, T val, memory_order success, memory_order failure) noexcept;

將obj中包含的值與預期的內容進行比較:

-如果是真的,它會用val替換包含的值。

-如果是假的,它將用所包含的值替換預期值

函數總是訪問包含的值來讀取它,如果這個比較是真的,那么它也會替換它。但是整個操作都是原子性的:在讀取值和被替換的時刻之間,它的值不能被其他線程修改。

** 注意:

這個函數直接的比較物理內容所包含的價值與預期的內容,這可能導致得到使用operator==比較的結果是一個失敗的結果,因為對象底層的物理內容中可能存在位對齊或其他邏輯表示相同但是物理表示不同的值(比如 true 和 2 或 3,它們在邏輯上都表示"真",但在物理上兩者的表示并不相同)。

不像 compare_exchange_strong,這個弱版本允許(spuriously 地)返回 false(即原子對象所封裝的值與參數 expected 的物理內容相同,但卻仍然返回 false),即使在預期的實際情況與所包含的對象相比較時也是如此。對于某些循環算法來說,這可能是可接受的行為,并且可能會在某些平臺上帶來顯著的性能提升。在這些虛假的失敗中,函數返回false,而不修改預期。

對于非循環算法來說, compare_exchange_strong通常是首選。

template (1)

template

bool atomic_compare_exchange_strong (volatile atomic* obj, T* expected, T val) noexcept;

template

bool atomic_compare_exchange_strong (atomic* obj, T* expected, T val) noexcept;

template

bool atomic_compare_exchange_strong_explicit (volatile atomic* obj,

T* expected, T val, memory_order success, memory_order failure) noexcept;

template

bool atomic_compare_exchange_strong_explicit (atomic* obj,

T* expected, T val, memory_order success, memory_order failure) noexcept;

overloads (2)

bool atomic_compare_exchange_strong (volatile A* obj, T* expected, T val) noexcept;

bool atomic_compare_exchange_strong (A* obj, T* expected, T val) noexcept;

bool atomic_compare_exchange_strong_explicit (volatile A* obj,

T* expected, T val, memory_order success, memory_order failure) noexcept;

bool atomic_compare_exchange_strong_explicit (A* obj,

T* expected, T val, memory_order success, memory_order failure) noexcept;

將obj中包含的值與預期的值進行比較:

-如果是真的,它會用val替換包含的值。

-如果是假的,它將用所包含的值替換預期值。

函數總是訪問包含的值來讀取它,如果這個比較是真的,那么它也會替換它。但是整個操作都是原子性的:在讀取值和被替換的時刻之間,它的值不能被其他線程修改。

** 注意:

compare_exchange_strong 跟 compare_exchange_week 不同的是:

與compare_exchange_weak 不同, strong版本的 compare-and-exchange 操作不允許(spuriously 地)返回 false,即原子對象所封裝的值與參數 expected 的物理內容相同,比較操作一定會為 true。不過在某些平臺下,如果算法本身需要循環操作來做檢查, compare_exchange_weak 的性能會更好。

template (integral) (1)

template T atomic_fetch_add (volatile atomic* obj, T val) noexcept;

template T atomic_fetch_add (atomic* obj, T val) noexcept;

template

T atomic_fetch_add_explicit (volatile atomic* obj, T val, memory_order sync) noexcept;

template

T atomic_fetch_add_explicit (atomic* obj, T val, memory_order sync) noexcept;

template (pointer) (2)

template U* atomic_fetch_add (volatile atomic* obj, ptrdiff_t val) noexcept;

template U* atomic_fetch_add (atomic* obj, ptrdiff_t val) noexcept;

template

U* atomic_fetch_add_explicit (volatile atomic* obj, ptrdiff_t val, memory_order sync) noexcept;

template

U* atomic_fetch_add_explicit (atomic* obj, ptrdiff_t val, memory_order sync) noexcept;

overloads (3)

T atomic_fetch_add (volatile A* obj, M val) noexcept;

T atomic_fetch_add (A* obj, M val) noexcept;

T atomic_fetch_add_explicit (volatile A* obj, M val, memory_order sync) noexcept;

T atomic_fetch_add_explicit (A* obj, M val, memory_order sync) noexcept;

將val添加到obj中所包含的值。整個操作都是原子性的:在讀取(返回)值和被該函數修改的時刻之間,值不能被修改。要制定內存數序使用顯示調用函數atomic_fetch_add_explicit 。

template (integral) (1)

template T atomic_fetch_sub (volatile atomic* obj, T val) noexcept;

template T atomic_fetch_sub (atomic* obj, T val) noexcept;

template

T atomic_fetch_sub_explicit (volatile atomic* obj, T val, memory_order sync) noexcept;

template

T atomic_fetch_sub_explicit (atomic* obj, T val, memory_order sync) noexcept;

template (pointer) (2)

template U* atomic_fetch_sub (volatile atomic* obj, ptrdiff_t val) noexcept;

template U* atomic_fetch_sub (atomic* obj, ptrdiff_t val) noexcept;

template

U* atomic_fetch_sub_explicit (volatile atomic* obj, ptrdiff_t val, memory_order sync) noexcept;

template

U* atomic_fetch_sub_explicit (atomic* obj, ptrdiff_t val, memory_order sync) noexcept;

overloads (3)

T atomic_fetch_sub (volatile A* obj, M val) noexcept;

T atomic_fetch_sub (A* obj, M val) noexcept;

T atomic_fetch_sub_explicit (volatile A* obj, M val, memory_order sync) noexcept;

T atomic_fetch_sub_explicit (A* obj, M val, memory_order sync) noexcept;

從obj中所包含的值減去val。整個操作都是原子性的:在讀取(返回)值和被該函數修改的時刻之間,值不能被修改。要制定內存數序使用顯示調用函數atomic_fetch_sub_explicit 。

template (integral) (1)

template T atomic_fetch_and (volatile atomic* obj, T val) noexcept;

template T atomic_fetch_and (atomic* obj, T val) noexcept;

template

T atomic_fetch_and_explicit (volatile atomic* obj,T val, memory_order sync) noexcept;

template

T atomic_fetch_and_explicit (atomic* obj,T val, memory_order sync) noexcept;

overloads (2)

T atomic_fetch_and (volatile A* obj, T val) noexcept;

T atomic_fetch_and (A* obj, T val) noexcept;

T atomic_fetch_and_explicit (volatile A* obj, T val, memory_order sync) noexcept;

T atomic_fetch_and_explicit (A* obj, T val, memory_order sync) noexcept;

讀取obj中包含的值,并通過在讀取值和val之間執行一個位操作“與”操作來替換它。

整個操作是原子性的(一個原子的讀-修改-寫操作):在讀取(返回)值和被該函數修改的那一刻之間,值不會受到其他線程的影響。要制定內存數序使用顯示調用函數atomic_fetch_and_explicit 。

template (integral) (1)

template T atomic_fetch_or (volatile atomic* obj, T val) noexcept;

template T atomic_fetch_or (atomic* obj, T val) noexcept;

template

T atomic_fetch_or_explicit (volatile atomic* obj, T val, memory_order sync) noexcept;

template

T atomic_fetch_or_explicit (atomic* obj,T val, memory_order sync) noexcept;

overloads (2)

T atomic_fetch_or (volatile A* obj, T val) noexcept;

T atomic_fetch_or (A* obj, T val) noexcept;

T atomic_fetch_or_explicit (volatile A* obj, T val, memory_order sync) noexcept;

T atomic_fetch_or_explicit (A* obj, T val, memory_order sync) noexcept;

讀取obj中包含的值,并通過在讀取值和val之間執行一個位操作“或”操作來替換它。

整個操作是原子性的(一個原子的讀-修改-寫操作):在讀取(返回)值和被該函數修改的那一刻之間,值不會受到其他線程的影響。要制定內存數序使用顯示調用函數atomic_fetch_or_explicit

template (integral) (1)

template T atomic_fetch_xor (volatile atomic* obj, T val) noexcept;

template T atomic_fetch_xor (atomic* obj, T val) noexcept;

template

T atomic_fetch_xor_explicit (volatile atomic* obj,T val, memory_order sync) noexcept;

template

T atomic_fetch_xor_explicit (atomic* obj,T val, memory_order sync) noexcept;

overloads (2)

T atomic_fetch_xor (volatile A* obj, T val) noexcept;

T atomic_fetch_xor (A* obj, T val) noexcept;

T atomic_fetch_xor_explicit (volatile A* obj, T val, memory_order sync) noexcept;

T atomic_fetch_xor_explicit (A* obj, T val, memory_order sync) noexcept;

讀取obj中包含的值,并通過在讀取值和val之間執行一個位操作“異或”操作來替換它。

整個操作是原子性的(一個原子的讀-修改-寫操作):在讀取(返回)值和被該函數修改的那一刻之間,值不會受到其他線程的影響。要制定內存數序使用顯示調用函數atomic_fetch_xor_explicit

bool atomic_flag_test_and_set (volatile atomic_flag* obj) noexcept;

bool atomic_flag_test_and_set (atomic_flag* obj) noexcept;

bool atomic_flag_test_and_set (volatile atomic_flag* obj, memory_order sync) noexcept;

bool atomic_flag_test_and_set (atomic_flag* obj, memory_order sync) noexcept;

設置obj指向的原子標志,并返回調用之前的值。

整個操作是原子性的(一個原子的讀-修改-寫操作):在讀取(返回)值和被該函數修改的瞬間之間,obj的值不會受到其他線程的影響。要制定內存數序使用顯示調用函數atomic_flag_test_and_set

void atomic_flag_clear (volatile atomic_flag* obj) noexcept;

void atomic_flag_clear (atomic_flag* obj) noexcept;

void atomic_flag_clear_explicit(volatile atomic_flag* obj, memory_order sync) noexcept;

void atomic_flag_clear_explicit(atomic_flag* obj, memory_order sync) noexcept;

清除obj,將它的標志值設置為false。該操作是原子性的。要制定內存數序使用顯示調用函數atomic_flag_clear_explicit。

六、Macro functions

ATOMIC_VAR_INIT

ATOMIC_VAR_INIT(val) //初始化 std::atomic 對象。

這個宏的存在是為了與C實現兼容,在其中,它被用作構造函數(默認構造的)原子對象;在C++中,這個初始化可以由初始化構造函數直接執行。

ATOMIC_FLAG_INIT

ATOMIC_FLAG_INIT //初始化 std::atomic_flag 對象。

這個宏的定義用來將類型std::atomic_flag的對象初始化到clear的狀態。

總結

以上是生活随笔為你收集整理的atomic头文件编译_c++11 多线程(3)atomic 总结的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

免费试看一区 | 婷婷国产在线观看 | 久久久久久久18 | 久久91久久久久麻豆精品 | 日韩精品不卡在线 | 国产亚洲va综合人人澡精品 | 天天爱天天色 | 亚洲最大成人免费网站 | 一区二区三区手机在线观看 | 久久少妇免费视频 | 最近字幕在线观看第一季 | 精品一区二区三区香蕉蜜桃 | 色成人亚洲| 狠狠操欧美| 天天婷婷 | 97在线观看免费 | 久久刺激视频 | www.99av| 国产精品黄色在线观看 | 日韩视频免费看 | 欧美色图另类 | 国产一区二区三区在线免费观看 | 中文字幕高清在线 | 一级黄色在线免费观看 | 美女久久久久久久久久久 | 亚洲午夜久久久久久久久久久 | 日韩网站在线看片你懂的 | 亚洲妇女av | 天天操夜夜干 | jizzjizzjizz亚洲| 一区二区不卡高清 | 色.www| 国产三级国产精品国产专区50 | 亚洲黑丝少妇 | 久久久久成人精品亚洲国产 | 五月天久久婷 | 黄色毛片视频 | 国产成人黄色在线 | 国产成人精品不卡 | 日韩在线观看三区 | 国产在线精品一区二区 | 97色视频在线 | 日韩中文字幕免费在线播放 | 五月色丁香 | 久久久久久久久久久久影院 | 国产伦理精品一区二区 | 日韩精品一区二区三区在线视频 | 麻豆视频国产在线观看 | 久久久精品久久日韩一区综合 | 午夜久久久精品 | 黄色网址国产 | 国产精品视频地址 | 国产成人免费在线 | 日韩高清免费观看 | 国内精品久久久久久久影视简单 | 日本精品久久久久影院 | 欧美一级高清片 | 99国产一区| 精品久久久久_ | 色婷婷丁香 | 国产91粉嫩白浆在线观看 | 成人黄色免费在线观看 | 天天干天天做天天操 | 亚洲国产69| 国产精品成人一区二区三区吃奶 | 99性视频| 日本高清中文字幕有码在线 | 欧美韩国日本在线 | 久久呀 | 91精品国产91久久久久 | 18女毛片 | www.久久免费视频 | 国产精品av久久久久久无 | 草久在线播放 | 91中文字幕网| 亚洲精品美女久久久 | 国产日韩在线观看一区 | 欧美国产日韩中文 | 天天骚夜夜操 | 免费看一级特黄a大片 | 亚洲成年人在线播放 | 五月网婷婷 | 午夜精品久久久久久久99婷婷 | 成年人免费观看在线视频 | 色婷婷综合在线 | 国产精品手机看片 | 欧美 日韩 性 | 国产高清免费视频 | av激情五月 | 久久精品日本啪啪涩涩 | 亚洲成a人片在线观看中文 中文字幕在线视频第一页 狠狠色丁香婷婷综合 | 国产做aⅴ在线视频播放 | av在线进入 | 国产精品久久久久久婷婷天堂 | 又色又爽又黄高潮的免费视频 | 亚洲午夜精品一区 | 久久人视频 | 国产午夜小视频 | 国产一区二区在线免费播放 | 国产中文伊人 | 91视频在线| av福利网址导航 | 中文在线a天堂 | 色噜噜日韩精品欧美一区二区 | 狠狠色丁香久久婷婷综合_中 | 国产成人精品一区二区三区福利 | 在线不卡a| 国产品久精国精产拍 | 国产专区视频在线观看 | 久久不色| 久久久69 | 国产 欧美 日产久久 | 中文字幕 国产专区 | av一级网站 | 天堂在线成人 | 一区二区三区在线观看 | 一区二区精品 | 成人av一区二区在线观看 | 国产专区在线播放 | 成人在线小视频 | 天天色天天色天天色 | 国产精品欧美一区二区 | 日韩网站在线免费观看 | 国产91精品看黄网站在线观看动漫 | 久色免费视频 | 中日韩欧美精彩视频 | 超碰av在线免费观看 | www.超碰| 中文字幕中文字幕在线中文字幕三区 | 色片网站在线观看 | 在线国产视频 | 日韩欧美一区二区三区在线观看 | 亚洲精品视频免费在线观看 | 最近中文字幕免费视频 | 天天色天天爱天天射综合 | 日韩欧美高清在线 | 国产视频1区2区3区 久久夜视频 | 午夜国产影院 | 99久久婷婷国产精品综合 | 在线国产激情视频 | 成人午夜精品久久久久久久3d | 在线观看免费 | 国产精品s色 | 亚洲一片黄 | 婷婷深爱网| 国产精品欧美日韩在线观看 | 黄网站大全| 黄色一级免费电影 | 97色婷婷 | 九九热1 | 美女免费av| 成年人电影免费看 | 99精品视频免费全部在线 | 涩涩资源网 | 欧美日韩久久一区 | 国产系列在线观看 | 亚洲蜜桃在线 | 欧美孕妇视频 | 麻豆传媒视频在线播放 | 国产高清精品在线 | 超碰在线观看97 | 日本中文字幕影院 | av黄色在线观看 | 福利电影久久 | 色综合久久综合网 | 久久天天躁夜夜躁狠狠85麻豆 | 国产亚洲无 | 天天操综合网站 | 亚洲精品tv久久久久久久久久 | 九九在线视频免费观看 | 超碰在线1 | 亚洲闷骚少妇在线观看网站 | 人人网人人爽 | 人人爱夜夜操 | 国产免费又粗又猛又爽 | 日日干夜夜草 | 欧女人精69xxxxxx| 99热亚洲精品 | 欧美日韩视频在线观看免费 | 国产精品九九视频 | 天天色播 | www.99久久.com | 9797在线看片亚洲精品 | 在线精品在线 | 最近中文字幕完整高清 | 国产精品k频道 | 久久999精品 | 夜夜骑首页| av天天澡天天爽天天av | 在线亚洲日本 | 九九有精品 | 国产一二三在线视频 | 久久免费国产精品1 | 亚洲国内精品在线 | 日韩中文字幕在线 | 五月天狠狠操 | 91亚洲狠狠婷婷综合久久久 | 久久爱影视i | 亚洲国产无| 91麻豆精品国产91久久久无限制版 | 色成人亚洲 | 午夜精品福利影院 | 亚洲精品激情 | 天天干,天天操,天天射 | 黄网站app在线观看免费视频 | 欧美成天堂网地址 | 婷婷网五月天 | 天天色天天色天天色 | 精品国产色 | 国产无遮挡又黄又爽在线观看 | 欧美日本在线观看视频 | 精品在线亚洲视频 | 国产999久久久 | 一区二区三区日韩在线观看 | 免费av在线网 | 欧美爽爽爽 | 91传媒免费在线观看 | 久久精品视频在线 | 狠狠色丁婷婷日日 | 精品国产一二三四区 | 免费看的黄色网 | 伊人www22综合色 | 国产欧美精品一区二区三区四区 | 好看的国产精品视频 | 人人干天天干 | www.com黄色| 手机在线永久免费观看av片 | www.色午夜,com | 天堂va在线观看 | 99九九视频 | 日韩欧美精品在线 | 综合婷婷| 亚洲精品动漫成人3d无尽在线 | 91视频国产免费 | 日日干夜夜骑 | 国产高清在线精品 | 国产视频精品久久 | 免费在线观看黄网站 | 中文字幕中文字幕 | 黄色av电影一级片 | 久久论理| 成人av高清 | 日韩在线字幕 | 亚洲国产精品成人av | 亚洲国产wwwccc36天堂 | 色.com| 久久人人爽视频 | 国产在线精品观看 | 国外av在线 | 99电影456麻豆 | 久久这里有 | 天天躁天天躁天天躁婷 | 国产夫妻av在线 | 亚洲女在线 | 欧美日韩国产一区 | 国产91精品看黄网站在线观看动漫 | 最新国产精品拍自在线播放 | 激情欧美在线观看 | 国产啊v在线观看 | 1024手机看片国产 | av福利在线免费观看 | 国产福利精品一区二区 | 911精品视频| 激情婷婷在线 | 久久99精品一区二区三区三区 | 精品一区二区三区在线播放 | 欧美成年人在线观看 | av千婊在线免费观看 | 97电影在线看视频 | 青草草在线| 亚洲另类人人澡 | 插插插色综合 | 亚洲国产精品电影在线观看 | 中文字幕乱码亚洲精品一区 | 成人va视频 | 日韩av午夜在线观看 | 国产一区二区三区在线免费观看 | 国产黄大片在线观看 | 国产黄色a| 成人网看片| 中文字幕丝袜 | 97视频免费在线 | 精品毛片一区二区免费看 | 国产一二三四在线视频 | 国产欧美综合视频 | 欧美精品乱码久久久久久按摩 | 久久久亚洲国产精品麻豆综合天堂 | 日韩一区二区三免费高清在线观看 | 色综合狠狠干 | 91av免费看| 狠狠躁日日躁夜夜躁av | 一区二区三区免费看 | 国产精品mm | av高清免费在线 | 美女免费黄视频网站 | 色香蕉网 | 久久av免费观看 | 四虎在线观看精品视频 | 成人久久久精品国产乱码一区二区 | 精品麻豆入口免费 | 在线三级中文 | av一区在线 | 国产在线欧美日韩 | 天天干夜夜爱 | 国内精品久久久久久久久久久 | 欧美做受高潮1 | 色播六月天 | 最新国产中文字幕 | 96久久| 高清视频一区 | 69av久久| 99视频在线免费播放 | 在线观看视频一区二区三区 | 精品亚洲视频在线 | 国产黄色片在线免费观看 | 国产成人福利在线 | 精品免费视频123区 午夜久久成人 | 久久久噜噜噜久久久 | 粉嫩一区二区三区粉嫩91 | 亚洲精品黄色 | 国产激情免费 | av久久在线| 婷婷综合av | 久久不射影院 | 夜夜操天天操 | 亚洲国产欧美在线人成大黄瓜 | 狠狠干干| 最近中文字幕免费观看 | 免费黄色av电影 | 免费99视频 | 久章操 | 精品国产乱码一区二区三区在线 | 特级毛片在线 | 国产不卡在线播放 | 国产色小视频 | 国产精品亚洲精品 | 超碰在线97国产 | 精品久久久久久久久久久久久久久久 | 久久精品成人欧美大片古装 | 国产小视频网站 | 射久久 | 91久久久久久久一区二区 | 伊人亚洲综合网 | 四虎在线免费观看视频 | 国产视频二区三区 | 中文字幕av一区二区三区四区 | 免费日韩av片 | 天天射天天干 | 欧美激情综合五月色丁香小说 | 国产夫妻av在线 | 国产午夜精品一区二区三区 | 四虎成人精品永久免费av | 日本九九视频 | 久草视频在线看 | 免费a级黄色毛片 | 成人在线播放av | 久久黄视频| 亚洲男男gⅴgay双龙 | 国产精品免费成人 | 欧美成a人片在线观看久 | 国产精品第一页在线 | 99色免费| 欧美性黄网官网 | 天天操夜夜操国产精品 | 天天玩天天干 | 欧美激情另类 | 国产精品成久久久久 | www日韩欧美 | 国产精品对白一区二区三区 | av一区二区三区在线 | 色资源二区在线视频 | 成人av视屏 | 日本 在线 视频 中文 有码 | 中文字幕一区在线 | 国产精品一区二区美女视频免费看 | 久草在线中文视频 | 在线观看日本高清mv视频 | 一区 二区电影免费在线观看 | 丁香六月婷婷开心 | 在线之家官网 | 久久精品看片 | 中文字幕在线观看免费 | 韩国精品一区二区三区六区色诱 | 日韩在线视频精品 | 久久精品久久精品久久39 | 999国内精品永久免费视频 | 免费观看www7722午夜电影 | 嫩嫩影院理论片 | 久草在线免费看视频 | 国产精品区一区 | 久久视频精品在线 | 高清av影院 | 国产精品久久久久久久久久ktv | 91在线视频免费 | 婷婷六月丁 | 日韩专区av | 综合色久| 日本三级人妇 | 97国产情侣爱久久免费观看 | 最近中文字幕免费大全 | 欧美日韩在线网站 | 午夜精品久久久久久久久久久久 | 国产黄色在线网站 | 日韩欧美综合在线视频 | 最近中文字幕在线播放 | 右手影院亚洲欧美 | 国产精品免费久久久久 | 日韩一区二区三区高清在线观看 | 黄色精品视频 | 黄色小说视频在线 | 9在线观看免费高清完整 | 日韩av二区| 日韩二区三区在线 | 久草免费在线视频观看 | 91精品福利在线 | 天天干天天拍天天操 | 美女久久久久久 | 丝袜少妇在线 | 国产在线一区观看 | 中文字幕久久久精品 | 五月天天色 | 日韩手机在线观看 | 国产精品私人影院 | 黄色中文字幕 | 婷婷在线五月 | 天天色综合久久 | 激情五月婷婷 | 最近中文字幕高清字幕在线视频 | av一级黄| 国产精品一区在线播放 | www.夜夜草 | 91视频观看免费 | 精品一区二区在线免费观看 | 美女视频黄是免费的 | 国内精品久久久久久久久久久久 | 婷婷色资源 | 色婷婷在线播放 | 国产无限资源在线观看 | 成人三级黄色 | 亚洲精品永久免费视频 | 久久久久久久久久久久久国产精品 | 国产成人一区二区在线观看 | 国产成人一区三区 | 久久伊人精品一区二区三区 | 亚洲精品免费看 | 91视频麻豆 | 在线观看一 | 永久免费毛片在线观看 | 日本高清中文字幕有码在线 | 天天干天天操天天爱 | 欧美午夜精品久久久久久孕妇 | 久久男人免费视频 | 99免费在线 | 日韩欧美高清一区二区三区 | av在线h| 色在线免费观看 | 美女久久久久 | 日韩精品一区二区三区免费视频观看 | 韩国一区二区av | 久久精品视频3 | av网址aaa| 国产成人一区二区三区影院在线 | 精品国产免费看 | 1024在线看片 | 97超碰中文字幕 | 婷婷激情网站 | 在线观看岛国片 | 91人网站 | 国产精品一区二区无线 | 中文字幕在线影视资源 | 国产精品成人一区二区 | 久久精品视频免费播放 | 国产精品 国内视频 | 三级av黄色 | 中文字幕在线专区 | 91在线中文字幕 | 国产九九九视频 | 免费高清在线观看电视网站 | 欧美在线aaa | 久久97久久97精品免视看 | 天天色天天射天天综合网 | 欧美电影在线观看 | 视频国产 | 国产91在线 | 美洲 | 在线成人国产 | 黄色av影视 | 69久久99精品久久久久婷婷 | 欧美激情第一区 | 中文字幕日韩国产 | 久久国产精品99久久人人澡 | 国产免费久久精品 | 亚洲精品理论片 | 永久中文字幕 | 午夜精品电影一区二区在线 | 久久综合中文色婷婷 | 国产精品黄色av | 丰满少妇在线观看网站 | 久久久国产一区二区 | 国精产品999国精产品视频 | 99精品欧美一区二区三区黑人哦 | 不卡av在线免费观看 | 精品国产福利在线 | 亚洲第一香蕉视频 | 日韩一区二区三免费高清在线观看 | japanesexxxhd奶水| 91香蕉视频720p | 亚洲涩涩涩 | 久久久久久久久久久久亚洲 | 狠狠地操| 婷婷伊人综合亚洲综合网 | 日本aaaa级毛片在线看 | 日韩av电影中文字幕 | 成人av资源网| 97操操 | 伊人狠狠干 | 成人影视免费看 | 国产精品毛片一区二区 | 夜夜干夜夜 | 亚洲最新视频在线 | 在线免费观看视频一区 | 久久黄色网 | 国产a级片免费观看 | 精品欧美一区二区在线观看 | 国产精品视频免费在线观看 | 国精产品满18岁在线 | 国产不卡一二三区 | 亚洲精品美女久久久久 | 国产精品久久久久久一区二区三区 | zzijzzij亚洲日本少妇熟睡 | 91精品视频免费看 | 免费91麻豆精品国产自产在线观看 | 亚洲一二三久久 | 日韩三级视频在线看 | 2020天天干天天操 | 日韩av网页 | 免费a v在线 | 久草国产在线 | 国产精品成人一区二区三区 | 久久在线视频精品 | 91热在线| 久久久精品影视 | 日本在线观看黄色 | 97超碰伊人 | 日本精品一区二区三区在线播放视频 | 亚洲经典视频 | 日日操夜 | 久久亚洲精品电影 | 久久国产一区二区 | 国产v在线播放 | 色综合久久久久综合体 | 黄色特一级 | 亚洲欧美日韩一二三区 | 毛片a级片| 免费观看成年人视频 | 久久久久亚洲国产精品 | 美女黄视频免费 | 国产一区二区网址 | 天天操天天干天天干 | 在线影院 国内精品 | 久久久久久久久久久久国产精品 | 久草视频免费看 | 在线观看91网站 | 国产精品女同一区二区三区久久夜 | 午夜精品视频一区 | 99精品视频99| 一区二区三区日韩视频在线观看 | 日韩高清不卡一区二区三区 | 国产黄a三级三级三级三级三级 | 丁香六月激情婷婷 | 久久久久久久久久久电影 | av电影在线免费 | 国产一级在线 | 伊人五月天av | 亚洲色图 校园春色 | 亚洲精品乱码久久久久久蜜桃欧美 | 久久99精品国产麻豆宅宅 | 亚洲 欧洲 国产 日本 综合 | 色中色综合 | 亚洲视频在线观看 | 狠狠地操 | 久草在线资源免费 | 99爱爱| 有码一区二区三区 | 国产黄色特级片 | av在线直接看 | 四虎在线观看 | 中文字幕一区二区三区乱码在线 | 国产99在线免费 | 成人av一级片 | 天天射天天 | 黄色三级网站在线观看 | 国产综合小视频 | 久久久久国产一区二区三区 | 狠狠狠狠狠色综合 | 久久国产免费 | 99热国产在线观看 | 色资源中文字幕 | 一区二区视频在线看 | 国产黄色免费观看 | 日本中出在线观看 | 国产91在线 | 美洲 | 久久久久福利视频 | 亚洲高清精品在线 | www.久久久.com| 成人91av| 婷婷丁香在线观看 | 国产精品免费久久久 | 波多野结衣一区二区 | 国产精品18久久久久久首页狼 | 日日躁夜夜躁aaaaxxxx | 韩国av电影在线观看 | 精品久久久久久久久久久院品网 | 成 人 黄 色 视频 免费观看 | 精品久久五月天 | 精品国产电影 | 精品在线播放视频 | 美女网站黄在线观看 | 国产成人在线网站 | 91在线精品视频 | 国产在线观看av | 欧美二区在线播放 | 欧美综合国产 | 久久看毛片 | 91伊人久久大香线蕉蜜芽人口 | 国产在线日韩 | 国内精品国产三级国产aⅴ久 | 天天曰天天爽 | 久久66热这里只有精品 | www.狠狠| 日韩久久精品一区二区三区 | 久久永久视频 | 国产亚洲久一区二区 | 粉嫩aⅴ一区二区三区 | 欧美性一级观看 | 超碰人人乐 | 91片在线观看 | 国产小视频你懂的 | 久久精品久久久精品美女 | 五月天亚洲综合 | 天天射综合 | 2020天天干天天操 | 91精品欧美 | 日本久久成人中文字幕电影 | 99久久精品电影 | 亚洲午夜精品久久久久久久久 | 国产在线精品一区二区不卡了 | 亚洲视频1区2区 | 69绿帽绿奴3pvideos | 国产在线中文字幕 | 亚洲精品影院在线观看 | 成人av一区二区兰花在线播放 | 麻豆精品在线 | 国产免费xvideos视频入口 | 国产在线p | 黄a网站| 成年人免费看片 | 蜜臀久久99精品久久久无需会员 | 一本一道久久a久久综合蜜桃 | 国产一区黄色 | 日本乱码在线 | 免费黄色av电影 | 91在线免费观看网站 | 免费福利视频网站 | 久艹视频在线免费观看 | 在线免费视频一区 | 2022久久国产露脸精品国产 | 日韩午夜视频在线观看 | 国产欧美在线一区二区三区 | 精品美女久久久久久免费 | 欧美淫视频 | 天无日天天操天天干 | av一区在线 | 手机av在线网站 | 日日色综合 | 狠狠操狠狠操 | www.色午夜.com| 久久爱影视i | 在线观看成人 | 91精品办公室少妇高潮对白 | www天天操| 欧美少妇bbwhd | 亚洲作爱视频 | 99精品视频在线播放观看 | 美女视频黄免费网站 | 97成人在线 | 亚洲精品玖玖玖av在线看 | 五月天亚洲激情 | 精品九九九 | 国产精品成人在线观看 | 欧美色图另类 | 国内精品二区 | 精品久久久久免费极品大片 | 色综合网在线 | 成人片在线播放 | 91在线视频一区 | 久久精品一区二区三区中文字幕 | 亚洲欧洲日韩在线观看 | 激情深爱| 国产一级精品在线观看 | 日韩精品欧美专区 | 丁香电影小说免费视频观看 | 亚洲综合视频在线播放 | 国产黄色精品网站 | 欧美日本啪啪无遮挡网站 | 午夜精品久久久99热福利 | 亚洲另类视频在线 | 91成人网在线观看 | 福利视频一区二区 | 国产午夜精品视频 | 久久久精品二区 | 国产精品久久久久永久免费 | 成人免费网站在线观看 | 国产亚洲精品成人av久久影院 | 日韩av中文在线 | 99热国产在线中文 | 亚洲国产精品小视频 | 久久久久久久久久久久av | 天天操偷偷干 | 国产精品99久久久精品免费观看 | 亚洲最大成人免费网站 | 欧美激情视频一区二区三区免费 | 麻豆免费视频 | 黄色亚洲大片免费在线观看 | 色网站在线免费 | 欧美福利久久 | 91精品国产欧美一区二区成人 | 9999激情| 久久精品视频免费观看 | 国产91精品一区二区绿帽 | 在线免费观看的av | 人人玩人人添人人澡超碰 | 五月综合在线观看 | av中文字幕网址 | 狠狠夜夜 | 日本午夜免费福利视频 | 永久精品视频 | 九九在线高清精品视频 | 午夜婷婷在线播放 | 国产精品久久久久久妇 | 国产精在线 | 久久福利小视频 | av三级在线免费观看 | 久久久久久麻豆 | 日韩精品一卡 | 麻豆视频国产 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 天天色综合1 | 久久久久免费精品视频 | 成年人在线免费看视频 | 激情综合六月 | 日韩精品一区二区三区在线视频 | 国产精久久久 | 亚洲精品资源在线 | 黄色大片视频网站 | 精品国产自在精品国产精野外直播 | a级片久久久 | 人人爽人人搞 | 欧美国产日韩久久 | 亚洲激精日韩激精欧美精品 | 日韩欧美一区二区三区在线观看 | 精品视频在线免费 | 一区二区 不卡 | 久久伦理视频 | 天天色综合天天 | 欧美日韩国产高清视频 | 国产一区二区免费看 | 久草在线视频免赞 | 一本色道久久综合亚洲二区三区 | 黄色精品国产 | 亚洲国产婷婷 | 亚洲日韩中文字幕在线播放 | 狠狠色狠狠色综合日日92 | 国产成人一二三 | 国产精品白浆视频 | 西西www4444大胆在线 | 亚洲人成人在线 | 香蕉视频免费看 | 区一区二区三在线观看 | 亚洲精品动漫久久久久 | 特级西西444www高清大视频 | 一区二区视频欧美 | 亚洲视频电影在线 | 亚洲精品国产精品国自产观看 | 亚洲精品国产拍在线 | 三级动图 | 国产亚洲永久域名 | 很黄很污的视频网站 | 人人爽人人插 | 六月丁香激情综合色啪小说 | 免费v片| 9免费视频 | 亚洲国产免费看 | 精品国产免费一区二区三区五区 | 久久久综合 | 精品视频免费看 | 色妞色视频一区二区三区四区 | 久久五月天婷婷 | 国内精品视频免费 | 国产视频在线看 | 亚州精品成人 | 国产不卡在线 | 久久久久国产一区二区三区四区 | 欧日韩在线| 91在线你懂的 | 国产精品久久在线 | 亚洲深夜影院 | 欧洲精品码一区二区三区免费看 | 色婷婷激情| 日日操天天操夜夜操 | 国产视频 亚洲视频 | 天堂在线免费视频 | av日韩国产 | www好男人 | 日韩大片在线免费观看 | a黄色片| 国产精品成人一区二区三区吃奶 | 波多野结衣一区二区三区中文字幕 | 五月婷婷六月丁香 | 人人搞人人干 | 三级av网 | 在线视频欧美精品 | 亚洲免费av在线播放 | 久久在线 | 天天操天天操天天操 | 18国产精品白浆在线观看免费 | 五月天婷亚洲天综合网鲁鲁鲁 | 国产又粗又猛又黄视频 | 欧美a级片免费看 | 亚洲有 在线 | 亚洲日日日 | 国内精品视频在线播放 | zzijzzij亚洲成熟少妇 | 久久久午夜剧场 | 亚洲国产精品成人va在线观看 | 免费视频xnxx com | 日韩av片无码一区二区不卡电影 | 欧美日韩中文字幕综合视频 | 91污视频在线 | 亚洲精品理论 | 黄色成品视频 | 国内精品免费 | 色多多视频在线观看 | 色夜视频 | 日韩一级黄色av | 亚洲精品乱码久久久久久蜜桃动漫 | 久久久久一区二区三区四区 | 91tv国产成人福利 | 欧洲av不卡| 99色在线观看视频 | 国产精品99久久久久久宅男 | 久久国产亚洲精品 | 麻豆视频免费网站 | 在线视频一区二区 | 男女拍拍免费视频 | 日韩激情在线视频 | 在线91播放 | 欧美日韩高清不卡 | 天天天天天天干 | 亚洲国产精品va在线看黑人动漫 | 精品在线免费视频 | 亚洲精品自拍视频在线观看 | av一区在线播放 | 久久综合九色综合久99 | 91精品国 | 日韩视频在线观看免费 | 精品国产免费人成在线观看 | 高清av免费一区中文字幕 | 91精品国产高清 | 成人亚洲精品国产www | 久久国产精品一区二区 | 婷婷六月激情 | 天天色天天射天天干 | 成人羞羞视频在线观看免费 | 欧美91av| 欧美激情精品久久 | www.日韩免费| 中文字幕av电影下载 | 黄色特一级片 | 狠狠的干狠狠的操 | www天天干 | www.夜夜爱 | 美女视频一区二区 | 国产成人三级三级三级97 | 亚洲精品在线免费观看视频 | 成人av av在线 | 久久精品国产精品亚洲 | 中文字幕国语官网在线视频 | 99re6热在线精品视频 | 色多多视频在线 | 天天射天天射天天 | 91精品视频在线免费观看 | 久久av免费电影 | 五月天亚洲婷婷 | 日日射天天射 | 亚洲丝袜中文 | 在线免费黄色av | 精品久久1 | 久久不卡电影 | av中文字幕av | 国产精品毛片一区视频播不卡 | 欧美色就是色 | 天天射成人| 四虎永久免费 | 天天插天天干天天操 | 狠狠干婷婷 | 国产专区在线视频 | 日韩丝袜 | 国产成人久久精品一区二区三区 | 日韩有色| 日本aa在线 | 欧美成人999 | 欧美一区三区四区 | 人人玩人人添人人澡97 | 久久久久 | 精品一区二区免费视频 | 国产精品第一页在线 | 国产精品美女久久久久久久久久久 | 丝袜美腿在线播放 | 色婷婷天天干 | 成人中文字幕在线观看 | 成人福利在线观看 | 在线精品视频在线观看高清 | 成人av在线直播 | 国产性天天综合网 | 久草在线视频在线观看 | 免费h漫在线观看 | 99久久精品一区二区成人 | 99久久婷婷国产 | 综合国产在线观看 | 日本 在线 视频 中文 有码 | 国产免费一区二区三区最新6 | 国产区第一页 | 亚洲爱爱视频 | 国产热re99久久6国产精品 | 国产美女精彩久久 | 99久久99久国产黄毛片 | 久草在线视频看看 | 九九热精品视频在线观看 | 少妇bbbb搡bbbb搡bbbb | 日韩精品视频免费在线观看 | 欧美视频在线二区 | 日韩免费网站 | 91热爆在线观看 | 欧美日韩国产综合一区二区 | 96精品视频| 一本一道久久a久久综合蜜桃 | 亚洲精品美女久久久 | 黄色91在线 | 九九亚洲视频 | 91福利视频久久久久 | 国产黄色观看 | 亚洲高清久久久 | 日韩av成人在线 | 伊人五月天.com | 欧美午夜寂寞影院 | 狠狠色丁香婷婷综合久久片 | 99视频在线精品 | 一区二区亚洲精品 | 国产高清视频色在线www | 婷婷九月激情 | 91毛片在线观看 | 手机色站| 国产免费作爱视频 | 手机在线欧美 | 看v片| 在线观看中文字幕网站 | 在线视频手机国产 | 高清在线一区二区 | 久久久午夜精品福利内容 | 插插插色综合 | 日韩激情第一页 | 精品国产区在线 | 色搞搞| 日韩av影视 | 国产精品电影一区 | 国产精品人成电影在线观看 | 国产精品字幕 | 精品久久久久久亚洲 | 五月婷婷av| 久久国产视频网 | 涩涩网站在线观看 | 五月婷在线视频 | 国产中文字幕视频在线观看 | 久久免费高清视频 | 国产精品美女在线观看 | 91亚洲精品国产 | 日韩av电影免费在线观看 | 精品久久91| 日韩欧美视频免费在线观看 | 五月天综合网站 | av不卡网站 | 久久久久久高潮国产精品视 | 亚洲自拍自偷 | 91色亚洲| 天天综合久久 | 国产999免费视频 | 久久久www| 草莓视频在线观看免费观看 |