精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

設置Linux進程的睡眠和喚醒

系統 Linux
在Linux中,僅等待CPU時間的進程稱為就緒進程,它們被放置在一個運行隊列中,一個就緒進程的狀 態標志位為TASK_RUNNING。一旦一個運行中的進程時間片用完, Linux 內核的調度器會剝奪這個進程對CPU的控制權,并且從運行隊列中選擇一個合適的進程投入運行。

在Linux中,僅等待CPU時間的進程稱為就緒進程,它們被放置在一個運行隊列中,一個就緒進程的狀 態標志位為TASK_RUNNING。一旦一個運行中的進程時間片用完, Linux 內核的調度器會剝奪這個進程對CPU的控制權,并且從運行隊列中選擇一個合適的進程投入運行。

當然,一個進程也可以主動釋放CPU的控制權。函數 schedule()是一個調度函數,它可以被一個進程主動調用,從而調度其它進程占用CPU。一旦這個主動放棄CPU的進程被重新調度占用 CPU,那么它將從上次停止執行的位置開始執行,也就是說它將從調用schedule()的下一行代碼處開始執行。

有時候,進程需要等待直到某個特定的事件發生,例如設備初始化完成、I/O 操作完成或定時器到時等。在這種情況下,進程則必須從運行隊列移出,加入到一個等待隊列中,這個時候進程就進入了睡眠狀態。

 

Linux 中的進程睡眠狀態分類

一種是可中斷的睡眠狀態,其狀態標志位TASK_INTERRUPTIBLE;

另一種是不可中斷 的睡眠狀態,其狀態標志位為TASK_UNINTERRUPTIBLE。可中斷的睡眠狀態的進程會睡眠直到某個條件變為真,比如說產生一個硬件中斷、釋放 進程正在等待的系統資源或是傳遞一個信號都可以是喚醒進程的條件。不可中斷睡眠狀態與可中斷睡眠狀態類似,但是它有一個例外,那就是把信號傳遞到這種睡眠 狀態的進程不能改變它的狀態,也就是說它不響應信號的喚醒。不可中斷睡眠狀態一般較少用到,但在一些特定情況下這種狀態還是很有用的,比如說:進程必須等 待,不能被中斷,直到某個特定的事件發生。

在現代的Linux操作系統中,進程一般都是用調用schedule()的方法進入睡眠狀態的,下面的代碼演

示了如何讓正在運行的進程進入睡眠狀態。

  1. sleeping_task = current
  2.  
  3. set_current_state(TASK_INTERRUPTIBLE); 
  4.  
  5. schedule(); 
  6.  
  7. func1(); 
  8.  
  9. /* Rest of the code ... */  

在***個語句中,程序存儲了一份進程結構指針sleeping_task,current 是一個宏,它指向正在執行

的進程結構。set_current_state()將該進程的狀態從執行狀態TASK_RUNNING 變成睡眠狀態

TASK_INTERRUPTIBLE。 如果schedule()是被一個狀態為TASK_RUNNING 的進程調度,那么schedule()將調度另外一個進程占用CPU;如果schedule()是被一個狀態為TASK_INTERRUPTIBLE 或TASK_UNINTERRUPTIBLE 的進程調度,那么還有一個附加的步驟將被執行:當前執行的進程在另外一個進程被調度之前會被從運行隊列中移出,這將導致正在運行的那個進程進入睡眠,因為 它已經不在運行隊列中了。

我們可以使用下面的這個函數將剛才那個進入睡眠的進程喚醒。

  1. wake_up_process(sleeping_task); 

在調用了wake_up_process()以后,這個睡眠進程的狀態會被設置為TASK_RUNNING,而且調度器

會把它加入到運行隊列中去。當然,這個進程只有在下次被調度器調度到的時候才能真正地投入運行。

無效喚醒

幾乎在所有的情況下,進程都會在檢查了某些條件之后,發現條件不滿足才進入睡眠??墒怯械臅r候

進程卻會在 判定條件為真后開始睡眠,如果這樣的話進程就會***期地休眠下去,這就是所謂的無效喚醒問題。在操作系統中,當多個進程都企圖對共享數據進行某種處理,而 ***的結果又取決于進程運行的順序時,就會發生競爭條件,這是操作系統中一個典型的問題,無效喚醒恰恰就是由于競爭條件導致的。

設想有兩個進程A 和B,A 進程正在處理一個鏈表,它需要檢查這個鏈表是否為空,如果不空就對鏈

表里面的數據進行一些操作,同時B進程也在往這個鏈表添加節點。當這個鏈表是空的時候,由于無數據可操作,這時A進程就進入睡眠,當B進程向鏈表里面添加了節點之后它就喚醒A 進程,其代碼如下:

A進程:

  1. spin_lock(&list_lock); 
  2.  
  3. if(list_empty(&list_head)) { 
  4.  
  5.   spin_unlock(&list_lock); 
  6.  
  7.   set_current_state(TASK_INTERRUPTIBLE); 
  8.  
  9.   schedule(); 
  10.  
  11.   spin_lock(&list_lock); 
  12.  
  13.  
  14. /* Rest of the code ... */ 
  15.  
  16. spin_unlock(&list_lock);  

B進程:

  1. spin_lock(&list_lock); 
  2.  
  3. list_add_tail(&list_head, new_node); 
  4.  
  5. spin_unlock(&list_lock); 
  6.  
  7. wake_up_process(processa_task);  

這里會出現一個問題,假如當A進程執行到第3行后第4行前的時候,B進程被另外一個處理器調度

投 入運行。在這個時間片內,B進程執行完了它所有的指令,因此它試圖喚醒A進程,而此時的A進程還沒有進入睡眠,所以喚醒操作無效。在這之后,A 進程繼續執行,它會錯誤地認為這個時候鏈表仍然是空的,于是將自己的狀態設置為TASK_INTERRUPTIBLE然后調用schedule()進入睡 眠。由于錯過了B進程喚醒,它將會***期的睡眠下去,這就是無效喚醒問題,因為即使鏈表中有數據需要處理,A 進程也還是睡眠了。

避免無效喚醒

如何避免無效喚醒問題呢?我們發現無效喚醒主要發生在檢查條件之后和進程狀態被設置為睡眠狀

態之前, 本來B進程的wake_up_process()提供了一次將A進程狀態置為TASK_RUNNING 的機會,可惜這個時候A進程的狀態仍然是TASK_RUNNING,所以wake_up_process()將A進程狀態從睡眠狀態轉變為運行狀態的努力 沒有起到預期的作用。要解決這個問題,必須使用一種保障機制使得判斷鏈表為空和設置進程狀態為睡眠狀態成為一個不可分割的步驟才行,也就是必須消除競爭條 件產生的根源,這樣在這之后出現的wake_up_process ()就可以起到喚醒狀態是睡眠狀態的進程的作用了。

找到了原因后,重新設計一下A進程的代碼結構,就可以避免上面例子中的無效喚醒問題了。

A進程:

  1. set_current_state(TASK_INTERRUPTIBLE); 
  2.  
  3. spin_lock(&list_lock); 
  4.  
  5. if(list_empty(&list_head)) { 
  6.  
  7. spin_unlock(&list_lock); 
  8.  
  9. schedule(); 
  10.  
  11. spin_lock(&list_lock); 
  12.  
  13.  
  14. set_current_state(TASK_RUNNING); 
  15.  
  16.  /* Rest of the code ... */ 
  17.  
  18. spin_unlock(&list_lock);  

可以看到,這段代碼在測試條件之前就將當前執行進程狀態轉設置成TASK_INTERRUPTIBLE了,并且在鏈表不為空的情況下又將自己置為TASK_RUNNING狀態。這樣一來如果B進程在A進程進程檢查

了鏈表為空以后調用wake_up_process(),那么A進程的狀態就會自動由原來TASK_INTERRUPTIBLE

變成TASK_RUNNING,此后即使進程又調用了schedule(),由于它現在的狀態是TASK_RUNNING,所以仍然不會被從運行隊列中移出,因而不會錯誤的進入睡眠,當然也就避免了無效喚醒問題。

Linux內核的例子

在Linux操作系統中,內核的穩定性至關重要,為了避免在Linux操作系統內核中出現無效喚醒問題,

Linux內核在需要進程睡眠的時候應該使用類似如下的操作:

  1. /* ‘q’是我們希望睡眠的等待隊列 */ 
  2.  
  3. DECLARE_WAITQUEUE(wait,current); 
  4.  
  5. add_wait_queue(q, &wait); 
  6.  
  7. set_current_state(TASK_INTERRUPTIBLE); 
  8.  
  9. /* 或TASK_INTERRUPTIBLE */ 
  10.  
  11. while(!condition) /* ‘condition’ 是等待的條件*/ 
  12.  
  13. schedule(); 
  14.  
  15. set_current_state(TASK_RUNNING); 
  16.  
  17. remove_wait_queue(q, &wait);  

上面的操作,使得進程通過下面的一系列步驟安全地將自己加入到一個等待隊列中進行睡眠:首先調

用DECLARE_WAITQUEUE ()創建一個等待隊列的項,然后調用add_wait_queue()把自己加入到等待隊列中,并且將進程的狀態設置為 TASK_INTERRUPTIBLE 或者TASK_INTERRUPTIBLE。然后循環檢查條件是否為真:如果是的話就沒有必要睡眠,如果條件不為真,就調用schedule()。當進程 檢查的條件滿足后,進程又將自己設置為TASK_RUNNING 并調用remove_wait_queue()將自己移出等待隊列。

從上面可以看到,Linux的內核代碼維護者也是在進程檢查條件之前就設置進程的狀態為睡眠狀態,

然后才循環檢查條件。如果在進程開始睡眠之前條件就已經達成了,那么循環會退出并用set_current_state()將自己的狀態設置為就緒,這樣同樣保證了進程不會存在錯誤的進入睡眠的傾向,當然也就不會導致出現無效喚醒問題。

下面讓我們用linux 內核中的實例來看看Linux 內核是如何避免無效睡眠的,這段代碼出自Linux2.6的內核(linux-2.6.11/kernel/sched.c: 4254):

  1. /* Wait for kthread_stop */ 
  2.  
  3. set_current_state(TASK_INTERRUPTIBLE); 
  4.  
  5. while (!kthread_should_stop()) { 
  6.  
  7. schedule(); 
  8.  
  9. set_current_state(TASK_INTERRUPTIBLE); 
  10.  
  11.  
  12. __set_current_state(TASK_RUNNING); 
  13.  
  14. return 0;  

上面的這些代碼屬于遷移服務線程migration_thread,這個線程不斷地檢查kthread_should_stop(),

直 到kthread_should_stop()返回1它才可以退出循環,也就是說只要kthread_should_stop()返回0該進程就會一直睡 眠。從代碼中我們可以看出,檢查kthread_should_stop()確實是在進程的狀態被置為TASK_INTERRUPTIBLE后才開始執行 的。因此,如果在條件檢查之后但是在schedule()之前有其他進程試圖喚醒它,那么該進程的喚醒操作不會失效。

總結

通過上面的討論,可以發現在Linux 中避免進程的無效喚醒的關鍵是在進程檢查條件之前就將進程的

狀態置為TASK_INTERRUPTIBLE或TASK_UNINTERRUPTIBLE,并且如果檢查的條件滿足的話就應該

將其狀態重新設置為TASK_RUNNING。這樣無論進程等待的條件是否滿足, 進程都不會因為被移出就緒隊列而錯誤地進入睡眠狀態,從而避免了無效喚醒問題。 

責任編輯:龐桂玉 來源: 嵌入式Linux中文站
相關推薦

2018-03-19 08:32:16

Linux 進程睡眠喚醒

2021-07-26 07:47:36

數據庫

2017-12-06 10:50:50

Linux自動喚醒系統運行時間

2021-07-20 08:02:41

Linux進程睡眠

2011-09-09 19:46:46

windows7睡眠

2013-03-25 14:29:23

Surface Pro

2010-09-02 16:40:15

SQL刪除

2016-09-07 18:42:02

Linux進程監控

2020-06-02 17:07:56

內核阻塞進程

2023-01-18 23:06:23

Linux鬧鐘

2010-02-25 10:28:43

Linux進程管理

2010-06-04 14:31:59

Linux 查看進程

2009-12-07 09:35:33

linux內核linuxS3C2410

2010-06-04 15:16:36

Linux 查看進程

2010-06-13 15:17:16

Linux 查看進程

2010-03-03 14:30:35

Linux睡眠休眠

2025-01-26 08:00:00

遠程喚醒技術WOL網卡

2017-03-03 09:40:52

Linux休眠喚醒

2012-08-22 13:53:15

Windows 8Linux

2023-03-02 23:50:36

Linux進程管理
點贊
收藏

51CTO技術棧公眾號

欧美人与禽猛交乱配视频| 波多视频一区| 成人精品一区二区三区四区| 国语自产偷拍精品视频偷| 黄色国产在线观看| 日韩成人一区| 欧美日韩国产中文精品字幕自在自线| 欧美一区二区三区四区在线观看地址 | 女人天堂av手机在线| 国产在线一二三区| 国产精品亚洲一区二区三区妖精| 欧美一级片免费在线| 久久爱一区二区| 偷窥自拍亚洲色图精选| 欧美高清激情brazzers| 欧美成人xxxxx| av毛片在线免费| 久久精品一区二区三区不卡牛牛 | 免费av网址在线| 尤物在线网址| 国产精品国产三级国产普通话99| 久久av一区二区三区亚洲| 国产精品呻吟久久| 日韩专区在线视频| 久久免费视频这里只有精品| 欧美性猛交xxxx乱大交少妇| 欧美久久香蕉| 日韩欧美一级二级三级| 992kp快乐看片永久免费网址| 阿v视频在线| 亚洲欧美精品午睡沙发| 亚洲高清资源综合久久精品| 五月天婷婷激情网| 懂色av中文字幕一区二区三区| 国产日韩亚洲欧美| 日韩欧美一级大片| 老司机精品视频网站| 97超级碰碰碰久久久| 青娱乐国产在线| 久久久久久久久丰满| 最近2019中文免费高清视频观看www99 | 国产三级漂亮女教师| 日本亚洲视频在线| 国产成人精品久久久| 成人免费视频毛片| 亚洲激情欧美| 欧美精品videofree1080p| 日韩在线观看免| 91亚洲国产高清| 搡老女人一区二区三区视频tv| 亚洲最大成人网站| 免费视频亚洲| 亚洲区免费影片| 国产又大又粗又爽的毛片| 精品一区三区| 国产亚洲精品美女| 精品无码在线观看| 成人综合久久| 色偷偷av亚洲男人的天堂| 少妇av片在线观看| 成人精品视频| 久久精品国产电影| 欧美国产日韩在线观看成人| 亚洲精彩视频| 久久久噜噜噜久久| 中文字幕亚洲精品在线| 久久天堂精品| 国产欧美久久一区二区| 国产裸体永久免费无遮挡| 国产一区二区女| 国产精品中出一区二区三区| 四虎影视在线观看2413| 久久综合五月天婷婷伊人| 日本一区二区在线视频| 久久久久久久久免费视频| 亚洲色图清纯唯美| 国产在线播放观看| 欧洲亚洲两性| 4438x亚洲最大成人网| 亚洲熟女一区二区三区| 台湾色综合娱乐中文网| 一个人www欧美| 麻豆疯狂做受xxxx高潮视频| 制服诱惑一区二区| 国产欧美日韩高清| 丰满少妇一级片| 欧美极品另类videosde| 成人在线观看毛片| 一区一区三区| 欧美一级片在线观看| 亚洲av成人片无码| 成人一二三区| 久久久综合免费视频| 波多野结衣视频网址| 国内成人精品2018免费看| 国产精品一区二区三区观看| 国产最新视频在线观看| 亚洲精品成a人| 天天摸天天碰天天添| 国产一区二区在线观| 亚洲精品中文字幕女同| 紧身裙女教师波多野结衣| 午夜一级在线看亚洲| 91在线免费网站| 美女毛片在线看| 一片黄亚洲嫩模| 在线观看国产一级片| 另类在线视频| 欧美成人午夜影院| 欧美成人精品网站| 91在线云播放| 国产内射老熟女aaaa| 成人国产激情在线| 日韩精品极品在线观看播放免费视频| 韩国一级黄色录像| 久久国产福利| 国产精品成人观看视频免费| 日本免费在线观看| 日韩欧美一区二区三区| 亚洲国产精品第一页| 97精品国产| 国产精品精品国产| 无码国产色欲xxxx视频 | 久草视频在线观| 国产精品一区在线观看乱码 | 亚洲综合自拍网| 你懂的一区二区| 国产精品丝袜白浆摸在线| 日韩电影免费| 天天影视色香欲综合网老头| 亚洲av无码久久精品色欲| 99久久99久久精品国产片桃花 | 久久天天躁狠狠躁夜夜躁| 成人一二三四区| 久久理论电影网| aa在线免费观看| 亚洲色图丝袜| 热久久免费视频精品| 无码国产精品一区二区免费16| 亚洲一区二区三区中文字幕在线| 亚洲日本黄色片| 欧美丰满日韩| 91亚洲国产精品| 黄在线免费观看| 5月丁香婷婷综合| 婷婷激情四射网| 国模大尺度一区二区三区| 亚洲午夜精品久久| 欧美性生活一级| 久久影视电视剧免费网站| 国产口爆吞精一区二区| 亚洲天堂福利av| 善良的小姨在线| 欧美二区视频| 成人资源av| 91破解版在线观看| 亚洲精品在线不卡| 中文文字幕一区二区三三| 国产精品久久久久影院亚瑟| 自拍偷拍一区二区三区四区| 国产精品国产一区| 91久久国产综合久久蜜月精品 | 五月久久久综合一区二区小说| 国产精品一区二区久久精品| 求av网址在线观看| 日韩一二三四区| xxxx 国产| 久久这里都是精品| www.涩涩涩| 亚洲欧洲日韩| 精品国产福利| 外国电影一区二区| 久久高清视频免费| 手机看片一区二区| 在线免费一区三区| 999精品在线视频| 成人精品视频一区二区三区 | 中文字幕九色91在线| 91精品国产综合久| 亚洲成人中文在线| 永久免费成人代码| 国产精一区二区三区| 欧美极品欧美精品欧美| 成人高清av| 国产91视觉| 色尼玛亚洲综合影院| 久久精品国产亚洲精品| 免费观看成年人视频| 在线视频观看一区| 欧美日韩一级大片| 久久久高清一区二区三区| 制服下的诱惑暮生| 麻豆成人在线| 777久久精品一区二区三区无码| 欧美理伦片在线播放| 国产精品综合不卡av| av日韩国产| 精品国模在线视频| 免费毛片在线| 亚洲精品在线网站| 91激情在线观看| 精品久久久久久中文字幕一区奶水 | 苍井空浴缸大战猛男120分钟| 亚洲h色精品| 日本欧美精品久久久| jizz性欧美2| 成人激情免费在线| 台湾成人免费视频| 海角国产乱辈乱精品视频| 欧美精品hd| 亚洲男人av在线| 黄色av小说在线观看| 在线成人av网站| 精品一区二三区| 亚洲午夜电影在线| 男女做暖暖视频| 国产精品天干天干在线综合| 国产人妻人伦精品1国产丝袜| 国产成人精品一区二| 一道本在线免费视频| 手机精品视频在线观看| 黄色成人在线看| 国产精品啊v在线| 男女h黄动漫啪啪无遮挡软件| 精品欧美久久| 欧美久久久久久久| 欧美人妖视频| 国内视频一区二区| 成人av动漫| 亚洲最大av在线| 国产美女亚洲精品7777| 国产精品一区二区女厕厕| av激情成人网| 国产成人涩涩涩视频在线观看| freexxx性亚洲精品| 欧美黄色三级网站| 日本伦理一区二区| 色综合久久精品亚洲国产| 黄色视屏免费在线观看| 精品久久国产精品| 黄色av免费在线| 美女久久久久久久| av毛片在线| 欧美激情精品久久久久久黑人| 中中文字幕av在线| 欧美国产精品va在线观看| 亚洲小说区图片| 欧美黄色三级网站| 波多野一区二区| 欧美中文在线观看国产| 国产高清不卡| 国产精品国模在线| 欧美视频在线视频精品| 国产在线高清精品| 欧美三级一区| 国产麻豆一区二区三区在线观看| 国产亚洲精品美女久久| 久久大香伊蕉在人线观看热2| 任你躁在线精品免费| 欧美激情国产日韩| 日韩激情图片| 亚洲一区 在线播放| 欧美日韩国产色综合一二三四| 日韩欧美一区二| 视频一区国产视频| 老司机久久精品| 大尺度一区二区| 精品成人av一区二区三区| 日本一区二区免费在线| 国产天堂av在线| 午夜天堂影视香蕉久久| 天堂网视频在线| 欧美日韩精品一区二区三区蜜桃| 99热这里只有精品99| 亚洲成人999| 国产在线黄色| 欧美精品日韩三级| 校园春色亚洲| 91日韩在线播放| 天美av一区二区三区久久| 台湾成人av| 国产中文一区| 成人免费xxxxx在线视频| 国产制服丝袜一区| av网站有哪些| 亚洲精品免费在线| 久久久久亚洲av成人毛片韩| 欧美日韩一区二区三区不卡| 亚洲国产av一区二区| 亚洲人高潮女人毛茸茸| 国产区在线观看| 国产精品69av| 8x国产一区二区三区精品推荐| 欧美高清视频一区二区三区在线观看| 欧美电影一二区| 成年人视频在线免费| 国产精品影视在线观看| a资源在线观看| 亚洲观看高清完整版在线观看| 亚洲精品一区二区二区| 精品国产电影一区二区| 麻豆视频在线观看免费| 日产精品久久久一区二区福利| 精品久久国产一区| 日本不卡免费新一二三区| 国内精品福利| 亚洲第一天堂久久| 国产日韩在线不卡| 亚洲黄色三级视频| 欧美一区二区在线视频| 成人免费在线电影| 97av在线视频免费播放| 99re6热只有精品免费观看| 亚洲欧洲精品一区二区| 翔田千里一区二区| 国产伦精品一区二区三区精品| 国产精品成人免费精品自在线观看| 偷偷操不一样的久久| 精品国产成人系列| 色老头在线观看| 91精品视频网站| 日本不卡免费一区| 日韩一级片播放| 91免费在线播放| 久一视频在线观看| 欧美一区二区三区人| 日本综合在线| 成人两性免费视频| 欧美黄色录像片| 尤物国产在线观看| 中文无字幕一区二区三区| 波多野结衣绝顶大高潮| 亚洲丝袜一区在线| 激情开心成人网| 欧美午夜欧美| 久久久久国产精品午夜一区| 一起草在线视频| 欧美日韩美女在线| 偷拍自拍在线| 欧美一区二区三区……| 日本中文字幕在线一区| 六月丁香婷婷激情| 91美女福利视频| 99久久久无码国产精品免费蜜柚| 亚洲精品永久免费精品| 大胆人体一区二区| 天堂精品视频| 久久av中文字幕片| 成人免费精品动漫网站| 欧美一区日韩一区| 午夜小视频在线观看| 国产精品久久久久久久小唯西川 | 国产精品福利观看| 成人网18免费网站| 一区二区三区国产好的精华液| 亚洲丝袜精品丝袜在线| 精品国精品国产自在久不卡| 欧美二区在线播放| 久久精品色播| 国产精品99久久免费黑人人妻| 国产网站一区二区三区| 91tv国产成人福利| 欧美激情一级二级| 一区二区三区视频免费观看| 国产一级做a爰片久久| 亚洲欧洲日产国产综合网| 亚洲av无码乱码国产麻豆| 国内自拍欧美激情| 欧美人与物videos另类xxxxx| 亚洲欧美久久久久| 一区二区不卡在线播放 | 日本男人操女人| 中文字幕一区在线观看视频| 性猛交富婆╳xxx乱大交天津| 国语自产精品视频在线看| 欧美精品乱码| 91亚洲一线产区二线产区| 色综合久久中文字幕| 欧美成人xxx| 国产精品乱码| 蜜桃久久久久久| 久久精品国产亚洲av无码娇色 | 国产精品午夜av在线| 久久婷婷激情| 久草视频免费在线播放| 亚洲美女又黄又爽在线观看| 色综合一区二区日本韩国亚洲 | 国产精品白丝喷水在线观看| 亚洲第一精品自拍| 精品亚洲a∨| 国产不卡一区二区视频| 国产精品国产三级国产普通话蜜臀| 人妻少妇精品无码专区久久| 国产精品极品美女在线观看免费 | 91国产视频在线播放| 三级电影一区| 三级黄色片网站| 欧美一区二区三区免费| 日本欧美日韩| 欧美一级视频免费看|