哈哈哈哈哈操欧洲电影,久草网在线,亚洲久久熟女熟妇视频,麻豆精品色,久久福利在线视频,日韩中文字幕的,淫乱毛视频一区,亚洲成人一二三,中文人妻日韩精品电影

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

【i.MX6ULL】驅(qū)動(dòng)開(kāi)發(fā)9——Linux I/O模型分析并進(jìn)來(lái)類比

碼農(nóng)愛(ài)學(xué)習(xí) ? 來(lái)源:碼農(nóng)愛(ài)學(xué)習(xí) ? 作者:碼農(nóng)愛(ài)學(xué)習(xí) ? 2022-05-26 09:05 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前面兩篇介紹按鍵的文章,無(wú)論是用GPIO來(lái)讀取,還是用中斷的方式,其應(yīng)用程序通過(guò)循環(huán)讀取的方式獲取按鍵值,都會(huì)使得CPU的占用率很高。本篇先來(lái)介紹Linux中幾種的I/O模型,以后使用這類方式進(jìn)行按鍵值的讀取,可以極大降低CPU的使用率。

1 Linux中的I/O模型

這里以網(wǎng)絡(luò)I/O為例進(jìn)行分析,網(wǎng)絡(luò)IO的本質(zhì)是socket的讀取,socket在linux系統(tǒng)被抽象為流,對(duì)于一次IO訪問(wèn),以read為例,當(dāng)一個(gè)read操作發(fā)生時(shí),它會(huì)經(jīng)歷兩個(gè)階段:

等待數(shù)據(jù)準(zhǔn)備 (Waiting for the data to be ready)

將數(shù)據(jù)從內(nèi)核拷貝到進(jìn)程中 (Copying the data from the kernel to the process)

網(wǎng)絡(luò)I/O的模型,可以分為五種,這里先分類列出:

pYYBAGKOSqSASDN6AACJ9PwMXcs037.png

2 五種I/O模型分析

2.1 阻塞式I/O模型

阻塞式I/O模型是最常用、最簡(jiǎn)單的模型。阻塞就是進(jìn)程被休息, CPU處理其它進(jìn)程去了。

應(yīng)用程序進(jìn)行recefrom系統(tǒng)調(diào)用,操作系統(tǒng)收到recefrom系統(tǒng)調(diào)用請(qǐng)求,經(jīng)過(guò)兩個(gè)階段:

等待數(shù)據(jù)準(zhǔn)備好

內(nèi)核將數(shù)據(jù)從內(nèi)核緩沖區(qū)復(fù)制到用戶緩沖區(qū)

這兩個(gè)階段完成后調(diào)用返回,應(yīng)用程序解除阻塞。

poYBAGKOSq2AAMoKAAHyp_gqMGE018.png

2.2 非阻塞式I/O模型

非阻塞就是輪詢的方式,在這種模型中, I/O操作不會(huì)立即完成,recefrom操作可能會(huì)返回一個(gè)錯(cuò)誤代碼,說(shuō)明這個(gè)命令不能立即滿足。

對(duì)于第一個(gè)階段:

等待數(shù)據(jù)準(zhǔn)備好

在這個(gè)階段系統(tǒng)調(diào)用會(huì)立刻返回一個(gè)錯(cuò)誤狀態(tài),不會(huì)阻塞,應(yīng)用程序需要不斷輪詢,直到內(nèi)核緩沖區(qū)數(shù)據(jù)準(zhǔn)備好

對(duì)于第二個(gè)階段:

內(nèi)核將數(shù)據(jù)從內(nèi)核緩沖區(qū)拷貝到用戶緩沖區(qū)

這個(gè)階段應(yīng)用程序的調(diào)用會(huì)被阻塞,直到拷貝完成,應(yīng)用程序的系統(tǒng)調(diào)用返回。

pYYBAGKOSrWAUg0mAANTbNQJfAc286.png

2.3 I/O復(fù)用模型

由于非阻塞I/O方式需要不斷輪詢,會(huì)消耗大量的CPU時(shí)間,而后臺(tái)又可能有多個(gè)任務(wù)在同時(shí)輪詢,為此,人們就想到了一種方式:循環(huán)查詢多個(gè)任務(wù)的完成狀態(tài),只要有任何一個(gè)任務(wù)完成,就去處理它。

IO多路復(fù)用有兩個(gè)特別的系統(tǒng)調(diào)用select、poll。

select可以等待多個(gè)socket,能實(shí)現(xiàn)同時(shí)對(duì)多個(gè)IO端口進(jìn)行監(jiān)聽(tīng),當(dāng)其中任何一個(gè)socket的數(shù)據(jù)準(zhǔn)好了,就能返回進(jìn)行可讀,然后進(jìn)程再進(jìn)行recvform系統(tǒng)調(diào)用,將數(shù)據(jù)由內(nèi)核拷貝到用戶進(jìn)程,這個(gè)過(guò)程是阻塞的。

pYYBAGKOSryAOrhdAAM9xQ4USq4878.png

2.4 信號(hào)驅(qū)動(dòng)式I/O模型

應(yīng)該程序進(jìn)行Read系統(tǒng)調(diào)用,進(jìn)程繼續(xù)運(yùn)行不會(huì)阻塞,立即返回,等待內(nèi)核緩沖區(qū)數(shù)據(jù)準(zhǔn)備好后,通過(guò)SIGIO信號(hào)通知應(yīng)用程序,應(yīng)用程序再進(jìn)行Read系統(tǒng)調(diào)用,內(nèi)核將內(nèi)核緩沖區(qū)中的數(shù)據(jù)拷貝到用戶緩沖區(qū),調(diào)用完成。

pYYBAGKOSsOAXnU-AALULi-Hvlo252.png

2.5 異步I/O模型

相對(duì)于同步IO,異步IO不是順序執(zhí)行。用戶進(jìn)程進(jìn)行aio_read系統(tǒng)調(diào)用之后,無(wú)論內(nèi)核數(shù)據(jù)是否準(zhǔn)備好,都會(huì)直接返回給用戶進(jìn)程,然后用戶態(tài)進(jìn)程可以去做別的事情。等到socket數(shù)據(jù)準(zhǔn)備好了,內(nèi)核直接復(fù)制數(shù)據(jù)給進(jìn)程,然后從內(nèi)核向進(jìn)程發(fā)送通知。IO兩個(gè)階段,進(jìn)程都是非阻塞的。

pYYBAGKOSsqAcEXGAAIuiv9GPbQ941.png

3 模型對(duì)比

3.1 阻塞I/O與非阻塞I/O對(duì)比

簡(jiǎn)單理解為需要做一件事能不能立即得到返回應(yīng)答,如果不能立即獲得返回,需要等待,那就阻塞了,否則就可以理解為非阻塞。詳細(xì)區(qū)別如下圖所示:

pYYBAGKOStKASMagAABRY-knMlQ399.png

3.2 同步I/O與異步I/O對(duì)比

實(shí)際上同步與異步是針對(duì)應(yīng)用程序內(nèi)核的交互而言的。

同步過(guò)程中進(jìn)程觸發(fā)IO操作并等待或者輪詢的去查看IO操作是否完成。

異步過(guò)程中進(jìn)程觸發(fā)IO操作以后,直接返回,做自己的事情,IO交給內(nèi)核來(lái)處理,完成后內(nèi)核通知進(jìn)程IO完成。

同步與異步如下圖所示:

poYBAGKOStmALg6jAAApIKov2tA307.png

對(duì)于Liunx的五種I/O模型,其實(shí)主要在等待數(shù)據(jù)和數(shù)據(jù)復(fù)制這兩個(gè)時(shí)間段不同。

pYYBAGKOSuCASWPTAAOYfSyT4SA440.png

4 各種I/O模型的生活場(chǎng)景式類比

4.1 類比1-飯店點(diǎn)菜

我們?nèi)ゲ蛷d吃飯,會(huì)經(jīng)過(guò)以下幾個(gè)步驟:首先根據(jù)菜單點(diǎn)菜,然后等待廚房準(zhǔn)備好,接著服務(wù)員上菜。在這個(gè)場(chǎng)景中,等待廚房準(zhǔn)備菜肴等同于等待數(shù)據(jù),服務(wù)員上菜等同于將數(shù)據(jù)從內(nèi)核復(fù)制到用戶空間,你就是用戶態(tài)進(jìn)程了,服務(wù)員和飯店看作是內(nèi)核態(tài)的進(jìn)程。

阻塞式I/O模型:只點(diǎn)一個(gè)菜,然后在餐桌上開(kāi)始等待,在這個(gè)過(guò)程中什么事都不干,等服務(wù)員把菜上到桌子上之后才開(kāi)始大快朵頤。

非阻塞式I/O模型:只點(diǎn)一個(gè)菜,然后開(kāi)始等待,啥事都不做,等了一會(huì)兒然后就去問(wèn)服務(wù)員,“我的菜好了嗎?”,沒(méi)好接著等待,過(guò)了一會(huì)兒然后又跑去問(wèn)....重復(fù)這個(gè)過(guò)程,直到服務(wù)員說(shuō)“親,你的菜好了,我現(xiàn)在給您送桌上去”,然后你坐在桌子上,等待服務(wù)員把飯菜送到你的餐桌上,才開(kāi)始吃飯。

I/O復(fù)用模型:你點(diǎn)了很多菜,然后開(kāi)始等待,某個(gè)時(shí)刻其中一個(gè)菜或者多個(gè)菜廚房里同時(shí)好了,服務(wù)員跑過(guò)來(lái)說(shuō),“親,您的有些菜好了,要現(xiàn)在上桌么?”, 你回答,現(xiàn)在就上,于是服務(wù)員上一個(gè)菜(服務(wù)員一次只能上一個(gè)菜),你就吃完一個(gè),上一個(gè)你就吃完一個(gè)。。。

信號(hào)驅(qū)動(dòng)式I/O模型:只點(diǎn)一個(gè)菜,然后給服務(wù)員留下手機(jī),告訴他菜準(zhǔn)備好了打個(gè)電話給你,先不要上菜,然后你就出去玩耍了,等到菜好了,服務(wù)員手機(jī)通知你,你立馬回到了餐廳,對(duì)服務(wù)員說(shuō)“你現(xiàn)在可以上菜了”,于是你在餐桌上等待服務(wù)員把菜送上來(lái),然后吃飯。

異步I/O模型:只點(diǎn)一個(gè)菜,然后給服務(wù)員留下手機(jī),告訴他菜準(zhǔn)備好了先上菜,菜上桌了打電話給你,然后你就出去玩耍了,等到菜上桌了,服務(wù)員手機(jī)通知你,你立馬回到了餐桌,開(kāi)始吃飯。

該例子出自: https://segmentfault.com/a/1190000016359495

4.2 類比2-釣魚

有A,B,C,D四個(gè)人在釣魚。

阻塞式I/O模型:A用的是最老式的魚竿,所以呢,得一直守著,等到魚上鉤了再拉桿;

非阻塞式I/O模型:B的魚竿有個(gè)功能,能夠顯示是否有魚上鉤,所以呢,B就和旁邊的MM聊天,隔會(huì)再看看有沒(méi)有魚上鉤,有的話就迅速拉桿;

I/O復(fù)用模型:C用的魚竿和B差不多,但他想了一個(gè)好辦法,就是同時(shí)放好幾根魚竿,然后守在旁邊,一旦有顯示說(shuō)魚上鉤了,它就將對(duì)應(yīng)的魚竿拉起來(lái);

異步I/O模型:D是個(gè)有錢人,干脆雇了一個(gè)人幫他釣魚,一旦那個(gè)人把魚釣上來(lái)了,就給D發(fā)個(gè)短信。

該例子出自: https://blog.csdn.net/historyasamirror/article/details/5778378

4.3 類比3-銀行存錢匯款

阻塞式I/O模型:你去一個(gè)銀行柜臺(tái)存錢。首先,你會(huì)將存錢的單子填好,交給柜員,之后,你就坐在柜臺(tái)前等。柜員辦好以后會(huì)給你一個(gè)回執(zhí),表示辦好了,然后你就可以拿著回執(zhí)干其它的事了。注意,這時(shí)如果你馬上去查賬,存的錢已經(jīng)打到你的賬戶上了。

非阻塞式I/O模型:這次不是去銀行存錢,而是去銀行匯款。同樣的,你也需要填寫匯款單然后交給柜員,柜員進(jìn)行一些簡(jiǎn)單的手續(xù)處理就能夠給你回執(zhí)。但是,你拿到回執(zhí)并不意味著錢已經(jīng)打到了對(duì)方的賬上。事實(shí)上,一般匯款的周期大概是24個(gè)小時(shí)左右,如果你要以存錢的模式來(lái)匯款的話,意味著你需要在銀行等24個(gè)小時(shí),這顯然是不現(xiàn)實(shí)的。

I/O復(fù)用模型:比如說(shuō)一個(gè)銀行柜臺(tái),現(xiàn)在有10個(gè)人想存錢。這10個(gè)人都填好存款單,然后都提交給柜臺(tái),提交完之后所有的10個(gè)人就在銀行大廳等待。這時(shí)候會(huì)專門有個(gè)人,他會(huì)了解存款單處理的情況,一旦有存款單處理完畢,他會(huì)將回執(zhí)交給相應(yīng)的正在大廳等待的人,這個(gè)拿到回執(zhí)的人就可以去干其他的事情了。而前面提到的這個(gè)專人,就對(duì)應(yīng)于select函數(shù)。

異步I/O模型:現(xiàn)在某銀行新開(kāi)通了一項(xiàng)存錢業(yè)務(wù)。用戶之需要將存款單交給柜臺(tái),然后無(wú)需等待就可以離開(kāi)了。柜臺(tái)辦好以后會(huì)給用戶發(fā)送一條短信,告知交易成功。這樣用戶不需要在柜臺(tái)前進(jìn)行長(zhǎng)時(shí)間的等待,同時(shí),也能夠得到確切的消息知道交易完成。

該例子出自: https://blog.csdn.net/historyasamirror/article/details/4270633

5 總結(jié)

本篇介紹了Linux中的五種I/O模型:阻塞式I/O模型、非阻塞式I/O模型、I/O復(fù)用模型、信號(hào)驅(qū)動(dòng)式I/O模型、異步I/O模型,并通過(guò)生活中實(shí)際的場(chǎng)景進(jìn)來(lái)類比。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5208

    文章

    20620

    瀏覽量

    336637
  • Linux
    +關(guān)注

    關(guān)注

    88

    文章

    11806

    瀏覽量

    219482
  • GPIO
    +關(guān)注

    關(guān)注

    16

    文章

    1333

    瀏覽量

    56428
  • i.MX6
    +關(guān)注

    關(guān)注

    1

    文章

    37

    瀏覽量

    16795
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    i.MX6ULL能否接受來(lái)自外部振蕩器的直接50 MHz輸入?

    我們正在將 LAN8710A-EZK PHY 與 RMII 模式下的 i.MX6ULL 集成,需要澄清有關(guān) 50 MHz 參考時(shí)鐘的信息。 由于RMII需要50 MHz時(shí)鐘,i.MX6ULL能否接受
    發(fā)表于 04-17 06:05

    開(kāi)發(fā)一個(gè)基于運(yùn)行 Yocto 的 i.MX6ULL 的定制板,如何減少啟動(dòng)時(shí)間?

    我正在開(kāi)發(fā)一個(gè)基于運(yùn)行 Yocto 的 i.MX6ULL 的定制板,我想盡可能減少啟動(dòng)時(shí)間。 到目前為止,我已經(jīng): 禁用內(nèi)核中所有不必要的選項(xiàng) (menuconfig) 將 Yocto 圖像減少到
    發(fā)表于 04-16 08:26

    i.MX 6ULL之后:2026年入門工控平臺(tái),TI AM62x與STM32MP1誰(shuí)主沉???

    做一個(gè)帶 7 寸屏的工業(yè)儀器、充電樁顯示屏或簡(jiǎn)易網(wǎng)關(guān),NXP i.MX 6ULL 是閉眼選的標(biāo)準(zhǔn)答案。
    的頭像 發(fā)表于 01-27 15:15 ?580次閱讀

    FRDM-i.MX 91開(kāi)發(fā)板刷機(jī)指南

    FRDM-i.MX 91開(kāi)發(fā)板刷機(jī)指南 在電子開(kāi)發(fā)領(lǐng)域,開(kāi)發(fā)板的刷機(jī)操作是一項(xiàng)基礎(chǔ)且關(guān)鍵的技能。今天,我們就來(lái)詳細(xì)探討NXP的FRDM-i.MX
    的頭像 發(fā)表于 12-24 11:30 ?1074次閱讀

    FRDM i.MX 9平臺(tái)選型指南:FRDM i.MX 9系列開(kāi)發(fā)平臺(tái)解析

    FRDM i.MX 9系列開(kāi)發(fā)平臺(tái)的入門級(jí)產(chǎn)品 FRDM i.MX 9系列概述 恩智浦FRDM i.MX
    的頭像 發(fā)表于 12-11 15:15 ?4.8w次閱讀
    FRDM <b class='flag-5'>i.MX</b> <b class='flag-5'>9</b>平臺(tái)選型指南:FRDM <b class='flag-5'>i.MX</b> <b class='flag-5'>9</b>系列<b class='flag-5'>開(kāi)發(fā)</b>平臺(tái)解析

    既要穩(wěn)定性,還要性價(jià)比的工業(yè)級(jí)開(kāi)發(fā)板 — 米爾i.MX91

    之前我介紹過(guò)NXPi.MX8系列的開(kāi)發(fā)板,最近它的下一代產(chǎn)品i.MX9系列產(chǎn)品也有了,我就拿到了這個(gè)基于NXPi.MX9系列的米爾MYD-LMX91
    的頭像 發(fā)表于 11-20 08:05 ?2630次閱讀
    既要穩(wěn)定性,還要性價(jià)比的工業(yè)級(jí)<b class='flag-5'>開(kāi)發(fā)</b>板 — 米爾<b class='flag-5'>i.MX</b>91

    簡(jiǎn)單認(rèn)識(shí)NXP FRDM i.MX 93開(kāi)發(fā)

    FRDM i.MX 93開(kāi)發(fā)板是一款入門級(jí)、緊湊型開(kāi)發(fā)板,采用i.MX93應(yīng)用處理器。該板配備板載IW612模塊,集成了恩智浦的三頻解決方案,支持Wi-Fi
    的頭像 發(fā)表于 11-17 09:45 ?1701次閱讀
    簡(jiǎn)單認(rèn)識(shí)NXP FRDM <b class='flag-5'>i.MX</b> 93<b class='flag-5'>開(kāi)發(fā)</b>板

    【米爾NXP i.MX 91開(kāi)發(fā)板評(píng)測(cè)】移植和運(yùn)行RT-Linux,實(shí)時(shí)性能測(cè)試

    介紹 實(shí)時(shí)性系統(tǒng)應(yīng)用廣泛,在工業(yè)自動(dòng)化、醫(yī)療設(shè)備、汽車電子等領(lǐng)域扮演著十分重要的角色,我們用i.MX91開(kāi)發(fā)板來(lái)移植運(yùn)行RT-Linux,看看它的實(shí)時(shí)性能表現(xiàn)如何 實(shí)時(shí)補(bǔ)丁 下載并應(yīng)用RT補(bǔ)丁
    發(fā)表于 09-01 10:11

    瑞芯微RK3506 vs NXP i.MX6ULL

    NXPi.MX6ULL核心板進(jìn)行多方面對(duì)比。性能與能效對(duì)比性能優(yōu)勢(shì)對(duì)比:RK3506在接口方面比i.MX6ULL少2個(gè)UART,其他性能方面,RK3506以三核A7(1.
    的頭像 發(fā)表于 06-19 16:26 ?1482次閱讀
    瑞芯微RK3506 vs NXP <b class='flag-5'>i.MX6ULL</b>

    618盛夏狂歡,米爾電子攜手恩智浦開(kāi)啟年度技術(shù)盛宴!

    即日起-2025.06.30,米爾恩智浦多系列開(kāi)發(fā)板限時(shí)折扣!米爾基于i.MX91、i.MX93、i.MX8MPlus、i.MX6UL/
    的頭像 發(fā)表于 06-13 08:03 ?1006次閱讀
    618盛夏狂歡,米爾電子攜手恩智浦開(kāi)啟年度技術(shù)盛宴!

    米爾NXP i.MX 91核心板發(fā)布,助力新一代入門級(jí)Linux應(yīng)用開(kāi)發(fā)

    本帖最后由 blingbling111 于 2025-5-30 16:17 編輯 米爾電子基于與NXP長(zhǎng)期合作的嵌入式處理器開(kāi)發(fā)經(jīng)驗(yàn),在i.MX 6i.MX 8系列核心板領(lǐng)域已
    發(fā)表于 05-30 11:20

    5分鐘學(xué)會(huì)網(wǎng)絡(luò)服務(wù)搭建,飛凌i.MX9352 + Linux 6.1實(shí)戰(zhàn)示例

    本文將以飛凌嵌入式OK-MX9352-C開(kāi)發(fā)板(搭載了在工業(yè)物聯(lián)網(wǎng)領(lǐng)域廣泛應(yīng)用的NXP i.MX9352處理器)為平臺(tái),介紹如何在Linux6.1.36
    的頭像 發(fā)表于 05-30 11:08 ?2491次閱讀
    5分鐘學(xué)會(huì)網(wǎng)絡(luò)服務(wù)搭建,飛凌<b class='flag-5'>i.MX</b>9352 + <b class='flag-5'>Linux</b> 6.1實(shí)戰(zhàn)示例

    新品!米爾NXP i.MX 91核心板,賦能新一代入門級(jí)Linux應(yīng)用

    米爾電子基于與NXP長(zhǎng)期合作的嵌入式處理器開(kāi)發(fā)經(jīng)驗(yàn),在i.MX6i.MX8系列核心板領(lǐng)域已形成完整產(chǎn)品矩陣,米爾累計(jì)推出5個(gè)平臺(tái)共計(jì)二十余款NXP核心板,涵蓋工業(yè)物聯(lián)網(wǎng)、新能源、醫(yī)療等領(lǐng)域。此次
    的頭像 發(fā)表于 05-29 08:01 ?3037次閱讀
    新品!米爾NXP <b class='flag-5'>i.MX</b> 91核心板,賦能新一代入門級(jí)<b class='flag-5'>Linux</b>應(yīng)用

    NXP i.MX 91開(kāi)發(fā)板#支持快速創(chuàng)建基于Linux?的邊緣器件

    NXP Semiconductors FRDM i.MX 91開(kāi)發(fā)板設(shè)計(jì)用于評(píng)估i.MX 91應(yīng)用處理器,支持快速創(chuàng)建基于Linux ^?^ 的邊緣器件。該
    的頭像 發(fā)表于 05-19 10:55 ?3312次閱讀
    NXP <b class='flag-5'>i.MX</b> 91<b class='flag-5'>開(kāi)發(fā)</b>板#支持快速創(chuàng)建基于<b class='flag-5'>Linux</b>?的邊緣器件

    ECB20-PG6Y28C-I 單板機(jī)深度測(cè)評(píng)報(bào)告 ——工業(yè)級(jí)嵌入式開(kāi)發(fā)的強(qiáng)力助手

    ECB20-PG6Y28C-I?是成都億佰特電子科技基于 i.MX6ULL 處理器推出的工業(yè)級(jí)測(cè)試底板,搭配 ECK20-6Y28C 系列核心板,專為高性能嵌入式場(chǎng)景設(shè)計(jì)。其核心亮點(diǎn)在于 雙網(wǎng)口、多接口擴(kuò)展能力?和 工業(yè)級(jí)可靠性
    的頭像 發(fā)表于 04-22 11:49 ?1356次閱讀
    沙田区| 新建县| 金湖县| 全南县| 东港市| 曲麻莱县| 江城| 广元市| 嵊泗县| 南郑县| 洛阳市| 微博| 紫金县| 凉城县| 易门县| 新巴尔虎右旗| 易门县| 五台县| 宣威市| 朔州市| 新宁县| 务川| 京山县| 佛坪县| 黑河市| 宁明县| 静海县| 海阳市| 丹巴县| 琼中| 浦城县| 茂名市| 甘德县| 哈尔滨市| 绵阳市| 民勤县| 乌拉特后旗| 福海县| 苍山县| 西林县| 林芝县|