国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

一文詳解在Android中Service和AIDL的使用

 更新時(shí)間:2023年04月27日 09:12:09   作者:Heart-Beats  
Service是Android四大組件之一,它是不依賴于用戶界面的,就是因?yàn)镾ervice不依賴與用戶界面,本文將詳細(xì)介紹在Android中Service和AIDL的使用,感興趣的同學(xué)可以參考本文

Service 和 AIDL 的使用

[TOC]

1. Service

  • Service (服務(wù)) 是一個(gè)一種可以在后臺(tái)執(zhí)行長時(shí)間操作而沒有用戶界面的應(yīng)用組件。
  • 服務(wù)可由其他應(yīng)用組件啟動(dòng)(如 Activity ),若沒進(jìn)行綁定,服務(wù)一旦啟動(dòng)將在后臺(tái)一直運(yùn)行,即使啟動(dòng)服務(wù)的組件( Activity )已銷毀也不受影響。
  • 組件也可以綁定到服務(wù),以與之進(jìn)行交互,甚至是執(zhí)行進(jìn)程間通信 ( IPC ),這時(shí)組件銷毀時(shí)服務(wù)也會(huì)停止。

該類中的常用方法如下:

public abstract class Service extends ContextWrapper implements ComponentCallbacks2, ContentCaptureManager.ContentCaptureClient {
        
    // 創(chuàng)建時(shí)回調(diào)
    public void onCreate() {
    }

    // startService 時(shí)回調(diào)
    public @StartResult int onStartCommand(Intent intent, @StartArgFlags int flags, int startId) {
        onStart(intent, startId);
        return mStartCompatibility ? START_STICKY_COMPATIBILITY : START_STICKY;
    }
    
    // bindService 時(shí)的回調(diào)
    @Nullable
    public abstract IBinder onBind(Intent intent);
    
    // unbindService 時(shí)的回調(diào)
    public boolean onUnbind(Intent intent) {
        return false;
    }
    
    // 當(dāng) onUnbind 返回 true 時(shí),重新綁定時(shí)的回調(diào)
    public void onRebind(Intent intent) {
    }
    
    // 銷毀停止時(shí)的回調(diào)
    public void onDestroy() {
    }
    
    // 內(nèi)部的停止方法,若想停止并獲取結(jié)果使用 stopSelfResult(startId)
    public final void stopSelf() {
        stopSelf(-1);
    }
}

這里 onStartCommand() 的返回值很重要,共有如下四種不同的取值:

  • START_STICKY

    • 粘性的

    • onStartCommand() 使用這個(gè)返回值執(zhí)行后,如果 service 進(jìn)程被 kill 掉,保留 service 的狀態(tài)為開始狀態(tài),但不保留遞送的 intent 對(duì)象;系統(tǒng)隨后會(huì)嘗試重新創(chuàng)建 service,由于服務(wù)狀態(tài)為開始狀態(tài),所以創(chuàng)建服務(wù)后一定會(huì)調(diào)用 onStartCommand (Intent, int, int) 方法。如果在此期間沒有任何啟動(dòng)命令被傳遞到 service , 那么參數(shù) Intent 將為 null 。

  • START_NOT_STICKY

    • 非粘性的

    • 使用這個(gè)返回值時(shí) , 如果在執(zhí)行完 onStartCommand() 后 , 服務(wù)被異常 kill 掉 ,系統(tǒng)不會(huì)自動(dòng)重啟該服務(wù)。

  • START_REDELIVER_INTENT

    • 重傳 Intent

    • 使用這個(gè)返回值時(shí),如果在執(zhí)行完 onStartCommand() 后,服務(wù)被異常 kill 掉,系統(tǒng)會(huì)自動(dòng)重啟該服務(wù) , 并將 Intent 的值傳入。

  • START_STICKY_COMPATIBILITY

    • START_STICKY 的兼容版本 , 但不保證服務(wù)被 kill 后一定能重啟。

1.1 Service 的基本生命周期

提到生命周期就不得不說到關(guān)于 Service 的兩種啟動(dòng)方法:

  • startService
  • bindService

1.1.1 startService

此方式啟動(dòng)的 Service 會(huì)一直無限運(yùn)行,只有調(diào)用了它的 stopService()stopSelf() 方法時(shí),才會(huì)停止運(yùn)行并銷毀。

生命周期:

  • startService:

 若 service 沒被創(chuàng)建,調(diào)用 startService() 后會(huì)執(zhí)行 onCreate() ----> onStartCommand(),若 service 已創(chuàng)建,startService() 只會(huì)執(zhí)行 onStartCommand()

  • stopService:

1.1.2 bindService

啟動(dòng)的服務(wù)和調(diào)用者之間是典型的 client-server 模式,調(diào)用者是 client,Service 則是 server 端。

         Service 只有一個(gè),但綁定到 Service 上面的 client 可以有多個(gè)。
client 可以通過 IBinder 接口獲取 Service 實(shí)例,實(shí)現(xiàn) client 端調(diào)用 Service 中的方法以實(shí)現(xiàn)交互。
         啟動(dòng)的 Service 的生命周期與其綁定的 client 息息相關(guān)。當(dāng) client 銷毀時(shí),會(huì)自動(dòng)與 Service 解除綁定,當(dāng)然,也可以調(diào)用 Context 的 `unbindService()` 方法手動(dòng)與 Service 解除綁定。當(dāng)沒有任何 client 與 Service 綁定時(shí),Service 就會(huì)自行銷毀。

生命周期:

  • bindService:

 沒啥特殊的,就是 bindService 時(shí) Service 若沒創(chuàng)建會(huì)創(chuàng)建 Service 示例,并在綁定成功后收到 onBind() 回調(diào)。

  • unbindService:
  • unbindService 將組件與 Service 解綁后會(huì)收到 onUnbind() 回調(diào),此時(shí)該 Service 若無任何組件與其綁定,則會(huì)自行銷毀。

1.2 Service 的啟動(dòng)方式

通過上節(jié)介紹,可以了解到啟動(dòng) Service 有 startService()bindService() 兩種方式。

1.2.1 startService

該啟動(dòng)方式,app 殺死、Activity 銷毀沒有任何影響,服務(wù)都不會(huì)銷毀停止運(yùn)行,所以此方式適合后臺(tái)一直運(yùn)行的任務(wù),但無法調(diào)用 Service 中的方法進(jìn)行交互。

比如:播放音樂、下載文件、進(jìn)程?;?hellip;

停止方式:主動(dòng) stopService()

1.2.2 bindService

該啟動(dòng)方式依賴于客戶端生命周期,當(dāng)客戶端 Activity 銷毀時(shí),即使沒有調(diào)用 unbindService() 方法,Service 也會(huì)銷毀停止運(yùn)行。所以此方式適合短時(shí)使用同時(shí)與 Service 產(chǎn)生交互的任務(wù)。

比如:通過 Service 跨進(jìn)程傳輸數(shù)據(jù)…

停止方式:Service 無任何綁定即會(huì)自動(dòng)停止

1.2.3 startService + bindService

該啟動(dòng)方式 Service 可以在后臺(tái)一直運(yùn)行,同時(shí)還可以與 Service 產(chǎn)生交互,調(diào)用它的方法。

比如:播放并控制音樂、下載文件并更新進(jìn)度…

停止方式:需要解除綁定并 stopService()

1.3 Service 和 Thread 的區(qū)別

既然提到 Service 可以執(zhí)行后臺(tái)任務(wù),那么也可以使用線程呀?那么看看有啥不同吧!

首先看看定義:

  • Thread

    線程為程序執(zhí)行的最小單元,Android 中的 UI 線程就是其中一種。

  • Service

    安卓中的四大組件之一,為一種特殊的機(jī)制,其實(shí)是一種輕量級(jí)的 IPC 通信。

其次,需要了解一下 Thread 的局限性:

Thread 的運(yùn)行是獨(dú)立于 Activity 的但依賴于進(jìn)程,也就是說當(dāng)應(yīng)用進(jìn)程被殺死或者線程體運(yùn)行完畢時(shí)就會(huì)停止運(yùn)行。

當(dāng) Activityfinish 后,是無法對(duì)其進(jìn)行管理的。同時(shí) Thread 運(yùn)行過程中對(duì)其進(jìn)行控制操作也非常麻煩,而且也無法通過它實(shí)現(xiàn) IPC(跨進(jìn)程)通信。

那么,就可以了解到 Service 是可以做到這些的。

默認(rèn)情況下, Service 是運(yùn)行在當(dāng)前 app 進(jìn)程的 UI 主線程中,可以在 AndroidManifest 文件中配置 android:process 指定它所在的進(jìn)程。

因此,與 Activity 一樣,Service 是無法直接在其內(nèi)部執(zhí)行耗時(shí)任務(wù)的,需要開啟子線程去執(zhí)行,否則就會(huì)產(chǎn)生 ANR。

1.4 IntentService

在介紹 IntentService 之前先說明一下使用傳統(tǒng)的 Service 會(huì)有何問題:

  • 無法直接處理耗時(shí)任務(wù),需要內(nèi)部開啟子線程
  • startService() 啟動(dòng)之后需要手動(dòng)去停止

那么 IntentService 就是為了解決這些問題而生的,看下該類的主要內(nèi)容:

@Deprecated
public abstract class IntentService extends Service {

    // 該 Handler 在子線程中創(chuàng)建
    private final class ServiceHandler extends Handler {
        
        public ServiceHandler(Looper looper) {
            super(looper);
        }

        @Override
        public void handleMessage(Message msg) {
            onHandleIntent((Intent)msg.obj);
            // 處理完任務(wù)后自動(dòng)停止
            stopSelf(msg.arg1);
        }
    }
    
    @Override
    public void onCreate() {
        super.onCreate();
        HandlerThread thread = new HandlerThread("IntentService[" + mName + "]");
        thread.start();

        mServiceLooper = thread.getLooper();
        mServiceHandler = new ServiceHandler(mServiceLooper);    
    }
    
    @Override
    public void onStart(@Nullable Intent intent, int startId) {
        Message msg = mServiceHandler.obtainMessage();
        msg.arg1 = startId;
        msg.obj = intent;
        
        // startService() 時(shí)將信息發(fā)送到 ServiceHandler 中
        mServiceHandler.sendMessage(msg);
    }
    
    /**
	 * 該方法的返回值為 Service 的標(biāo)志位:
	 *
	 *  @see Service.START_STICKY_COMPATIBILITY: START_STICKY 的兼容版本,但不保證服務(wù)被kill后一定能重啟
	 *
	 *  @see Service.START_STICKY: 粘性的,如果 service 進(jìn)程被 kill 掉,保留 service 的狀態(tài)為開始狀態(tài),但不保留傳送的 intent 對(duì)象。隨后系統(tǒng)會(huì)嘗試重新創(chuàng)建 service,創(chuàng)建后即會(huì)重新調(diào)用 onStartCommand(Intent,int,int) 方法。如果在此期間沒有任何啟動(dòng)命令被傳遞到 service,那么參數(shù) Intent 將為null
	 *
	 *  @see Service.START_NOT_STICKY: 非粘性的,在執(zhí)行完 onStartCommand 后,服務(wù)被異常 kill 掉,系統(tǒng)不會(huì)自動(dòng)重啟該服務(wù)
	 *
	 *  @see Service.START_REDELIVER_INTENT: 重傳 Intent,在執(zhí)行完 onStartCommand 后,服務(wù)被異常 kill 掉,系統(tǒng)會(huì)自動(dòng)重啟該服務(wù),并將 Intent 的值傳入
	 *
	 */
    @Override
    public int onStartCommand(@Nullable Intent intent, int flags, int startId) {
        onStart(intent, startId);
        return mRedelivery ? START_REDELIVER_INTENT : START_NOT_STICKY;
    }
    
    @Override
    public void onDestroy() {
        mServiceLooper.quit();
    }
    
    @Override
    @Nullable
    public IBinder onBind(Intent intent) {
        return null;
    }
    
    // startService() -----> ServiceHandler 的 handleMessage() ------> onHandleIntent()
    @WorkerThread
    protected abstract void onHandleIntent(@Nullable Intent intent);
    
}

從上述代碼中就可以看出它的主要特征:

  • 會(huì)創(chuàng)建獨(dú)立的 worker 線程來處理所有的 Intent 請(qǐng)求,并最終執(zhí)行復(fù)寫的 onHandleIntent() 方法;
  • 請(qǐng)求任務(wù)處理完成后,IntentService 會(huì)自動(dòng)停止,無需調(diào)用 stopSelf() 方法停止 Service

因此,對(duì)于那種需要后臺(tái)處理某些任務(wù),處理完成即退出是非常適合使用 IntentService 的,如:下載文件。

1.5 Android 8.0 對(duì)后臺(tái)服務(wù)的限制

上節(jié)中可以看到 IntentService 被標(biāo)記廢棄了,這是由于 Android 8.0(API 26) 以后系統(tǒng)不允許后臺(tái)應(yīng)用創(chuàng)建后臺(tái)服務(wù),創(chuàng)建后臺(tái)服務(wù)需要使用 JobScheduler 來由系統(tǒng)進(jìn)行調(diào)度任務(wù)的執(zhí)行。那么怎樣應(yīng)用會(huì)被認(rèn)定為后臺(tái)呢?

如果滿足以下任意條件,應(yīng)用將被視為處于前臺(tái):

  • 具有可見 Activity (不管該 Activity 已啟動(dòng)還是已暫停);
  • 具有前臺(tái)服務(wù);
  • 另一個(gè)前臺(tái)應(yīng)用已關(guān)聯(lián)到該應(yīng)用(不管是通過綁定到其中一個(gè)服務(wù),還是通過使用其中一個(gè)內(nèi)容提供程序);
  • IME;
  • 壁紙服務(wù);
  • 通知偵聽器;
  • 語音或文本服務(wù)。

如果以上條件均不滿足,應(yīng)用將被視為處于后臺(tái)。

因此,Android 8.0 引入了一種全新的方法,即 Context.startForegroundService() 以在前臺(tái)啟動(dòng)新服務(wù)。系統(tǒng)創(chuàng)建服務(wù)后應(yīng)在五秒的時(shí)間內(nèi)調(diào)用該服務(wù)的 startForeground() 方法以顯示新服務(wù)的用戶可見通知。如果未在此時(shí)間限制內(nèi)未調(diào)用 startForeground() 方法,則系統(tǒng)將停止服務(wù)并聲明此應(yīng)用為 ANR。

但在一些特殊情況下,還是可以創(chuàng)建后臺(tái)服務(wù)的:

  • 處理對(duì)用戶可見的任務(wù)時(shí),后臺(tái)應(yīng)用將被置于一個(gè)臨時(shí)白名單中并持續(xù)數(shù)分鐘。位于白名單中時(shí),應(yīng)用可以無限制地啟動(dòng)服務(wù),并且其后臺(tái)服務(wù)也可以運(yùn)行。
    • 處理一條高優(yōu)先級(jí) Firebase 云消息傳遞 (FCM) 消息;
    • 接收廣播,例如短信/彩信消息;
    • 從通知執(zhí)行 PendingIntent。
  • bindService() 方法不受后臺(tái)限制。

1.5.1 前臺(tái)服務(wù)

使用步驟:

  • 添加權(quán)限

    創(chuàng)建一個(gè)前臺(tái)服務(wù),首先需要請(qǐng)求前臺(tái)服務(wù)權(quán)限(Android 9 - API 級(jí)別 28 及以上 ),如下:

<manifest xmlns:android="http://schemas.android.com/apk/res/android" ...>

    <uses-permission android:name="android.permission.FOREGROUND_SERVICE"/>

    <application ...>
        ...
    </application>
</manifest>
  • 這是一個(gè)正常的權(quán)限,系統(tǒng)會(huì)自動(dòng)將其授予請(qǐng)求的應(yīng)用程序。

  • 創(chuàng)建前臺(tái)服務(wù)

    創(chuàng)建一個(gè)前臺(tái)服務(wù)與創(chuàng)建一個(gè)正常服務(wù)沒太大區(qū)別,只是需要在 Service 創(chuàng)建之后調(diào)用 startForeground() 來啟動(dòng)前臺(tái)服務(wù),如下:

class TestService : Service() {
    
   override fun onCreate() {
      super.onCreate()
       
        // Android 8.0 調(diào)用 startForefround() 方法啟動(dòng)服務(wù)
        if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.O) {
            setForegroundService();
        }
   }
    
   private fun  setForegroundService() {
       
       // 創(chuàng)建通知渠道
        val CHANNEL_ID = 1
        val channelName = getString(R.string.channel_name)
       // 設(shè)置通知的優(yōu)先級(jí)
        val importance = NotificationManager.IMPORTANCE_LOW
        val channel = NotificationChannel(CHANNEL_ID, channelName, importance)
        val notificationManager = getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager
        notificationManager.createNotificationChannel(channel)

       // 設(shè)置前臺(tái)服務(wù)通知的點(diǎn)擊事件
       val pendingIntent: PendingIntent =
        Intent(this, ExampleActivity::class.java).let { notificationIntent ->
            PendingIntent.getActivity(this, 0, notificationIntent, 0)
        }
       
       // 創(chuàng)建通知
        val notification: Notification = NotificationCompat.Builder(this, CHANNEL_ID)
                .setContentTitle(getText(R.string.notification_title))
                .setContentText(getText(R.string.notification_message))
                .setSmallIcon(R.drawable.icon)
                .setContentIntent(pendingIntent)
                .setTicker(getText(R.string.ticker_text))
                .build()

        // Notification ID cannot be 0.
        startForeground(NOTIFICATION_ID, notification)
   }

   override fun onBind(intent: Intent): IBinder? {
		return null
   }
}
  • 在這里有兩個(gè)點(diǎn)需要注意一下:

    Android 8.0 以上創(chuàng)建通知需要先創(chuàng)建通知渠道,再使用渠道 id 創(chuàng)建通知

    前臺(tái)服務(wù)的通知優(yōu)先級(jí)必須為 PRIORITY_LOW 或更高,通知優(yōu)先級(jí)詳細(xì)見設(shè)置渠道的重要性級(jí)別

  • 注冊(cè)服務(wù)

<manifest xmlns:android="http://schemas.android.com/apk/res/android" ...>

    <application ...>

        <service
            android:name="com.hl.myplugin.TestService"
            android:enabled="true"
            android:exported="false" />
    </application>

</manifest>

聲明前臺(tái)服務(wù)類型

如果在 Android 10(API 級(jí)別 29)或更高版本訪問前臺(tái)服務(wù)中的位置信息,則需要聲明 <service> 組件的前臺(tái)服務(wù)類型為 location;

如果在 Android 11(API 級(jí)別 30)或更高版本訪問前臺(tái)服務(wù)中的攝像頭或麥克風(fēng),則需要聲明 <service> 組件的前臺(tái)服務(wù)類型為 camera 或 microphone。

<manifest xmlns:android="http://schemas.android.com/apk/res/android" ...>

    <application ...>

        <service ...
            android:foregroundServiceType="location|camera|microphone"/>
    </application>

</manifest>

在運(yùn)行時(shí),如果前臺(tái)服務(wù)只需要訪問清單中聲明的類型的子集,則可以使用以下代碼片段中的邏輯來限制服務(wù)的訪問:

val notification: Notification = ...
// 開啟前臺(tái)服務(wù)的重載方法
startForeground(NOTIFICATION_ID, notification, FOREGROUND_SERVICE_TYPE_LOCATION or FOREGROUND_SERVICE_TYPE_CAMERA)

但 Android 11(API 級(jí)別 30)為了幫助保護(hù)用戶隱私,對(duì)前臺(tái)服務(wù)何時(shí)可以訪問設(shè)備的位置、攝像頭或麥克風(fēng)進(jìn)行了限制。當(dāng)應(yīng)用程序在后臺(tái)運(yùn)行啟動(dòng)前臺(tái)服務(wù)時(shí),前臺(tái)服務(wù)有以下限制:

  • 除非用戶已授予應(yīng)用程序 ACCESS_BACKGROUND_LOCATION 權(quán)限,否則 前臺(tái)服務(wù)無法訪問位置。

  • 前臺(tái)服務(wù)無法訪問麥克風(fēng)或攝像頭。

如果啟動(dòng)的服務(wù)對(duì)位置、麥克風(fēng)和攝像頭的訪問受到限制,那么在調(diào)試時(shí) Logcat 中會(huì)顯示以下消息:

Foreground service started from background can not have location/camera/microphone access: service SERVICE_NAME
  • 限制豁免:

    在某些情況下,即使應(yīng)用程序在后臺(tái)運(yùn)行時(shí)啟動(dòng)了前臺(tái)服務(wù) ,它仍然可以在應(yīng)用程序在前臺(tái)運(yùn)行時(shí)(“使用中”)訪問位置、相機(jī)和麥克風(fēng)信息。在這些情況下,如果服務(wù)聲明了一個(gè) 前臺(tái)服務(wù)類型location,并且服務(wù)由一個(gè)具有ACCESS_BACKGROUND_LOCATION 權(quán)限的應(yīng)用程序啟動(dòng),那么該服務(wù)即使在后臺(tái)啟動(dòng)但在前臺(tái)運(yùn)行時(shí)仍可訪問位置信息。

    以下包含這些情況:

    • 該服務(wù)由系統(tǒng)組件啟動(dòng)。

    • 該服務(wù)通過與應(yīng)用小部件交互啟動(dòng)。

    • 該服務(wù)通過與通知交互來啟動(dòng)。

    • 該服務(wù)作為PendingIntent從不同的可見應(yīng)用程序發(fā)送的啟動(dòng) 。

    • 該服務(wù)由在設(shè)備所有者模式下運(yùn)行的設(shè)備策略控制器應(yīng)用程序啟動(dòng)。

    • 該服務(wù)由提供VoiceInteractionService.

    • 該服務(wù)由具有START_ACTIVITIES_FROM_BACKGROUND特權(quán)權(quán)限的應(yīng)用程序啟動(dòng) 。

  • 啟動(dòng)前臺(tái)服務(wù)

// Android 8.0使用 startForegroundService 在前臺(tái)啟動(dòng)服務(wù)
if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.O){
   startForegroundService(Intent(this,TestService::class.java)
}else{
  startService(Intent(this,TestService::class.java))
}
  • 移除前臺(tái)服務(wù)

    調(diào)用 stopForeground(removeNotification: Boolean) 方法即可移除前臺(tái)服務(wù),參數(shù)代表是否刪除狀態(tài)欄通知。

    注意: stopForeground() 并不會(huì)使服務(wù)停止運(yùn)行,若想停止服務(wù),仍需調(diào)用 stopService()

1.5.2 JobIntentService

由于前臺(tái)服務(wù)在通知欄上會(huì)顯示該 Service 正在運(yùn)行,這可能會(huì)帶來不好的用戶體驗(yàn)。如果還是希望使用服務(wù)在后臺(tái)默默工作、通過使用服務(wù)開啟子進(jìn)程等等,那么就可以使用 JobIntentService。

JobIntentService 用于處理被加入到隊(duì)列的 job/service 任務(wù)。當(dāng)運(yùn)行在 Android O 或更高版本時(shí),任務(wù)將作為 job 通過 JobScheduler.enqueue() 進(jìn)行分發(fā);當(dāng)運(yùn)行在較老版本的平臺(tái)上時(shí),任務(wù)仍舊會(huì)使用 Context.startService() 執(zhí)行。

使用步驟:

  • 在 Manifest 中聲明 Permission

    JobIntentService 處理了亮屏/鎖屏,因此需要在 AndroidManifest.xml 中添加 android.Manifest.permission.WAKE_LOCK 權(quán)限,如下:

<uses-permission android:name="android.permission.WAKE_LOCK" />

在 Manifest 中聲明 Service

JobIntentService 本質(zhì)上也是一個(gè) Service,因此需要在 AndroidManifest.xml 聲明,以便系統(tǒng)與之交互,如下:

<service android:name="SimpleJobIntentService" 
         android:permission="android.permission.BIND_JOB_SERVICE" > 
    ... 
</service>

創(chuàng)建 JobIntentService 的實(shí)現(xiàn)類

與 IntentService 的 onHandleIntent() 方法相似,只需重寫 onHandleWork() 方法處理相應(yīng)的邏輯即可:

class SimpleJobIntentService : JobIntentService() {

	companion object {
		private const val JOB_ID = 1

		fun enqueueWork(context: Context, work: Intent) {
			enqueueWork(context, SimpleJobIntentService::class.java, JOB_ID, work)
		}
	}

	override fun onHandleWork(intent: Intent) {
        // 具體邏輯
	}
}

啟動(dòng)服務(wù)

SimpleJobIntentService.enqueueWork(context, new Intent());

可以看出,它使用起來非常簡單,因?yàn)橐呀?jīng)封裝了大量的內(nèi)部邏輯,只需要調(diào)用 enqueueWork() 靜態(tài)方法就可以了。

2. Service 的?;?/h2>

Android 系統(tǒng)會(huì)盡可能長的延續(xù)一個(gè)應(yīng)用程序進(jìn)程,但在內(nèi)存過低的時(shí)候,仍然會(huì)不可避免需要移除舊的進(jìn)程。為了決定哪些進(jìn)程留下,哪些進(jìn)程被殺死,系統(tǒng)根據(jù)在進(jìn)程中在運(yùn)行的組件及組件的狀態(tài),為每一個(gè)進(jìn)程分配了一個(gè)優(yōu)先級(jí)等級(jí)。優(yōu)先級(jí)最低的進(jìn)程首先被殺死。這個(gè)進(jìn)程重要性的層次結(jié)構(gòu)主要有五個(gè)等級(jí)。

2.1 進(jìn)程的五個(gè)常用等級(jí):

主要分為:

  • 前臺(tái)進(jìn)程(Foreground process)

  • 可見進(jìn)程(Visible process)

  • 服務(wù)進(jìn)程 (Service process)

  • 后臺(tái)進(jìn)程 (Background process)

  • 空進(jìn)程

了解這些以后,你就能明白為啥不建議在 Activity 中開線程處理耗時(shí)任務(wù)?

主要原因如下:

  • Activity 中開線程做耗時(shí)操作,切到桌面會(huì)變成后臺(tái)進(jìn)程
  • 啟動(dòng) Service 新建線程處理耗時(shí)任務(wù),這時(shí)會(huì)變?yōu)榉?wù)進(jìn)程

因?yàn)榉?wù)進(jìn)程的優(yōu)先級(jí)比后臺(tái)進(jìn)程的優(yōu)先級(jí)高,所以此方式處理耗時(shí)任務(wù)更好。 同時(shí),使用 Service 將會(huì)保證 app 至少有服務(wù)進(jìn)程的優(yōu)先級(jí)。

2.1.1 前臺(tái)進(jìn)程

前臺(tái)進(jìn)程是用戶當(dāng)前做的事所必須的進(jìn)程,如果滿足下面各種情況中的一種,一個(gè)進(jìn)程被認(rèn)為是在前臺(tái):

  • 進(jìn)程持有一個(gè)正在與用戶交互的 Activity。

  • 進(jìn)程持有一個(gè) Service,這個(gè) Service 處于這幾種狀態(tài):

    • Service 與用戶正在交互的 Activity 綁定。

    • Service 是在前臺(tái)運(yùn)行的,即它調(diào)用了 startForeground()。

    • Service 正在執(zhí)行它的生命周期回調(diào)函數(shù) —— onCreate()、 onStart()onDestroy()。

  • 進(jìn)程持有一個(gè) BroadcastReceiver,這個(gè) BroadcastReceiver 正在執(zhí)行它的 onReceive() 方法。

殺死前臺(tái)進(jìn)程需要用戶交互,因?yàn)榍芭_(tái)進(jìn)程的優(yōu)先級(jí)是最高的。

2.1.2 可見進(jìn)程

如果一個(gè)進(jìn)程不含有任何前臺(tái)的組件,但仍可被用戶在屏幕上所見。當(dāng)滿足如下任一條件時(shí),進(jìn)程被認(rèn)為是可見的:

  • 進(jìn)程持有一個(gè) Activity,這個(gè) Activity 不在前臺(tái),但是仍然被用戶可見,即處于 onPause() 狀態(tài)。

  • 進(jìn)程持有一個(gè) Service,這個(gè) Service 和一個(gè)可見的 Activity 綁定。

可見的進(jìn)程也被認(rèn)為是很重要的,一般不會(huì)被銷毀,除非是為了保證所有前臺(tái)進(jìn)程的運(yùn)行而不得不殺死可見進(jìn)程的時(shí)候。

2.1.3 服務(wù)進(jìn)程

如果一個(gè)進(jìn)程中運(yùn)行著一個(gè) Service,這個(gè) Service 是通過 startService() 開啟的,并且不屬于上面兩種較高優(yōu)先級(jí)的情況(未進(jìn)行任何綁定),這個(gè)進(jìn)程就是一個(gè)服務(wù)進(jìn)程。

盡管服務(wù)進(jìn)程沒有和用戶可以看到的東西綁定,但是它們一般在做的事情是用戶關(guān)心的,比如后臺(tái)播放音樂,后臺(tái)下載數(shù)據(jù)等。所以系統(tǒng)會(huì)盡量維持它們的運(yùn)行,除非系統(tǒng)內(nèi)存不足以維持前臺(tái)進(jìn)程和可見進(jìn)程的運(yùn)行需要。

2.1.4 后臺(tái)進(jìn)程

如果進(jìn)程不屬于上面三種情況,但是它持有一個(gè)用戶不可見的activity(Activity的 onStop() 被調(diào)用,但是 onDestroy() 沒有調(diào)用的狀態(tài)),就認(rèn)為進(jìn)程是一個(gè)后臺(tái)進(jìn)程。

后臺(tái)進(jìn)程不直接影響用戶體驗(yàn),系統(tǒng)會(huì)為了前臺(tái)進(jìn)程、可見進(jìn)程、服務(wù)進(jìn)程而任意殺死后臺(tái)進(jìn)程。

通常會(huì)有很多個(gè)后臺(tái)進(jìn)程存在,它們會(huì)被保存在一個(gè) LRU (least recently used) 列表中,這樣就可以確保用戶最近使用的 Activity 最后被銷毀,即最先銷毀時(shí)間最遠(yuǎn)的 Activity。

2.1.5 空進(jìn)程

如果一個(gè)進(jìn)程不包含任何活躍的應(yīng)用組件,則認(rèn)為是空進(jìn)程。

例如:一個(gè)進(jìn)程當(dāng)中已經(jīng)沒有數(shù)據(jù)在運(yùn)行,但是內(nèi)存當(dāng)中還為這個(gè)應(yīng)用駐留了一個(gè)進(jìn)程空間。

保存這種進(jìn)程的唯一理由是為了緩存的需要,為了加快下次要啟動(dòng)這個(gè)進(jìn)程中的組件時(shí)的啟動(dòng)時(shí)間。系統(tǒng)為了平衡進(jìn)程緩存和底層內(nèi)核緩存的資源,經(jīng)常會(huì)殺死空進(jìn)程。

2.2 Service ?;畹某S眉记?/h3>
  • 設(shè)置最高優(yōu)先級(jí)
<service  
     android:name="com.dbjtech.acbxt.waiqin.UploadService"  
     android:enabled="true" >  
     <intent-filter android:priority="1000" >  
         <action android:name="xxxx" />  
     </intent-filter>  
</service>
  • 如上,Service 對(duì)于 intent-filter 可以通過 android:priority = “1000” 這個(gè)屬性設(shè)置最高優(yōu)先級(jí),1000是最高值,如果數(shù)字越小則優(yōu)先級(jí)越低,同時(shí)適用于廣播。

  • 使用前臺(tái)服務(wù)

    Service 創(chuàng)建時(shí)通過 startForeground() 方法把 Service 提升為前臺(tái)進(jìn)程級(jí)別,在 onDestroy() 里面要記得調(diào)用 stopForeground() 方法。

  • 復(fù)寫onStartCommand() 方法,返回 START_STICKY

    當(dāng) Service 因內(nèi)存不足被 kill,當(dāng)內(nèi)存又有的時(shí)候,Service 就會(huì)被重新創(chuàng)建啟動(dòng)。

    注意:但是不能保證任何情況下都被重建,比如進(jìn)程被干掉了….

  • onDestroy() 方法里發(fā)廣播重啟 Service

    Service + Broadcast 方式,就是當(dāng) Service 走 onDestory() 的時(shí)候,發(fā)送一個(gè)自定義的廣播,當(dāng)收到廣播的時(shí)候,重新啟動(dòng) Service。

    注意:第三方應(yīng)用或是在 setting 里-應(yīng)用-強(qiáng)制停止時(shí),APP 進(jìn)程就直接被干掉了,onDestroy() 方法都進(jìn)不來,所以無法保證會(huì)執(zhí)行

  • 監(jiān)聽系統(tǒng)廣播判斷 Service 狀態(tài)

    通過系統(tǒng)的一些廣播,比如:手機(jī)重啟、界面喚醒、應(yīng)用狀態(tài)改變等等監(jiān)聽并捕獲,然后判斷我們的 Service 是否還存活決定是否重新啟動(dòng)。

  • Application 加上 Persistent 屬性

    該屬性相當(dāng)于將該進(jìn)程設(shè)置為常駐內(nèi)存進(jìn)程,即系統(tǒng)應(yīng)用。一般為安裝在/system/app下的 app,正常的三方應(yīng)用安裝在 /data/app 下。

3. AIDL 的使用

Android 接口定義語言 (AIDL),利用它定義客戶端與服務(wù)均認(rèn)可的編程接口,以便二者使用進(jìn)程間通信 (IPC) 進(jìn)行相互通信。

跨進(jìn)程通信 (IPC) 的方式很多,AIDL 是其中一種。還有 Binder、文件共享、Messenger、ContentProviderSocket 等進(jìn)程間通信的方式。AIDL 是接口定義語言,只是一個(gè)工具。具體通信還是得用Binder 來進(jìn)行。Binder 是 Android 獨(dú)有的跨進(jìn)程通信方式,只需要一次拷貝,更快速和安全。

官方推薦用 Messenger 來進(jìn)行跨進(jìn)程通信,但是 Messenger 是以串行的方式來處理客戶端發(fā)來的消息,如果大量的消息同時(shí)發(fā)送到服務(wù)端,服務(wù)端仍然只能一個(gè)個(gè)處理。因此對(duì)于大量的并發(fā)請(qǐng)求,這種情況就得用 AIDL 。其實(shí) Messenger 的底層也是 AIDL,只不過系統(tǒng)做了層封裝,簡化使用。

3.1 Messenger (串行處理)

3.1.1 服務(wù)端

  • 創(chuàng)建一個(gè) Handler 對(duì)象,并實(shí)現(xiàn) hanlemessage 方法,用于接收來自客戶端的消息,并作處理
  • 創(chuàng)建一個(gè) Messenger,封裝 Handler
  • messenger.getBinder() 方法獲取一個(gè) IBinder 對(duì)象,通過 onBind 返回給客戶端

使用示例如下:

public class MessengerService extends Service {
    
    // 存儲(chǔ)客戶端發(fā)送的 Messenger 對(duì)象
    ArrayList<Messenger> mClients = new ArrayList<Messenger>();
    
    int mValue = 0;
    
    /**
     *  客戶端請(qǐng)求注冊(cè) Messenger 
     */
    static final int MSG_REGISTER_CLIENT = 1;
    
    /**
     * 客戶端請(qǐng)求反注冊(cè) Messenger 
     */
    static final int MSG_UNREGISTER_CLIENT = 2;
    

    /**
     * 客戶端請(qǐng)求設(shè)值,相當(dāng)于請(qǐng)求其他命令
     */
    static final int MSG_SET_VALUE = 3;
    

    class IncomingHandler extends Handler {
        
        @Override
        public void handleMessage(Message msg) {
            switch (msg.what) {
                case MSG_REGISTER_CLIENT:
                    mClients.add(msg.replyTo);
                    break;
                case MSG_UNREGISTER_CLIENT:
                    mClients.remove(msg.replyTo);
                    break;
                case MSG_SET_VALUE:
                    mValue = msg.arg1;
                    for (int i=mClients.size()-1; i>=0; i--) {
                        try {
                            // 取得客戶端傳送的 Messenger,發(fā)送消息回 Messenger 實(shí)現(xiàn)雙向通信
                            mClients.get(i).send(Message.obtain(null, MSG_SET_VALUE, mValue, 0));
                        } catch (RemoteException e) {
							// 客戶端有可能在此過程中死了產(chǎn)生異常,需要移除
                            mClients.remove(i);
                        }
                    }
                    break;
                default:
                    super.handleMessage(msg);
            }
        }
    }
    
    final Messenger mMessenger = new Messenger(new IncomingHandler());
    
    @Override
    public IBinder onBind(Intent intent) {
        return mMessenger.getBinder();
    }
}

注意:該Service 在聲明時(shí)必須對(duì)外開放,即 android:exported="true"

3.1.2 客戶端

  • 在 Activity 中綁定服務(wù)
  • 創(chuàng)建 ServiceConnection ,在其 onServiceConnected() 方法中通過參數(shù) IBinder 將 Messenger 實(shí)例化
  • 使用 Messenger 向服務(wù)端發(fā)送命令,或需要接收服務(wù)器端的返回信息,則還要?jiǎng)?chuàng)建一個(gè) Messenger(handler),并將這個(gè) Messenger 傳遞給服務(wù)端,在handler 中接收處理服務(wù)端的消息,這就實(shí)現(xiàn)了客戶端和服務(wù)端的雙向通信

使用示例如下:

public class MessengerServiceActivities extends Activity{

    // 向服務(wù)端發(fā)送命令的 Messenger
    private Messenger mService = null;
    
    private boolean mIsBound;
    
    private TextView mCallbackText;
    
    private class IncomingHandler extends Handler {
        @Override
        public void handleMessage(Message msg) {
            switch (msg.what) {
                case MessengerService.MSG_SET_VALUE:
                    mCallbackText.setText("Received from service: " + msg.arg1);
                    break;
                default:
                    super.handleMessage(msg);
            }
        }
    }
    
    // 接收服務(wù)端返回消息的 Messenger
    private final Messenger mMessenger = new Messenger(new IncomingHandler());

    private ServiceConnection mConnection = new ServiceConnection() {
        
        public void onServiceConnected(ComponentName className, IBinder service) {
			// 連接時(shí)獲取與服務(wù)端交互的 Messenger
            mService = new Messenger(service);
            mCallbackText.setText("Attached.");

            try {
                // 將需要接收服務(wù)端返回消息的 Messenger 發(fā)送在消息體中
                Message msg = Message.obtain(null, MessengerService.MSG_REGISTER_CLIENT);
                msg.replyTo = mMessenger;
                mService.send(msg);
                
                // 向服務(wù)端發(fā)送設(shè)值命令
                msg = Message.obtain(null, MessengerService.MSG_SET_VALUE, this.hashCode(), 0);
                mService.send(msg);
            } catch (RemoteException e) {
                // xxx
            }

            Toast.makeText(this, R.string.remote_service_connected, Toast.LENGTH_SHORT).show();
        }
        
        public void onServiceDisconnected(ComponentName className) {
            mService = null;
            mCallbackText.setText("Disconnected.");
            Toast.makeText(this, R.string.remote_service_disconnected,Toast.LENGTH_SHORT).show();
        }
    };
    
    void doBindService() {
        bindService(new Intent(this, MessengerService.class), mConnection, Context.BIND_AUTO_CREATE);
        mIsBound = true;
        mCallbackText.setText("Binding.");
    }
    
    void doUnbindService() {
        if (mIsBound) {
            if (mService != null) {
                try {
                    // 解綁時(shí)移除服務(wù)端中添加的 Messenger,取消消息接收
                    Message msg = Message.obtain(null, MessengerService.MSG_UNREGISTER_CLIENT);
                    msg.replyTo = mMessenger;
                    mService.send(msg);
                } catch (RemoteException e) {
                    //xxx
                }
            }
            
            unbindService(mConnection);
            mIsBound = false;
            mCallbackText.setText("Unbinding.");
        }
    }
}

3.2 AIDL(并行處理)

步驟:

  • 創(chuàng)建 .aidl 文件:

    定義 AIDL 接口

  • 實(shí)現(xiàn)接口:

    Android SDK 工具會(huì)基于 .aidl 文件,使用 Java 編程語言生成繼承自 IInterface 接口的接口。生成的接口擁有一個(gè)繼承自 Binder 類名為 Stub 的內(nèi)部抽象類,并聲明 AIDL 接口中的抽象方法。大概結(jié)構(gòu)如下:

public interface IInterface{
    public IBinder asBinder();
}

public interface xxxInterface extends android.os.IInterface{

    public static abstract class Stub extends android.os.Binder implements xxxInterface{
        
        @Override 
        public android.os.IBinder asBinder() {
          	return this;
        }
        
        xxxx
    }
    
    // AIDL 中聲明的抽象方法
    xxxx
}
  • 向客戶端公開接口:

    實(shí)現(xiàn) Service 并重寫 onBind(),從而返回 Stub 類的實(shí)現(xiàn).

3.2.1 定義 AIDL 接口

src/main 下面創(chuàng)建 aidl 目錄,然后新建 IPersonManager.aidl 文件,里面聲明方法用于客戶端調(diào)用,服務(wù)端實(shí)現(xiàn)。如下:

package com.xfhy.allinone.ipc.aidl;
import com.xfhy.allinone.ipc.aidl.Person;
interface IPersonManager {
    List<Person> getPersonList();
    //in: 從客戶端流向服務(wù)端
    boolean addPerson(in Person person);
}

這個(gè)接口和平常我們定義接口時(shí)差別不是很大,需要注意的是即使 Person 和 PersonManager 在同一個(gè)包下面還是得導(dǎo)包,這是AIDL的規(guī)則。

  • AIDL 支持的數(shù)據(jù)類型

    在 AIDL 文件中,不是所有數(shù)據(jù)類型都是可以使用的,支持的數(shù)據(jù)類型如下:

    • Java 編程語言中的所有原語類型(如 int、long、char、boolean 等)

    • String 和 CharSequence

    • List:只支持 ArrayList,里面每個(gè)元素都必須能夠被 AIDL 支持

    • Map:只支持HashMap,里面的每個(gè)元素都必須被 AIDL 支持,包括 key 和 value

    • Parcelable:所有實(shí)現(xiàn)了Parcelable接口的對(duì)象

    • AIDL:所有的AIDL接口本身也可以在 AIDL 文件中使用

  • 定義傳輸?shù)膶?duì)象

    在 kotlin 或 Java 這邊需要定義好這個(gè)需要傳輸?shù)膶?duì)象 Person,,或者定義在 aidl 目錄下, 但需要通過 sourceSet{} 將此目錄定義為 kotlin 或 java 源碼目錄,這里以在 kotlin 下為示例:

class Person(var name: String? = "") : Parcelable {
    constructor(parcel: Parcel) : this(parcel.readString())

    override fun toString(): String {
        return "Person(name=$name) hashcode = ${hashCode()}"
    }

    override fun writeToParcel(parcel: Parcel, flags: Int) {
        parcel.writeString(name)
    }

    fun readFromParcel(parcel: Parcel) {
        this.name = parcel.readString()
    }

    override fun describeContents(): Int {
        return 0
    }

    companion object CREATOR : Parcelable.Creator<Person> {
        override fun createFromParcel(parcel: Parcel): Person {
            return Person(parcel)
        }

        override fun newArray(size: Int): Array<Person?> {
            return arrayOfNulls(size)
        }
    }

然后得在 aidl 的相同目錄下也需要聲明一下這個(gè) Person 對(duì)象,新建一個(gè) Person.aidl:

package com.xfhy.allinone.ipc.aidl;

parcelable Person;

注意:當(dāng)需要傳遞對(duì)象時(shí),則該對(duì)象必須實(shí)現(xiàn) Parcelable 接口并且需要指示數(shù)據(jù)走向的方向標(biāo)記

方向標(biāo)記意義
in數(shù)據(jù)只能由客戶端流向服務(wù)端,服務(wù)端修改數(shù)據(jù)不會(huì)同步返回
out數(shù)據(jù)只能由服務(wù)端流向客戶端,客戶端會(huì)新創(chuàng)建一個(gè)無參對(duì)象傳遞到服務(wù)端,服務(wù)端修改數(shù)據(jù)會(huì)同步返回
inout數(shù)據(jù)可在服務(wù)端與客戶端之間雙向流通,服務(wù)端和客戶端同步共用一個(gè)對(duì)象

 

  • 原語類型(基本類型)默認(rèn)是 in,inout 開銷很大,因此慎用。調(diào)用 AIDL 生成接口的為客戶端,實(shí)現(xiàn)接口方為服務(wù)端。

    都完成了之后,rebuild 一下,AS 會(huì)自動(dòng)生成IPersonManager.java 接口文件。

3.2.2 服務(wù)端實(shí)現(xiàn)接口

定義一個(gè) Service, 然后將其 process 設(shè)置成一個(gè)新的進(jìn)程,與主進(jìn)程區(qū)分開,模擬跨進(jìn)程訪問,它里面需要實(shí)現(xiàn) .aidl 生成的接口,如下:

class RemoteService : Service() {

    private val mPersonList = mutableListOf<Person?>()

    private val mBinder: Binder = object : IPersonManager.Stub() {
        
        override fun getPersonList(): MutableList<Person?> = mPersonList

        override fun addPerson(person: Person?): Boolean {
            return mPersonList.add(person)
        }
    }

    override fun onBind(intent: Intent?): IBinder? {
        return mBinder
    }

    override fun onCreate() {
        super.onCreate()
        mPersonList.add(Person("Garen"))
        mPersonList.add(Person("Darius"))
    }
}

實(shí)現(xiàn)的 IPersonManager.Stub 是一個(gè) Binder,需要通過 onBind() 返回,客戶端需要通過這個(gè) Binder 來跨進(jìn)程調(diào)用 Service 這邊的服務(wù)。

3.2.3 客戶端與服務(wù)端進(jìn)行通信

客戶端這邊需要通過 bindService() 來連接此 Service,進(jìn)而實(shí)現(xiàn)通信??蛻舳说?onServiceConnected() 回調(diào)會(huì)接收 Service 的 onBind() 方法所返回的 binder 實(shí)例。再調(diào)用 XxxInterface.Stub.asInterface(service) 就能轉(zhuǎn)換取得 XxxInterface 實(shí)例。如下:

class AidlActivity : TitleBarActivity() {

    companion object {
        const val TAG = "xfhy_aidl"
    }

    private var remoteServer: IPersonManager? = null

    private val serviceConnection = object : ServiceConnection {
        override fun onServiceConnected(name: ComponentName?, service: IBinder?) {
            log(TAG, "onServiceConnected")
            //在onServiceConnected調(diào)用IPersonManager.Stub.asInterface 獲取接口類型的實(shí)例
            //通過這個(gè)實(shí)例調(diào)用服務(wù)端的服務(wù)
            remoteServer = IPersonManager.Stub.asInterface(service)
        }

        override fun onServiceDisconnected(name: ComponentName?) {
            log(TAG, "onServiceDisconnected")
        }
    }

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_aidl)

        btnConnect.setOnClickListener {
            connectService()
        }
        btnGetPerson.setOnClickListener {
            getPerson()
        }
        btnAddPerson.setOnClickListener {
            addPerson()
        }
    }

    private fun connectService() {
        val intent = Intent()
        //action 和 package(app的包名)
        intent.action = "com.xfhy.aidl.Server.Action"
        intent.setPackage("com.xfhy.allinone")
        val bindServiceResult = bindService(intent, serviceConnection, Context.BIND_AUTO_CREATE)
        log(TAG, "bindService $bindServiceResult")

        //如果targetSdk是30,那么需要處理Android 11中的程序包可見性  具體參見:        https://developer.android.com/about/versions/11/privacy/package-visibility
    }

    private fun addPerson() {
        //客戶端調(diào)服務(wù)端方法時(shí),需要捕獲以下幾個(gè)異常:
        //RemoteException 異常:
        //DeadObjectException 異常:連接中斷時(shí)會(huì)拋出異常;
        //SecurityException 異常:客戶端和服務(wù)端中定義的 AIDL 發(fā)生沖突時(shí)會(huì)拋出異常;
        try {
            val addPersonResult = remoteServer?.addPerson(Person("蓋倫"))
            log(TAG, "addPerson result = $addPersonResult")
        } catch (e: RemoteException) {
            e.printStackTrace()
        } catch (e: DeadObjectException) {
            e.printStackTrace()
        } catch (e: SecurityException) {
            e.printStackTrace()
        }
    }

    private fun getPerson() {
        val personList = remoteServer?.personList
        log(TAG, "person 列表 $personList")
    }

    override fun onDestroy() {
        super.onDestroy()
        //最后記得unbindService
        unbindService(serviceConnection)
    }
}

測試時(shí)先 getPerson 再 addPerson 最后 getPerson,輸出日志:

2020-12-24 12:41:00.170 24785-24785/com.xfhy.allinone D/xfhy_aidl: bindService true
2020-12-24 12:41:00.906 24785-24785/com.xfhy.allinone D/xfhy_aidl: onServiceConnected
2020-12-24 12:41:04.253 24785-24785/com.xfhy.allinone D/xfhy_aidl: person 列表 [Person(name=Garen), Person(name=Darius)]
2020-12-24 12:41:05.952 24785-24785/com.xfhy.allinone D/xfhy_aidl: addPerson result = true
2020-12-24 12:41:09.022 24785-24785/com.xfhy.allinone D/xfhy_aidl: person 列表 [Person(name=Garen), Person(name=Darius), Person(name=蓋倫)]

注意:在客戶端調(diào)用這些遠(yuǎn)程方法時(shí)是同步調(diào)用,在主線程調(diào)用可能會(huì)導(dǎo)致 ANR,應(yīng)該在子線程去調(diào)用。

3.2.4 oneway 關(guān)鍵字(異步)

將 aidl 接口的方法前加上 oneway 關(guān)鍵字則這個(gè)方法就是異步調(diào)用,不會(huì)阻塞調(diào)用線程。當(dāng)客戶端調(diào)用服務(wù)端的方法不需要知道返回結(jié)果時(shí),使用異步調(diào)用可以提高客戶端的執(zhí)行效率。

3.2.5 線程安全

AIDL 的方法是在服務(wù)端的 Binder 線程池中執(zhí)行的,所以多個(gè)客戶端同時(shí)進(jìn)行連接且操作數(shù)據(jù)時(shí)可能存在多個(gè)線程同時(shí)訪問的情形。這時(shí)就需要在服務(wù)端 AIDL 方法中處理多線程同步問題。

先看下服務(wù)端的 AIDL 方法是在哪個(gè)線程中:

override fun addPerson(person: Person?): Boolean {
    log(TAG, "服務(wù)端 addPerson() 當(dāng)前線程 : ${Thread.currentThread().name}")
    return mPersonList.add(person)
}

//日志輸出
服務(wù)端 addPerson() 當(dāng)前線程 : Binder:3961_3

可以看到,確實(shí)是在非主線程中執(zhí)行的,那確實(shí)會(huì)存在多線程安全問題。這就需要將 mPersonList 的類型修改為 CopyOnWriteArrayList,以確保線程安全:

//服務(wù)端
private val mPersonList = CopyOnWriteArrayList<Person?>()

override fun getPersonList(): MutableList<Person?> = mPersonList

//客戶端
private fun getPerson() {
    val personList = remoteServer?.personList
    personList?.let {
        log(TAG, "personList ${it::class.java}")
    }
}

//輸出日志
personList class java.util.ArrayList

另外還有 ConcurrentHashMap 也是同樣的道理,這里就不驗(yàn)證了。

3.2.6 AIDL 監(jiān)聽器(觀察者? 雙向通信?)

上面的案例中,只能在客戶端每次去調(diào)服務(wù)端的方法然后獲得結(jié)果。若想服務(wù)端數(shù)據(jù)有變動(dòng)就通知一下客戶端,這就需要添加監(jiān)聽器了。

因?yàn)檫@個(gè)監(jiān)聽器 Listener 是需要跨進(jìn)程的,這里首先就需要為這個(gè) Listener 創(chuàng)建一個(gè) aidl 的回調(diào)接口IPersonChangeListener.aidl

interface IPersonChangeListener {
 	 // 這里由服務(wù)端調(diào)用此接口,因此服務(wù)端其實(shí)充當(dāng) "Client",數(shù)據(jù)流通方向標(biāo)記為 in 更合理
	  void onPersonDataChanged(in Person person);
}

有了監(jiān)聽器,還需要在 IPersonManager.aidl 中加上注冊(cè)/反注冊(cè)監(jiān)聽的方法:

interface IPersonManager {
    ......
    void registerListener(IPersonChangeListener listener);
    void unregisterListener(IPersonChangeListener listener);
}

現(xiàn)在我們?cè)诜?wù)端實(shí)現(xiàn)這個(gè)注冊(cè)/反注冊(cè)的方法,這還不簡單嗎? 搞一個(gè) List<IPersonChangeListener> 來存放 Listener 集合,當(dāng)數(shù)據(jù)變化的時(shí)候遍歷這個(gè)集合,通知一下這些Listener就行。

仔細(xì)想想這樣真的行嗎? 這個(gè) IPersonChangeListener 是需要跨進(jìn)程的,那么客戶端每次傳過來的對(duì)象是經(jīng)過序列化與反序列化的,服務(wù)端這邊接收到的根本不是客戶端傳過來的那個(gè)對(duì)象。 雖然傳過來的 Listener 不同,但是用來通信的 Binder 是同一個(gè),利用這個(gè)原理 Android 提供了一個(gè) RemoteCallbackList 的東西,專門用于存放監(jiān)聽接口的集合的。RemoteCallbackList 內(nèi)部將數(shù)據(jù)存儲(chǔ)于一個(gè) ArrayMap 中,key 就是用來傳輸?shù)?binder,value 就是監(jiān)聽接口的封裝。如下:

//RemoteCallbackList.java  源碼有刪減
public class RemoteCallbackList<E extends IInterface> {
    ArrayMap<IBinder, Callback> mCallbacks = new ArrayMap<IBinder, Callback>();

    private final class Callback implements IBinder.DeathRecipient {
        final E mCallback;
        final Object mCookie;

        Callback(E callback, Object cookie) {
            mCallback = callback;
            mCookie = cookie;
        }
    }

    public boolean register(E callback, Object cookie) {
        synchronized (mCallbacks) {
            IBinder binder = callback.asBinder();
            Callback cb = new Callback(callback, cookie);
            mCallbacks.put(binder, cb);
            return true;
        }
    }
}

RemoteCallbackList 內(nèi)部在操作數(shù)據(jù)的時(shí)候已經(jīng)做了線程同步的操作,所以不需要單獨(dú)做額外的線程同步操作?,F(xiàn)在來實(shí)現(xiàn)一下這個(gè)注冊(cè)/反注冊(cè)方法:

private val mListenerList = RemoteCallbackList<IPersonChangeListener?>()

private val mBinder: Binder = object : IPersonManager.Stub() {
    .....
    override fun registerListener(listener: IPersonChangeListener?) {
        mListenerList.register(listener)
    }

    override fun unregisterListener(listener: IPersonChangeListener?) {
        mListenerList.unregister(listener)
    }
}

RemoteCallbackList 添加與刪除數(shù)據(jù)對(duì)應(yīng)著 register()/unregister()方法,然后我們模擬一下服務(wù)端數(shù)據(jù)更新的情況,開個(gè)線程每隔 5 秒添加一個(gè) Person 數(shù)據(jù),然后通知一下觀察者:

//死循環(huán) 每隔5秒添加一次person,通知觀察者
private val serviceWorker = Runnable {
    while (!Thread.currentThread().isInterrupted) {
        Thread.sleep(5000)
        val person = Person("name${Random().nextInt(10000)}")
        log(AidlActivity.TAG, "服務(wù)端 onDataChange() 生產(chǎn)的 person = $person}")
        mPersonList.add(person)
        onDataChange(person)
    }
}
private val mServiceListenerThread = Thread(serviceWorker)

//數(shù)據(jù)變化->通知觀察者
private fun onDataChange(person: Person?) {
    //1. 使用RemoteCallbackList時(shí),必須首先調(diào)用beginBroadcast(), 最后調(diào)用finishBroadcast(). 得成對(duì)出現(xiàn)
    //這里拿到的是監(jiān)聽器的數(shù)量
    val callbackCount = mListenerList.beginBroadcast()
    for (i in 0 until callbackCount) {
        try {
            //這里try一下避免有異常時(shí)無法調(diào)用finishBroadcast()
            mListenerList.getBroadcastItem(i)?.onPersonDataChanged(person)
        } catch (e: RemoteException) {
            e.printStackTrace()
        }
    }
    
    //3. 最后調(diào)用finishBroadcast()  必不可少
    mListenerList.finishBroadcast()
}

override fun onCreate() {
    .....
    mServiceListenerThread.start()
}

override fun onDestroy() {
    super.onDestroy()
    mServiceListenerThread.interrupt()
}

服務(wù)端實(shí)現(xiàn)好了,客戶端就比較好辦:

private val mPersonChangeListener = object : IPersonChangeListener.Stub() {
    override fun onPersonDataChanged(person: Person?) {
        log(TAG, "客戶端 onPersonDataChanged() person = $person}")
    }
}

private fun registerListener() {
    remoteServer?.registerListener(mPersonChangeListener)
}

private fun unregisterListener() {
    remoteServer?.asBinder()?.isBinderAlive?.let {
        remoteServer?.unregisterListener(mPersonChangeListener)
    }
}

因?yàn)槭切枰邕M(jìn)程通信的,所以需要繼承自 IPersonChangeListener.Stub 從而生成一個(gè)監(jiān)聽器對(duì)象。最后輸出日志如下:

服務(wù)端 onDataChange() 生產(chǎn)的 person = Person(name=name9398) hashcode = 130037351}
客戶端 onPersonDataChanged() person = Person(name=name9398) hashcode = 217703225}

3.2.7 Binder 死亡通知

服務(wù)端進(jìn)程可能隨時(shí)會(huì)被殺掉,這時(shí)需要在客戶端能夠被感知到 binder 已經(jīng)死亡,從而做一些收尾清理工作或者進(jìn)程重新連接。有如下 4 種方式能知道服務(wù)端是否已經(jīng)掛掉:

  • 調(diào)用 binder 的 pingBinder() 檢查,返回 false 則說明遠(yuǎn)程服務(wù)失效
  • 調(diào)用 binder 的 linkToDeath() 注冊(cè)監(jiān)聽器,當(dāng)遠(yuǎn)程服務(wù)失效時(shí),就會(huì)收到回調(diào)
  • 綁定 Service 時(shí)用到的 ServiceConnection 有個(gè) onServiceDisconnected() 回調(diào)在服務(wù)端斷開時(shí)也能收到回調(diào)
  • 客戶端調(diào)用遠(yuǎn)程方法時(shí),拋出 DeadObjectException(RemoteException)

寫份代碼驗(yàn)證一下,在客戶端修改為如下:

private val mDeathRecipient = object : IBinder.DeathRecipient {
    
    override fun binderDied() {
        //監(jiān)聽 binder died
        log(TAG, "binder died")
        //移除死亡通知
        mService?.unlinkToDeath(this, 0)
        mService = null
        //重新連接
        connectService()
    }
}

private val serviceConnection = object : ServiceConnection {
    
    override fun onServiceConnected(name: ComponentName?, service: IBinder?) {
        this@AidlActivity.mService = service
        log(TAG, "onServiceConnected")

        //給binder設(shè)置一個(gè)死亡代理
        service?.linkToDeath(mDeathRecipient, 0)

        mRemoteServer = IPersonManager.Stub.asInterface(service)
    }

    override fun onServiceDisconnected(name: ComponentName?) {
        log(TAG, "onServiceDisconnected")
    }
}

綁定服務(wù)之后,將服務(wù)端進(jìn)程殺掉,輸出日志如下:

//第一次連接
bindService true
onServiceConnected, thread = main

//殺掉服務(wù)端 
binder died, thread = Binder:29391_3
onServiceDisconnected, thread = main

//重連
bindService true
onServiceConnected, thread = main

確實(shí)是監(jiān)聽到服務(wù)端斷開連接的時(shí)刻,然后重新連接也是 ok 的。

注意:binderDied() 方法是運(yùn)行在子線程的,onServiceDisconnected()是運(yùn)行在主線程的,如果要在這里更新UI,得注意一下。

3.2.8 權(quán)限驗(yàn)證

有沒有注意到,目前的 Service 是完全暴露的,任何 app 都可以訪問這個(gè) Service 并且遠(yuǎn)程調(diào)用 Service 的服務(wù),這樣不太安全??梢栽谇鍐挝募屑尤胱远x權(quán)限,然后在 Service 中校驗(yàn)一下客戶端有沒有這個(gè)權(quán)限即可。如下:

<permission
    android:name="com.xfhy.allinone.ipc.aidl.ACCESS_PERSON_SERVICE"
    android:protectionLevel="normal" />

客戶端需要在清單文件中聲明這個(gè)權(quán)限:

<uses-permission android:name="com.xfhy.allinone.ipc.aidl.ACCESS_PERSON_SERVICE"/>

服務(wù)端 Service 校驗(yàn)權(quán)限:

override fun onBind(intent: Intent?): IBinder? {
    val check = checkCallingOrSelfPermission("com.xfhy.allinone.ipc.aidl.ACCESS_PERSON_SERVICE")
    if (check == PackageManager.PERMISSION_DENIED) {
        log(TAG,"沒有權(quán)限")
        return null
    }
    log(TAG,"有權(quán)限")
    return mBinder
}

以上就是一文詳解在Android中Service和AIDL的使用的詳細(xì)內(nèi)容,更多關(guān)于Service和AIDL的使用的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論

男生用鸡操女生视频动漫 | 天堂av在线最新版在线| 亚洲天堂av最新网址| 欧洲亚洲欧美日韩综合| 在线播放一区二区三区Av无码| 日日夜夜大香蕉伊人| 国产亚洲精品品视频在线| 日韩精品啪啪视频一道免费| 黄色视频在线观看高清无码| 亚洲天堂第一页中文字幕| 免费啪啪啪在线观看视频| 亚洲午夜伦理视频在线| 男女啪啪啪啪啪的网站| 免费福利av在线一区二区三区| 99人妻视频免费在线| 亚洲va天堂va国产va久| 中文字幕日韩精品就在这里| 成人H精品动漫在线无码播放| 一区二区三区日本伦理| 国产白嫩美女一区二区| 精品亚洲在线免费观看| 中文字幕av一区在线观看| 国产乱弄免费视频观看| 性色av一区二区三区久久久| 水蜜桃国产一区二区三区| 亚洲av一妻不如妾| 国产剧情演绎系列丝袜高跟| 亚洲国产欧美国产综合在线| 99精品视频在线观看免费播放| 亚洲美女高潮喷浆视频| 日韩欧美亚洲熟女人妻| 国产性生活中老年人视频网站| 桃色视频在线观看一区二区 | 男女啪啪啪啪啪的网站| 成人影片高清在线观看| 久草视频在线免播放| 亚洲天堂成人在线观看视频网站| 天天操天天弄天天射| 亚洲一区二区三区久久午夜 | 日本乱人一区二区三区| 中文乱理伦片在线观看| 亚洲国产40页第21页| 毛茸茸的大外阴中国视频| 久草视频首页在线观看| 被大鸡吧操的好舒服视频免费| 亚洲一级 片内射视正片| 亚洲精品ww久久久久久| 快点插进来操我逼啊视频| 午夜久久久久久久99| 五月激情婷婷久久综合网| 国产乱子伦精品视频潮优女| 超碰97人人做人人爱| 日本性感美女视频网站| 久草视频中文字幕在线观看| 免费一级特黄特色大片在线观看| 国产九色91在线观看精品| av在线观看网址av| 黑人解禁人妻叶爱071| av久久精品北条麻妃av观看| 亚洲成人免费看电影| 国产精彩福利精品视频| 国产美女精品福利在线| 亚洲午夜电影在线观看| 成人av久久精品一区二区| 男人操女人逼逼视频网站| av线天堂在线观看| 啊啊好大好爽啊啊操我啊啊视频| 日韩亚洲高清在线观看| 五十路老熟女码av| 欧美成人综合视频一区二区| 青青热久免费精品视频在线观看| 自拍偷区二区三区麻豆| av乱码一区二区三区| 国产亚州色婷婷久久99精品| 国产精品手机在线看片| 国产欧美精品免费观看视频| 亚洲高清免费在线观看视频| 黄片色呦呦视频免费看| 天天操天天干天天日狠狠插 | a v欧美一区=区三区| 在线观看一区二区三级| 久久久久久99国产精品| 在线播放国产黄色av| 青青热久免费精品视频在线观看| 国产精品日韩欧美一区二区| 黄页网视频在线免费观看| 日韩精品啪啪视频一道免费| 精品美女福利在线观看| 国产成人自拍视频在线免费观看| 亚洲一区二区久久久人妻| 国产精品国产三级国产精东| 爆乳骚货内射骚货内射在线| 亚洲欧美另类手机在线| 老师啊太大了啊啊啊尻视频| 丝袜亚洲另类欧美变态| 91chinese在线视频| 夜夜嗨av蜜臀av| 老司机欧美视频在线看| 欧洲日韩亚洲一区二区三区| 极品粉嫩小泬白浆20p主播| 97人人妻人人澡人人爽人人精品| av中文在线天堂精品| 久久久久久99国产精品| 337p日本大胆欧美人| 久久久久91精品推荐99| 亚欧在线视频你懂的| 在线视频精品你懂的| 香蕉aⅴ一区二区三区| 午夜久久香蕉电影网| 极品性荡少妇一区二区色欲| 真实国模和老外性视频| 国产精品女邻居小骚货| 日本性感美女三级视频| 欧美偷拍自拍色图片| 蜜臀av久久久久久久| 中文字幕 码 在线视频| 国产中文精品在线观看| 天天干天天日天天干天天操| 97人人模人人爽人人喊| 色综合久久五月色婷婷综合| 天天日天天摸天天爱| 亚洲成人熟妇一区二区三区| 青草久久视频在线观看| 自拍偷拍亚洲另类色图| 9久在线视频只有精品| 精品91高清在线观看| 国产精品一二三不卡带免费视频| 午夜dv内射一区区| 播放日本一区二区三区电影| 国产午夜亚洲精品麻豆| 久久丁香婷婷六月天| av成人在线观看一区| 男女啪啪视频免费在线观看| 美女福利写真在线观看视频| av线天堂在线观看| 美女福利写真在线观看视频| 青青青青操在线观看免费| 骚逼被大屌狂草视频免费看| 中文字幕在线永久免费播放| 国产高清女主播在线| 久草福利电影在线观看| 人妻少妇精品久久久久久| ka0ri在线视频| 中文字幕熟女人妻久久久| 亚洲高清国产拍青青草原| 国产精品国产三级国产精东 | 日本黄在免费看视频| 亚洲中文字幕乱码区| 一区二区三区蜜臀在线| 2022国产精品视频| 粉嫩欧美美人妻小视频| 91极品新人『兔兔』精品新作| 好了av中文字幕在线| 美女福利写真在线观看视频| 欧美成人小视频在线免费看| 亚洲va国产va欧美va在线| 国产亚洲天堂天天一区| 精品国产乱码一区二区三区乱| 熟女91pooyn熟女| 老司机福利精品免费视频一区二区| 韩国爱爱视频中文字幕| 天天插天天色天天日| 99精品免费久久久久久久久a| 888亚洲欧美国产va在线播放| 天天操夜夜操天天操天天操 | 日本女人一级免费片| 夏目彩春在线中文字幕| 四川乱子伦视频国产vip| 亚洲最大免费在线观看| 18禁网站一区二区三区四区| 日本人竟这样玩学生妹| 国产成人小视频在线观看无遮挡 | 日韩美在线观看视频黄| mm131美女午夜爽爽爽| 亚洲精品在线资源站| 亚洲乱码中文字幕在线| yy6080国产在线视频| 色综合久久五月色婷婷综合| 国产欧美精品不卡在线| 人妻久久久精品69系列| 中文字幕亚洲久久久| 精品视频一区二区三区四区五区| 99精品国自产在线人| 福利在线视频网址导航| 97精品成人一区二区三区| 国产性色生活片毛片春晓精品 | 大香蕉大香蕉在线看| 免费高清自慰一区二区三区网站| 大香蕉玖玖一区2区| 日本高清成人一区二区三区| 在线免费视频 自拍| 久久久久久久久久久久久97| 四川乱子伦视频国产vip| 93人妻人人揉人人澡人人| 色天天天天射天天舔| 91国语爽死我了不卡| 亚洲特黄aaaa片| 成人亚洲国产综合精品| 中文字幕奴隷色的舞台50| 精品一区二区三区午夜| 99国产精品窥熟女精品| 无码日韩人妻精品久久| 色综合色综合色综合色| 少妇系列一区二区三区视频| 午夜大尺度无码福利视频| 国产91久久精品一区二区字幕| 亚洲一区二区三区精品乱码| 国产精彩福利精品视频| 欧美日本在线视频一区| 99av国产精品欲麻豆| 日韩a级黄色小视频| 日日操夜夜撸天天干| 精品亚洲在线免费观看| 国产亚洲天堂天天一区| 天天日天天爽天天爽| 亚洲国产在线精品国偷产拍| 国产va在线观看精品| 果冻传媒av一区二区三区 | 日日夜夜精品一二三| 国产又粗又黄又硬又爽| 制丝袜业一区二区三区| 夜夜嗨av一区二区三区中文字幕| 2021天天色天天干| 亚洲精品 日韩电影| 午夜精品亚洲精品五月色| 日韩av大胆在线观看| 视频一区二区三区高清在线| yellow在线播放av啊啊啊 | 天天日天天干天天要| 人人在线视频一区二区| 亚洲男人在线天堂网| 久久久久久久精品成人热| 精品亚洲中文字幕av| 搡老熟女一区二区在线观看| 日本少妇精品免费视频| 青青擦在线视频国产在线| 精品国产午夜视频一区二区| 天堂av在线官网中文| 午夜精品福利91av| 少妇被强干到高潮视频在线观看| 中文字幕高清免费在线人妻| 亚洲视频在线观看高清| www久久久久久久久久久| 日韩美女搞黄视频免费| 六月婷婷激情一区二区三区| 亚洲中文字幕国产日韩| 38av一区二区三区| 亚洲欧美激情人妻偷拍| 午夜场射精嗯嗯啊啊视频| 黄色三级网站免费下载| 亚洲国产免费av一区二区三区| 一区二区三区蜜臀在线| 成人国产小视频在线观看| 97人妻无码AV碰碰视频| 中文字幕人妻熟女在线电影| sw137 中文字幕 在线| 久久精品国产亚洲精品166m| 天天操,天天干,天天射| 中文字幕在线观看极品视频| 日韩精品二区一区久久| 国产妇女自拍区在线观看| 一本一本久久a久久精品综合不卡| 第一福利视频在线观看| 中文字幕中文字幕人妻| 1区2区3区不卡视频| 东京热男人的av天堂| 98视频精品在线观看| 特级无码毛片免费视频播放| 亚洲精品无码久久久久不卡| 在线新三级黄伊人网| www久久久久久久久久久| 国产精品视频一区在线播放| 人妻3p真实偷拍一二区| 成人sm视频在线观看| 亚洲伊人av天堂有码在线| 青草久久视频在线观看| 欧美久久一区二区伊人| 成年人该看的视频黄免费| 亚洲一区av中文字幕在线观看| 在线不卡日韩视频播放| 免费观看丰满少妇做受| 2o22av在线视频| 香蕉aⅴ一区二区三区| 青青热久免费精品视频在线观看 | 国产九色91在线视频| 欧美亚洲偷拍自拍色图| 91免费观看国产免费| 免费在线观看污污视频网站| 91综合久久亚洲综合| 免费在线黄色观看网站| 伊人综合aⅴ在线网| 干逼又爽又黄又免费的视频| 日本一二三区不卡无| 亚洲综合另类欧美久久| 中文字幕在线乱码一区二区| 亚洲国产中文字幕啊啊啊不行了| 欧美交性又色又爽又黄麻豆| 色呦呦视频在线观看视频| 中文人妻AV久久人妻水| 亚洲国产在人线放午夜| 中国熟女一区二区性xx| 在线播放 日韩 av| 好吊视频—区二区三区| 欧美一区二区三区乱码在线播放| 精品av国产一区二区三区四区 | 在线观看av2025| 久草视频在线一区二区三区资源站| 亚洲卡1卡2卡三卡四老狼| 亚洲青青操骚货在线视频| 国产日韩av一区二区在线| 色偷偷伊人大杳蕉综合网| 青青青激情在线观看视频| 99国内小视频在现欢看| 日韩一区二区电国产精品| 日韩加勒比东京热二区| 国产精品久久综合久久| 在线免费视频 自拍| 我想看操逼黄色大片| 在线免费观看靠比视频的网站| 黄片三级三级三级在线观看| 国产在线免费观看成人| 亚洲精品午夜久久久久| 美女福利写真在线观看视频| 少妇被强干到高潮视频在线观看| 亚洲欧美清纯唯美另类 | 91she九色精品国产| tube69日本少妇| 一区二区三区毛片国产一区| 国产成人无码精品久久久电影| 丝袜美腿视频诱惑亚洲无| 中文字幕免费在线免费| 黑人变态深video特大巨大| 午夜精品福利91av| 综合一区二区三区蜜臀| 成人网18免费视频版国产| 亚洲伊人色一综合网| 日本18禁久久久久久| 日韩欧美制服诱惑一区在线| 免费啪啪啪在线观看视频| 日韩精品一区二区三区在线播放| 青青青视频自偷自拍38碰| 综合国产成人在线观看| 亚洲av人人澡人人爽人人爱| 久久久久久久亚洲午夜综合福利 | 天天操天天干天天日狠狠插| 中国视频一区二区三区| 欧美地区一二三专区| 亚洲国产在线精品国偷产拍| 亚洲国产美女一区二区三区软件| 在线观看视频污一区| 亚洲公开视频在线观看| 国产剧情演绎系列丝袜高跟| 老师啊太大了啊啊啊尻视频| 女同性ⅹxx女同h偷拍| 在线观看视频一区麻豆| 夜色17s精品人妻熟女| 在线观看911精品国产| 亚洲综合一区成人在线| 2022精品久久久久久中文字幕| 亚洲av无乱一区二区三区性色| 天天色天天舔天天射天天爽| 成人乱码一区二区三区av| 蜜桃视频17c在线一区二区| 国产精品久久久久久久女人18| 一区二区三区麻豆福利视频| 国产在线免费观看成人| 国产 在线 免费 精品| 都市家庭人妻激情自拍视频| 亚洲2021av天堂| 欧美日韩国产一区二区三区三州| 91色秘乱一区二区三区| 精品一区二区三区在线观看| 国产视频网站一区二区三区| 久久久精品999精品日本| av破解版在线观看| 男人的天堂在线黄色| 国产又粗又猛又爽又黄的视频在线 | 香港三日本三韩国三欧美三级| 日本美女性生活一级片| av天堂加勒比在线| 天天干夜夜操天天舔| 97瑟瑟超碰在线香蕉| 91人妻精品久久久久久久网站| 天美传媒mv视频在线观看| 国产精品久久久久久美女校花| 3344免费偷拍视频| 蜜臀av久久久久久久| 中文字幕熟女人妻久久久| 日噜噜噜夜夜噜噜噜天天噜噜噜| 亚洲高清免费在线观看视频| 一色桃子人妻一区二区三区| 香港三日本三韩国三欧美三级| 精品国产乱码一区二区三区乱| 中文字幕无码日韩专区免费| 在线观看国产免费麻豆| 亚洲另类伦春色综合小| 亚洲精品欧美日韩在线播放| 国产麻豆剧果冻传媒app| 在线视频国产欧美日韩| 亚洲 中文字幕在线 日韩| 亚洲国产香蕉视频在线播放 | 男人的天堂在线黄色| 久久久噜噜噜久久熟女av| 日韩加勒比东京热二区| 91免费福利网91麻豆国产精品 | 国产chinesehd精品麻豆| 亚洲第一黄色在线观看| 天天日天天舔天天射进去| 欧美viboss性丰满| 最新中文字幕乱码在线| 欧美一区二区中文字幕电影 | 日日摸夜夜添夜夜添毛片性色av| 大白屁股精品视频国产| 91九色porny国产在线| japanese日本熟妇另类| 欧美一区二区三区高清不卡tv| 亚洲va国产va欧美va在线| 黄工厂精品视频在线观看| 国产使劲操在线播放| 婷婷六月天中文字幕| 888欧美视频在线| 99国内小视频在现欢看| 中文字幕在线欧美精品| 亚洲1卡2卡三卡4卡在线观看| jiuse91九色视频| 青青青青青青青青青国产精品视频| 国语对白xxxx乱大交| 热久久只有这里有精品| 欧美另类一区二区视频| 男女啪啪啪啪啪的网站| 抽查舔水白紧大视频| 97人妻色免费视频| 熟女91pooyn熟女| 91精品国产综合久久久蜜| 插小穴高清无码中文字幕| 亚洲免费国产在线日韩| 一个色综合男人天堂| av乱码一区二区三区| 久久久久久久久久久久久97| 久久免费看少妇高潮完整版| 精品首页在线观看视频| 蝴蝶伊人久久中文娱乐网| 中文字幕av一区在线观看| 经典av尤物一区二区| 色哟哟国产精品入口| 91精品高清一区二区三区| 免费十精品十国产网站| 久久久久久久久久久免费女人| 青青草成人福利电影| 骚逼被大屌狂草视频免费看| 亚洲少妇人妻无码精品| 亚洲 中文 自拍 另类 欧美| av视屏免费在线播放| 人人妻人人爽人人添夜| 欧美黄片精彩在线免费观看| 日本韩国免费福利精品| 亚洲中文字字幕乱码| 国产在线拍揄自揄视频网站| 中文字幕在线永久免费播放| 国产精品久久9999| 最近中文2019年在线看| 9l人妻人人爽人人爽| 成人高清在线观看视频| 欧美黄色录像免费看的| 亚洲国产成人无码麻豆艾秋| 欧美日韩高清午夜蜜桃大香蕉| 少妇ww搡性bbb91| 大尺度激情四射网站| 亚洲欧美激情国产综合久久久| 硬鸡巴动态操女人逼视频| 国产成人综合一区2区| 黄色视频在线观看高清无码| 国产精品sm调教视频| 亚洲成av人无码不卡影片一| 偷偷玩弄新婚人妻h视频| 中文字幕亚洲久久久| 伊人网中文字幕在线视频| 视频一区 二区 三区 综合| 成年人免费看在线视频| 青青青艹视频在线观看| 51精品视频免费在线观看| 日韩人妻在线视频免费| 色吉吉影音天天干天天操| 日韩av有码中文字幕| 91chinese在线视频| 天堂女人av一区二区| 亚洲av无硬久久精品蜜桃| 亚洲精品成人网久久久久久小说| 91综合久久亚洲综合| 国产精品3p和黑人大战| 中文乱理伦片在线观看| 视频一区二区在线免费播放| 成人av中文字幕一区| 天天干夜夜操啊啊啊| 爆乳骚货内射骚货内射在线| 在线免费观看黄页视频| 激情国产小视频在线| 手机看片福利盒子日韩在线播放| 98精产国品一二三产区区别| 中文字日产幕乱六区蜜桃| 国产精品自偷自拍啪啪啪| 一二三中文乱码亚洲乱码one| 日韩午夜福利精品试看| 青青草在观免费国产精品| 国产va在线观看精品| 国产精品熟女久久久久浪潮| 五十路在线观看完整版| 国产亚州色婷婷久久99精品| 同居了嫂子在线播高清中文| av在线免费观看亚洲天堂| 自拍偷拍日韩欧美一区二区| 日韩一区二区三区三州| 玖玖一区二区在线观看| 欧美日韩一级黄片免费观看| 98精产国品一二三产区区别| 欧美80老妇人性视频| 亚洲欧美福利在线观看| 国产麻豆剧果冻传媒app| 女蜜桃臀紧身瑜伽裤| 国产视频网站国产视频| 热久久只有这里有精品| 中文字母永久播放1区2区3区| 国产一线二线三线的区别在哪| 国产欧美精品不卡在线| 欧美精品 日韩国产| 亚洲一区二区三区在线高清 | 人人爱人人妻人人澡39| 果冻传媒av一区二区三区| av中文字幕国产在线观看| 亚洲欧美成人综合视频| 91人妻精品一区二区久久| 人人妻人人爽人人添夜| 清纯美女在线观看国产| 国产高潮无码喷水AV片在线观看| 69精品视频一区二区在线观看| 欧美va亚洲va天堂va| 美女视频福利免费看| 精品亚洲国产中文自在线| 黄色男人的天堂视频| 亚洲精品乱码久久久久久密桃明| 天天日夜夜干天天操| 国产黄色a级三级三级三级| 中出中文字幕在线观看| 手机看片福利盒子日韩在线播放| 喷水视频在线观看这里只有精品| 9l人妻人人爽人人爽| 国产三级精品三级在线不卡| 999九九久久久精品| 亚洲一区二区久久久人妻| 亚洲国产欧美国产综合在线| 久久99久久99精品影院| 任你操视频免费在线观看| 一区二区在线观看少妇| 青草亚洲视频在线观看| 免费啪啪啪在线观看视频| 亚洲美女美妇久久字幕组| 日本黄在免费看视频| av在线观看网址av| 综合激情网激情五月天| 欧美中国日韩久久精品| 国产又粗又猛又爽又黄的视频美国| 日本又色又爽又黄又粗| 天天摸天天日天天操| 亚洲国产欧美一区二区三区久久| 男人天堂最新地址av| 亚洲高清免费在线观看视频| 黑人巨大精品欧美视频| 熟女人妻一区二区精品视频| 天天操天天干天天艹| 熟女妇女老妇一二三区| 瑟瑟视频在线观看免费视频| 欧洲日韩亚洲一区二区三区| 精品国产污污免费网站入口自| 国产V亚洲V天堂无码欠欠| 日本一本午夜在线播放| 亚洲欧美另类手机在线| 亚洲一区二区三区五区| 日本精品一区二区三区在线视频。| 人妻少妇中文有码精品| 红杏久久av人妻一区| 亚洲精品福利网站图片| 男女第一次视频在线观看| 国产欧美日韩在线观看不卡| 不卡一区一区三区在线| 中文字幕一区二区亚洲一区| 91在线视频在线精品3| 伊人成人在线综合网| 亚洲 中文 自拍 另类 欧美 | 黄色视频在线观看高清无码| 黄工厂精品视频在线观看| 激情人妻校园春色亚洲欧美| 天天干天天操天天摸天天射| 欧美精品中文字幕久久二区| 伊人精品福利综合导航| 一区二区三区日本伦理| 狠狠躁狠狠爱网站视频| 色婷婷综合激情五月免费观看| 中文字幕在线第一页成人| 黄片色呦呦视频免费看| 水蜜桃国产一区二区三区| 大尺度激情四射网站| 国产老熟女伦老熟妇ⅹ| 日本成人不卡一区二区| 在线免费观看国产精品黄色| 亚洲av午夜免费观看| 传媒在线播放国产精品一区| 97超碰免费在线视频| 欧美精品 日韩国产| 天天操天天操天天碰| 自拍偷拍日韩欧美一区二区| 自拍偷拍亚洲欧美在线视频| 制丝袜业一区二区三区| 久久久久久97三级| 亚洲一区二区三区偷拍女厕91| wwwxxx一级黄色片| 国产露脸对白在线观看| 最新97国产在线视频| 亚洲 中文 自拍 另类 欧美| 午夜激情高清在线观看| 国产又粗又黄又硬又爽| 最新日韩av传媒在线| 精品视频国产在线观看| 一区二区久久成人网| 激情小视频国产在线 | 日韩美女精品视频在线观看网站 | 日本熟女精品一区二区三区| 青青色国产视频在线| 又粗又长 明星操逼小视频| okirakuhuhu在线观看| 色婷婷综合激情五月免费观看| 青青伊人一精品视频| 天天干天天爱天天色| 狠狠躁夜夜躁人人爽天天天天97| 福利国产视频在线观看| 成人国产影院在线观看| 专门看国产熟妇的网站| 国产精品成久久久久三级蜜臀av| 成人高清在线观看视频| 中文字幕在线观看极品视频| 中文字幕在线第一页成人| 中国把吊插入阴蒂的视频| 精品一区二区三区在线观看| 亚洲蜜臀av一区二区三区九色| 福利一二三在线视频观看| 日韩美女搞黄视频免费| 国产黄色片在线收看| 人妻少妇亚洲精品中文字幕| 久久久久五月天丁香社区| 熟女妇女老妇一二三区| 大肉大捧一进一出好爽在线视频 | av老司机精品在线观看| 日韩人妻丝袜中文字幕| 亚洲免费成人a v| 欧美一区二区三区高清不卡tv| 美女av色播在线播放| 国产aⅴ一线在线观看| 国产精品久久久久国产三级试频| 欧美成人小视频在线免费看| 少妇人妻100系列| 91快播视频在线观看| 亚洲中文字字幕乱码| 国产性生活中老年人视频网站| 亚洲福利精品福利精品福利| 亚洲av第国产精品| 欧美韩国日本国产亚洲| 91精品国产观看免费| 欧美日本在线观看一区二区 | 91九色国产熟女一区二区| 国产极品美女久久久久久| 亚洲成人国产综合一区| 中出中文字幕在线观看| 直接观看免费黄网站| 熟女俱乐部一二三区| 天天色天天操天天透| 做爰视频毛片下载蜜桃视频1| 午夜精品在线视频一区| 美味人妻2在线播放| 99精品久久久久久久91蜜桃| 国产高清女主播在线| 亚洲成a人片777777| 亚洲特黄aaaa片| 欧美成人猛片aaaaaaa| 一区二区三区av高清免费| 日视频免费在线观看| 51国产偷自视频在线播放| 亚洲精品麻豆免费在线观看| 日本精品一区二区三区在线视频。| 亚洲天堂av最新网址| 久久久麻豆精亚洲av麻花| 99久久久无码国产精品性出奶水| 在线制服丝袜中文字幕| 亚洲天堂第一页中文字幕| 天天日天天干天天插舔舔| 成人18禁网站在线播放| 97少妇精品在线观看| 2021久久免费视频| 国内自拍第一页在线观看| 婷婷午夜国产精品久久久| 亚洲伊人久久精品影院一美女洗澡 | 国产福利小视频二区| 黄色视频在线观看高清无码| 福利午夜视频在线观看| 欲乱人妻少妇在线视频裸| 亚洲成人情色电影在线观看| 亚洲精品乱码久久久本| 黄色片黄色片wyaa| 性色av一区二区三区久久久| 免费黄色成人午夜在线网站| 性感美女诱惑福利视频| 亚洲高清国产自产av| 97青青青手机在线视频 | 99热国产精品666| 欧美xxx成人在线| 韩国亚洲欧美超一级在线播放视频| 国产91精品拍在线观看| 亚洲图库另类图片区| 亚洲视频在线观看高清| 天天日天天透天天操| 欧美第一页在线免费观看视频| 韩国亚洲欧美超一级在线播放视频 | 亚洲无码一区在线影院| 亚洲人一区二区中文字幕| 日本熟女50视频免费| 国产又粗又猛又爽又黄的视频美国| 日本人妻精品久久久久久| 男人天堂色男人av| 大香蕉大香蕉在线看| 人妻久久无码中文成人| 人人妻人人澡欧美91精品 | 性感美女福利视频网站| 婷婷久久久久深爱网| 男女啪啪啪啪啪的网站| 中文字幕日韩精品就在这里| 一区二区三区在线视频福利| 91超碰青青中文字幕| 美女 午夜 在线视频| 制服丝袜在线人妻中文字幕| 亚洲成人国产综合一区| 亚洲成人免费看电影| 亚洲护士一区二区三区| 欧美国品一二三产区区别| 天天干狠狠干天天操| 99久久超碰人妻国产| 日韩在线视频观看有码在线| 亚洲久久午夜av一区二区| 亚洲午夜高清在线观看| 国产亚洲成人免费在线观看| xxx日本hd高清| 狠狠鲁狠狠操天天晚上干干| 97人妻夜夜爽二区欧美极品| 成人亚洲国产综合精品| 欧美色婷婷综合在线| av网站色偷偷婷婷网男人的天堂| 久久综合老鸭窝色综合久久| 2022精品久久久久久中文字幕| 99久久99一区二区三区| 午夜精品福利一区二区三区p| 午夜激情精品福利视频| 午夜在线观看一区视频| 亚洲最大黄了色网站| 国产实拍勾搭女技师av在线| 91福利视频免费在线观看| www日韩a级s片av| 91精品免费久久久久久| 在线观看免费av网址大全| 99精品视频之69精品视频| 欧美香蕉人妻精品一区二区| 熟女视频一区,二区,三区| okirakuhuhu在线观看| 人人妻人人人操人人人爽| 欧美中文字幕一区最新网址| 天天躁夜夜躁日日躁a麻豆| 超碰97人人澡人人| 国产超码片内射在线| 欧美成一区二区三区四区| 日韩影片一区二区三区不卡免费| 1000部国产精品成人观看视频| 夏目彩春在线中文字幕| 国产综合精品久久久久蜜臀| 大香蕉玖玖一区2区| 护士小嫩嫩又紧又爽20p| 真实国模和老外性视频| 亚洲另类伦春色综合小| 成熟熟女国产精品一区| 午夜精品九一唐人麻豆嫩草成人| 大胆亚洲av日韩av| 97少妇精品在线观看| 日本高清在线不卡一区二区| 在线成人日韩av电影| 男人和女人激情视频| 亚洲av无女神免非久久| 国产精品sm调教视频| 又粗又硬又猛又爽又黄的| 93精品视频在线观看| 国产亚洲精品视频合集| 专门看国产熟妇的网站| 亚洲精品国偷自产在线观看蜜桃| 精品乱子伦一区二区三区免费播| 欧美精品一二三视频| 欧美地区一二三专区| 天天夜天天日天天日| 久久麻豆亚洲精品av| 中文字幕在线观看国产片| 国产精品sm调教视频| 夜夜嗨av蜜臀av| av新中文天堂在线网址| 天堂va蜜桃一区入口| 国产又色又刺激在线视频| 激情色图一区二区三区| 午夜影院在线观看视频羞羞羞| rct470中文字幕在线| 3337p日本欧洲大胆色噜噜| 偷拍美女一区二区三区| 日本少妇精品免费视频| 在线免费观看日本伦理| 亚国产成人精品久久久| 国产亚洲成人免费在线观看| 亚洲男人让女人爽的视频| 99精品视频在线观看免费播放| 男生用鸡操女生视频动漫 | 午夜激情久久不卡一区二区 | 任我爽精品视频在线播放| 国产女人露脸高潮对白视频| 国产大学生援交正在播放| 同居了嫂子在线播高清中文| 亚洲变态另类色图天堂网| 中文字幕免费在线免费| 午夜91一区二区三区| 中文字幕人妻熟女在线电影| 女同性ⅹxx女同hd| 欧美日韩高清午夜蜜桃大香蕉| 3344免费偷拍视频| 国产自拍黄片在线观看| 欧美日韩在线精品一区二区三| 色av色婷婷人妻久久久精品高清 | 38av一区二区三区| 黄色成年网站午夜在线观看| 性感美女高潮视频久久久| 国产自拍在线观看成人| 大鸡八强奸视频在线观看| 人妻素人精油按摩中出| 大尺度激情四射网站| 久久99久久99精品影院| 成人性爱在线看四区| av天堂中文字幕最新| 岳太深了紧紧的中文字幕| 男人操女人的逼免费视频| 中文字幕在线免费第一页| 一本久久精品一区二区| 欧美精产国品一二三产品价格| 久青青草视频手机在线免费观看| 91极品新人『兔兔』精品新作| 欧美aa一级一区三区四区| 亚洲 中文 自拍 无码| 精品乱子伦一区二区三区免费播| 成人精品在线观看视频| 97瑟瑟超碰在线香蕉| 国产黄色片蝌蚪九色91| 男人操女人的逼免费视频| 免费看高清av的网站| 久久农村老妇乱69系列| 99热久久极品热亚洲| 2020久久躁狠狠躁夜夜躁| 亚洲成人激情av在线| 宅男噜噜噜666国产| 97精品成人一区二区三区 | 婷婷五月亚洲综合在线| 做爰视频毛片下载蜜桃视频1| 午夜精品在线视频一区| 1000部国产精品成人观看视频| 天天摸天天干天天操科普 | 99精品免费观看视频| 端庄人妻堕落挣扎沉沦| 久久久精品999精品日本| 天堂av在线播放免费| 成年人啪啪视频在线观看| 国产无遮挡裸体免费直播视频| 91av精品视频在线| 岛国青草视频在线观看| 亚洲福利午夜久久久精品电影网| 免费十精品十国产网站| 岛国av高清在线成人在线| 香蕉av影视在线观看| 国产自拍在线观看成人| 2021久久免费视频| 绝色少妇高潮3在线观看| 青草亚洲视频在线观看| 成人亚洲精品国产精品| 欧美性受xx黑人性猛交| 亚洲色偷偷综合亚洲AV伊人| 又粗又硬又猛又黄免费30| 超pen在线观看视频公开97| 在线观看av2025| 偷拍自拍福利视频在线观看| 天天想要天天操天天干| 91自产国产精品视频| 在线新三级黄伊人网| 强行扒开双腿猛烈进入免费版| 人人妻人人澡欧美91精品| 91在线视频在线精品3| 中文字幕 码 在线视频| heyzo蜜桃熟女人妻| 中文字幕成人日韩欧美| 日日夜夜大香蕉伊人| av一本二本在线观看| 日韩美女精品视频在线观看网站| 国产中文精品在线观看| 久久久久久久精品老熟妇| 亚洲av人人澡人人爽人人爱| 欧美成一区二区三区四区| 亚洲卡1卡2卡三卡四老狼| 女同互舔一区二区三区| 91高清成人在线视频| 亚洲精品乱码久久久久久密桃明 | 521精品视频在线观看| 国产白袜脚足J棉袜在线观看| 国产精品久久久久久久女人18| 亚洲av日韩av网站| 夜夜骑夜夜操夜夜奸| 97超碰人人搞人人| 日韩国产乱码中文字幕| 欧美3p在线观看一区二区三区| 日本真人性生活视频免费看| xxx日本hd高清| 最新国产亚洲精品中文在线| 亚洲粉嫩av一区二区三区| 亚洲综合另类欧美久久| 天堂av在线最新版在线| 粉嫩小穴流水视频在线观看| 日韩无码国产精品强奸乱伦| 成人在线欧美日韩国产| 少妇露脸深喉口爆吞精| 六月婷婷激情一区二区三区| 欧美日韩在线精品一区二区三| 国产极品美女久久久久久| 国产中文精品在线观看| 人人爽亚洲av人人爽av| 亚洲综合另类精品小说| 五十路熟女人妻一区二区9933| 在线观看的黄色免费网站| 欧美日韩亚洲国产无线码| 天天日天天干天天要| 全国亚洲男人的天堂| 2019av在线视频| 亚洲 中文 自拍 另类 欧美| 极品粉嫩小泬白浆20p主播| 久久三久久三久久三久久| 久久久久久国产精品| 欧美日韩国产一区二区三区三州 | 亚洲欧美精品综合图片小说 | 在线视频精品你懂的| 91p0rny九色露脸熟女| 极品性荡少妇一区二区色欲| 精品美女在线观看视频在线观看 | 在线免费观看靠比视频的网站| 偷拍美女一区二区三区| 成人综合亚洲欧美一区| 欧美日韩精品永久免费网址| 国产在线观看黄色视频| 色综合色综合色综合色| 3D动漫精品啪啪一区二区下载| 40道精品招牌菜特色| AV无码一区二区三区不卡| 日本人妻少妇18—xx| 欧美国产亚洲中英文字幕| 亚洲欧美清纯唯美另类| 四川乱子伦视频国产vip| 大香蕉福利在线观看| 欧美另类一区二区视频| 人妻少妇亚洲精品中文字幕| 伊拉克及约旦宣布关闭领空| 人妻3p真实偷拍一二区| 国产亚洲天堂天天一区| 国产精品国产三级国产午| 精品一线二线三线日本| 北条麻妃av在线免费观看| 老司机欧美视频在线看| 中出中文字幕在线观看| 亚洲精品久久综合久| 在线国产中文字幕视频| 日本福利午夜电影在线观看| 大陆精品一区二区三区久久| 蜜桃视频在线欧美一区| 亚洲国产精品中文字幕网站| 久草电影免费在线观看| 亚洲伊人av天堂有码在线| 亚洲一区制服丝袜美腿| 桃色视频在线观看一区二区| 久久艹在线观看视频| 日本精品美女在线观看| 93人妻人人揉人人澡人人| 午夜精品福利91av| 国产精品手机在线看片| 黄色片黄色片wyaa| www日韩a级s片av| 色哟哟在线网站入口| 成人激情文学网人妻| 亚洲精品一线二线在线观看| 18禁网站一区二区三区四区| 熟女人妻在线观看视频| 狠狠操狠狠操免费视频| 成人性爱在线看四区| 国产成人自拍视频在线免费观看 | 9l人妻人人爽人人爽| 亚洲高清视频在线不卡| 成人区人妻精品一区二视频| 天堂av在线最新版在线| 一区国内二区日韩三区欧美| 免费在线播放a级片| 爆乳骚货内射骚货内射在线| 午夜成午夜成年片在线观看| 高潮喷水在线视频观看| 午夜免费体验区在线观看| 国产清纯美女al在线| 亚洲成人熟妇一区二区三区 | 适合午夜一个人看的视频| 91片黄在线观看喷潮| 11久久久久久久久久久| 日韩欧美一级精品在线观看| 亚洲 自拍 色综合图| 日韩美女综合中文字幕pp| 欧美日韩不卡一区不区二区| 亚洲国产精品美女在线观看| caoporn蜜桃视频| 伊人网中文字幕在线视频| 成人av免费不卡在线观看| 免费观看污视频网站| 自拍偷拍亚洲精品第2页| 黄网十四区丁香社区激情五月天| 中文字幕 亚洲av| 在线亚洲天堂色播av电影| 国产日韩精品一二三区久久久| 不戴胸罩引我诱的隔壁的人妻| 天天做天天干天天操天天射| 女同久久精品秋霞网| 不卡一不卡二不卡三| 超鹏97历史在线观看| 视频二区在线视频观看| 日韩美女综合中文字幕pp| 精产国品久久一二三产区区别| 99re久久这里都是精品视频| 亚洲一区二区三区五区 | 日本一二三区不卡无| 91p0rny九色露脸熟女| 欧美国产亚洲中英文字幕| 日韩av有码中文字幕| 又色又爽又黄的美女裸体| 岛国青草视频在线观看| 亚洲国产成人最新资源| 精品av国产一区二区三区四区| 女人精品内射国产99| 欧美另类重口味极品在线观看| 黄网十四区丁香社区激情五月天| 干逼又爽又黄又免费的视频| 都市激情校园春色狠狠| 80电影天堂网官网| 国产精品黄页网站视频| 91极品新人『兔兔』精品新作| 亚洲综合另类欧美久久| 91老师蜜桃臀大屁股| 成人影片高清在线观看| 亚洲欧美清纯唯美另类| 国产精品欧美日韩区二区| 欧美亚洲免费视频观看| 国产成人精品久久二区91| 午夜91一区二区三区| 成年人啪啪视频在线观看| 久久久超爽一二三av| 女警官打开双腿沦为性奴| 国产卡一卡二卡三乱码手机| 欧亚日韩一区二区三区观看视频| 国产老熟女伦老熟妇ⅹ| 开心 色 六月 婷婷| 国产一线二线三线的区别在哪| 黄色成人在线中文字幕| 中文字幕av熟女人妻| 1769国产精品视频免费观看| 亚洲av黄色在线网站| 日韩欧美国产精品91| 又色又爽又黄的美女裸体| 亚洲va国产va欧美va在线| 午夜dv内射一区区| 色婷婷六月亚洲综合香蕉| 成人激情文学网人妻| 自拍 日韩 欧美激情| 欧美韩国日本国产亚洲| 久久h视频在线观看| 亚洲天堂精品久久久| 欧美成人精品在线观看| nagger可以指黑人吗| 国产又粗又猛又爽又黄的视频在线 | 天天射夜夜操狠狠干| 婷婷色中文亚洲网68| 欧美一区二区三区乱码在线播放 | 欧美精品欧美极品欧美视频| 青青青艹视频在线观看| 美女福利视频导航网站| 蜜臀成人av在线播放| 精品少妇一二三视频在线| 51国产偷自视频在线播放 | 大香蕉伊人国产在线| 深夜男人福利在线观看| 大香蕉玖玖一区2区| 一级黄色片夫妻性生活| 国产成人精品av网站| 久久久极品久久蜜桃| 国产日韩精品免费在线| 99热久久极品热亚洲| 亚洲国产在线精品国偷产拍| 国产之丝袜脚在线一区二区三区| 亚洲人妻国产精品综合| 天天日天天做天天日天天做| 中文字幕在线观看国产片| 888欧美视频在线| 国产熟妇人妻ⅹxxxx麻豆| 色婷婷久久久久swag精品| 大胸性感美女羞爽操逼毛片| 在线免费观看日本伦理| 国产精品人妻熟女毛片av久| 久久农村老妇乱69系列| 欧美中国日韩久久精品| 青青草成人福利电影| 五月天中文字幕内射| 日韩一区二区三区三州| 在线国产中文字幕视频| 99热99re在线播放| 欧美视频中文一区二区三区| 日韩一区二区三区三州| 成年人啪啪视频在线观看| 岛国黄色大片在线观看| 青青青青爽手机在线| 激情啪啪啪啪一区二区三区| 日本熟妇色熟妇在线观看| 国产日韩欧美视频在线导航 | 男人的天堂一区二区在线观看| 夜夜嗨av一区二区三区中文字幕| 少妇人妻100系列| 亚洲区美熟妇久久久久| 亚洲成人av一区在线| 中文字幕 码 在线视频| 99精品一区二区三区的区| 超污视频在线观看污污污 | 中文字幕一区二区人妻电影冢本| 亚洲天堂第一页中文字幕| 国产精品免费不卡av| 91精品视频在线观看免费| 黄色男人的天堂视频| 中文 成人 在线 视频| 鸡巴操逼一级黄色气| 最新的中文字幕 亚洲| 婷婷五月亚洲综合在线| 天天做天天干天天操天天射| 天干天天天色天天日天天射| 免费观看国产综合视频| 1769国产精品视频免费观看| 绝顶痉挛大潮喷高潮无码 | 国产精品黄色的av| 少妇人妻100系列| 91啪国自产中文字幕在线| 中文字幕日韩无敌亚洲精品 | 久久久久久cao我的性感人妻| 岛国av高清在线成人在线| 色伦色伦777国产精品| 2020韩国午夜女主播在线| 偷拍自拍 中文字幕| 精品人妻伦一二三区久| 亚国产成人精品久久久| 91老熟女连续高潮对白| 狍和女人的王色毛片| 久久久精品999精品日本 | 久久久久91精品推荐99| 久久精品国产23696| 亚洲午夜在线视频福利| 男人和女人激情视频| 国产成人无码精品久久久电影| jul—619中文字幕在线| 人人超碰国字幕观看97| 日韩一个色综合导航| 日本裸体熟妇区二区欧美| 国产精品sm调教视频| av亚洲中文天堂字幕网| 91中文字幕免费在线观看| 福利午夜视频在线观看| 亚洲一区二区激情在线| 中文字幕日韩精品就在这里| 午夜福利资源综合激情午夜福利资 | 亚洲高清国产拍青青草原| 天天日天天爽天天干| 黄色片一级美女黄色片| 日韩人妻xxxxx| 久久精品国产23696| 97青青青手机在线视频 | 国产janese在线播放| 久久精品亚洲国产av香蕉| av高潮迭起在线观看| 国产精品中文av在线播放| 91快播视频在线观看| 性欧美激情久久久久久久| 宅男噜噜噜666免费观看| 精品91高清在线观看| 欧美viboss性丰满| 日韩欧美亚洲熟女人妻| 亚洲青青操骚货在线视频| 黄色大片男人操女人逼| 中文字幕日本人妻中出| 国产成人精品av网站| 在线观看黄色成年人网站| 久久精品在线观看一区二区| 初美沙希中文字幕在线| 99人妻视频免费在线| 手机看片福利盒子日韩在线播放| 亚洲综合在线视频可播放| 亚洲激情,偷拍视频| 一级黄片大鸡巴插入美女| 综合国产成人在线观看| 这里有精品成人国产99| 精品日产卡一卡二卡国色天香| 久久美欧人妻少妇一区二区三区 | 中文字幕人妻一区二区视频| 亚洲福利天堂久久久久久 | 99精品国产aⅴ在线观看| 真实国产乱子伦一区二区| 天天日天天玩天天摸| 亚欧在线视频你懂的| 国产精品亚洲在线观看| 福利午夜视频在线观看| 9l人妻人人爽人人爽| 欧美日韩激情啪啪啪| 国产av欧美精品高潮网站| 国产清纯美女al在线| tube69日本少妇| 亚洲成人熟妇一区二区三区 | 欧美日韩国产一区二区三区三州| 黄色大片男人操女人逼| 久久久久久久久久久免费女人| 大香蕉伊人中文字幕| 大鸡吧插逼逼视频免费看| 大香蕉大香蕉在线有码 av| 日日日日日日日日夜夜夜夜夜夜| 在线 中文字幕 一区| 亚洲av可乐操首页| 日本精品美女在线观看| av在线资源中文字幕| 国产精品亚洲а∨天堂免| 午夜频道成人在线91| 蜜桃久久久久久久人妻| 黄色黄色黄片78在线| 精品区一区二区三区四区人妻| 日韩激情文学在线视频| 1024久久国产精品| 免费黄高清无码国产| 天天干天天操天天扣| 国产精品黄片免费在线观看| 搞黄色在线免费观看| 快插进小逼里大鸡吧视频| 1769国产精品视频免费观看| 91精品国产黑色丝袜| 日韩精品一区二区三区在线播放| 在线观看911精品国产| 国产chinesehd精品麻豆| 日韩精品激情在线观看| 狍和女人的王色毛片| 成人av在线资源网站| 色秀欧美视频第一页| 中文字幕奴隷色的舞台50| 1区2区3区4区视频在线观看| 精品久久久久久久久久久a√国产| 99久久中文字幕一本人| 中文字幕在线观看国产片| 天天干天天操天天插天天日| 美女av色播在线播放| 日韩成人综艺在线播放| 欧美亚洲牲夜夜综合久久| av网站色偷偷婷婷网男人的天堂| 久久久久久久精品成人热| 天堂女人av一区二区| 夜夜骑夜夜操夜夜奸| 岛国一区二区三区视频在线| 动色av一区二区三区| 11久久久久久久久久久| 视频啪啪啪免费观看| ka0ri在线视频| 亚洲成人三级在线播放 | 在线免费观看国产精品黄色| 美女少妇亚洲精选av| 欧美在线精品一区二区三区视频| 亚洲欧美一卡二卡三卡| 天天做天天干天天操天天射| 中文字幕一区二区亚洲一区| 亚洲精品一线二线在线观看| 国产+亚洲+欧美+另类| 爱有来生高清在线中文字幕| 91免费观看国产免费| 青青伊人一精品视频| 38av一区二区三区| 久久精品视频一区二区三区四区| 把腿张开让我插进去视频| 国产精品人妻一区二区三区网站 | 日本福利午夜电影在线观看| 日韩美女搞黄视频免费| free性日本少妇| 亚洲福利天堂久久久久久 | 超碰97人人澡人人| 成人av电影免费版| 黑人乱偷人妻中文字幕| 熟女人妻在线中出观看完整版| 成年午夜免费无码区| 亚洲中文字幕综合小综合| 少妇人妻二三区视频| 自拍 日韩 欧美激情| 中文字幕人妻一区二区视频| 北条麻妃高跟丝袜啪啪| 午夜场射精嗯嗯啊啊视频| 日本一二三区不卡无| 欧美精品久久久久久影院| 欧美另类一区二区视频| 精品一区二区三区在线观看| 熟女人妻三十路四十路人妻斩| yellow在线播放av啊啊啊| 天天干天天操天天摸天天射| 日本一二三中文字幕| 激情内射在线免费观看| 夏目彩春在线中文字幕| 亚洲男人的天堂a在线| 亚洲成a人片777777| 夜色福利视频在线观看| 久久久制服丝袜中文字幕| 搡老熟女一区二区在线观看| 成年人黄色片免费网站| 抽查舔水白紧大视频| 亚洲高清免费在线观看视频| 亚洲激情,偷拍视频| 午夜在线一区二区免费| 又色又爽又黄的美女裸体| av网址国产在线观看| 57pao国产一区二区| 国产无遮挡裸体免费直播视频| 色婷婷综合激情五月免费观看| 玩弄人妻熟妇性色av少妇| 五十路丰满人妻熟妇| 五十路av熟女松本翔子| 日本黄色三级高清视频| 黄色中文字幕在线播放| 欧美日韩在线精品一区二区三| 国产成人小视频在线观看无遮挡| 888亚洲欧美国产va在线播放| 日韩成人综艺在线播放| 天天干天天操天天爽天天摸| 2019av在线视频| 中文 成人 在线 视频| 欧美激情电影免费在线| 亚洲福利精品视频在线免费观看| 亚洲日本一区二区三区| 天天射夜夜操综合网| 十八禁在线观看地址免费| 日本人妻精品久久久久久| yy6080国产在线视频| 少妇ww搡性bbb91| 亚洲欧美国产综合777| 色综合久久无码中文字幕波多| 青青青青青青草国产| 大鸡巴操娇小玲珑的女孩逼| 久久久久久9999久久久久| 日韩av有码中文字幕| 国产成人精品av网站| 日韩成人性色生活片| 欧美一区二区三区激情啪啪啪 | 亚洲中文字字幕乱码| 少妇人妻二三区视频| 色av色婷婷人妻久久久精品高清| 国产又粗又黄又硬又爽| av手机在线观播放网站| 深田咏美亚洲一区二区| 伊人成人综合开心网| 久久久制服丝袜中文字幕| 成年人黄色片免费网站| 亚洲av日韩精品久久久| 绝色少妇高潮3在线观看| 女人精品内射国产99| 伊人网中文字幕在线视频| 欧洲黄页网免费观看| 亚洲熟妇无码一区二区三区| 福利视频一区二区三区筱慧| 国产精品入口麻豆啊啊啊| 日韩精品电影亚洲一区| 国产日韩精品免费在线| 自拍偷拍亚洲另类色图| 亚洲成高清a人片在线观看| 熟女人妻三十路四十路人妻斩| 国产精品成人xxxx| 亚洲区欧美区另类最新章节| 日本性感美女写真视频| 中文字幕人妻三级在线观看| 在线免费观看视频一二区| 香蕉片在线观看av| 人妻丝袜榨强中文字幕| 青青操免费日综合视频观看| 国语对白xxxx乱大交| 一区二区三区久久中文字幕| 亚洲公开视频在线观看| 五十路熟女人妻一区二区9933| 精品老妇女久久9g国产| 75国产综合在线视频| 中文 成人 在线 视频| 中文字幕亚洲久久久| 日日操综合成人av| 熟女在线视频一区二区三区| 岛国毛片视频免费在线观看| 在线 中文字幕 一区| 在线免费观看欧美小视频| 日韩中文字幕精品淫| 51精品视频免费在线观看| 2021久久免费视频| 一级a看免费观看网站| 免费黄高清无码国产| 巨乳人妻日下部加奈被邻居中出| 男人插女人视频网站| 亚洲av一妻不如妾| 精品区一区二区三区四区人妻| 66久久久久久久久久久| 成人18禁网站在线播放| 啪啪啪啪啪啪啪啪啪啪黄色| 91片黄在线观看喷潮| 青青青视频自偷自拍38碰| 水蜜桃一区二区三区在线观看视频 | 任你操视频免费在线观看| 国产又粗又猛又爽又黄的视频在线| 91九色porny蝌蚪国产成人| 人人妻人人人操人人人爽| 欧美美女人体视频一区| 亚洲中文字幕乱码区| 不卡一区一区三区在线| 抽查舔水白紧大视频| 国产性生活中老年人视频网站| 1024久久国产精品| 午夜免费体验区在线观看| 大陆胖女人与丈夫操b国语高清| 日韩美在线观看视频黄| 蜜臀av久久久久久久| 扒开让我视频在线观看| 97国产福利小视频合集| 91精品国产综合久久久蜜 | 亚洲第一黄色在线观看| 岛国一区二区三区视频在线| 国产精品视频一区在线播放| 最近中文字幕国产在线| av网址国产在线观看| 99热99re在线播放| 亚洲另类在线免费观看| 日本又色又爽又黄又粗| 一区二区三区av高清免费| 亚洲av男人的天堂你懂的| 亚洲精品乱码久久久本| 韩国AV无码不卡在线播放| 91香蕉成人app下载| 最近的中文字幕在线mv视频| 特级无码毛片免费视频播放 | 98视频精品在线观看| 午夜频道成人在线91| 国产在线免费观看成人| 免费看高清av的网站| 久久人人做人人妻人人玩精品vr | 888欧美视频在线| 日本精品视频不卡一二三| 亚洲欧美综合在线探花| 中文字幕在线视频一区二区三区| 任我爽精品视频在线播放| 五十路人妻熟女av一区二区| 日韩a级精品一区二区| 日本裸体熟妇区二区欧美| 1769国产精品视频免费观看| 午夜精品亚洲精品五月色| 香港一级特黄大片在线播放| 欧美在线偷拍视频免费看| 狠狠嗨日韩综合久久| 激情色图一区二区三区| 久草免费人妻视频在线| 都市激情校园春色狠狠| 制服丝袜在线人妻中文字幕| 人人在线视频一区二区| 韩国爱爱视频中文字幕| 日韩成人免费电影二区| 国产剧情演绎系列丝袜高跟| 青青在线视频性感少妇和隔壁黑丝 | 大陆胖女人与丈夫操b国语高清 | 97a片免费在线观看| 青春草视频在线免费播放| 欧美性感尤物人妻在线免费看| 日韩av中文在线免费观看| 日韩精品一区二区三区在线播放| 一区二区三区av高清免费| 青娱乐在线免费视频盛宴| 国产一级麻豆精品免费| 国产麻豆精品人妻av| 91在线免费观看成人| 中文字幕高清在线免费播放 | 99精品视频在线观看免费播放| 最近中文2019年在线看| 亚洲区美熟妇久久久久| 激情五月婷婷综合色啪| 2012中文字幕在线高清| 激情五月婷婷免费视频| 大香蕉大香蕉大香蕉大香蕉大香蕉 | 黑人性生活视频免费看| 成人蜜臀午夜久久一区| 大肉大捧一进一出好爽在线视频| 欧美区一区二区三视频| 欧洲国产成人精品91铁牛tv| 亚洲1区2区3区精华液| 久久久久久久亚洲午夜综合福利| 经典亚洲伊人第一页| 都市家庭人妻激情自拍视频| 中文字幕熟女人妻久久久| 亚洲国产精品久久久久蜜桃| 国产日本精品久久久久久久| 大陆av手机在线观看| 又粗又硬又猛又爽又黄的| 在线 中文字幕 一区| 亚洲一级av无码一级久久精品| 青草久久视频在线观看| 天天日天天添天天爽| 日本黄在免费看视频| 性感美女福利视频网站| 亚洲无码一区在线影院| 日本脱亚入欧是指什么| 免费观看污视频网站| 日本高清撒尿pissing| 久久久久久久精品老熟妇| 日韩美女精品视频在线观看网站| 日本真人性生活视频免费看| 国产av欧美精品高潮网站| 国内自拍第一页在线观看| 国产视频一区在线观看| 天天操天天污天天射| 亚洲人妻30pwc| 久久久噜噜噜久久熟女av| 日本人妻少妇18—xx| 啪啪啪啪啪啪啪啪av| 新婚人妻聚会被中出| 一区二区三区的久久的蜜桃的视频| 宅男噜噜噜666国产| 国产va精品免费观看| 视频二区在线视频观看| av一区二区三区人妻| 国产精品一区二区久久久av| 男人天堂av天天操| 日日夜夜狠狠干视频| 硬鸡巴动态操女人逼视频| 亚洲午夜精品小视频| huangse网站在线观看| 人妻3p真实偷拍一二区| 91精品综合久久久久3d动漫| 一区二区三区久久中文字幕| av老司机亚洲一区二区| 自拍偷拍日韩欧美一区二区| 亚洲天堂有码中文字幕视频| 成人av中文字幕一区| 欧美中国日韩久久精品| 制丝袜业一区二区三区| 日韩欧美一级黄片亚洲| 超碰97人人澡人人| 国产精品久久久久久久久福交| 天天干天天操天天插天天日| 欧美香蕉人妻精品一区二区| 偷拍自拍亚洲美腿丝袜| 国内资源最丰富的网站| 最新黄色av网站在线观看| 亚洲国产在人线放午夜| 欧美亚洲国产成人免费在线| 亚洲激情av一区二区| 国产精品成久久久久三级蜜臀av| 少妇被强干到高潮视频在线观看| okirakuhuhu在线观看| 天天艹天天干天天操| 伊人开心婷婷国产av| avjpm亚洲伊人久久| av一本二本在线观看| 人妻自拍视频中国大陆| 亚洲少妇高潮免费观看| 黑人解禁人妻叶爱071| 亚洲激情,偷拍视频| 日本熟妇丰满厨房55| 中国视频一区二区三区| 一区二区三区欧美日韩高清播放| 亚洲人妻视频在线网| 久久久久久久99精品| 天码人妻一区二区三区在线看| 午夜激情精品福利视频| 青娱乐极品视频青青草| 最新97国产在线视频| 日韩美女综合中文字幕pp| 国产麻豆国语对白露脸剧情 | 国产九色91在线观看精品| 欧美成人猛片aaaaaaa| 国产露脸对白在线观看| 97香蕉碰碰人妻国产樱花| 适合午夜一个人看的视频| 大香蕉玖玖一区2区| 任你操任你干精品在线视频| 欧美亚洲少妇福利视频| 国产精品视频一区在线播放| 无码国产精品一区二区高潮久久4| 色秀欧美视频第一页| 亚洲 清纯 国产com| 国产美女精品福利在线| 黄色在线观看免费观看在线| 91国内视频在线观看| 亚洲天堂成人在线观看视频网站| 超碰97人人澡人人| 精品国产午夜视频一区二区| 日韩亚国产欧美三级涩爱| 欧美在线精品一区二区三区视频 | 日韩精品中文字幕福利| 一级黄片久久久久久久久| 亚洲成人免费看电影| 97国产精品97久久| 免费在线看的黄片视频| 91国偷自产一区二区三区精品| 日本免费视频午夜福利视频| 91高清成人在线视频| 亚洲欧美国产麻豆综合| 色哟哟在线网站入口| 18禁美女羞羞免费网站| 日韩一区二区三区三州| 经典国语激情内射视频| 熟女视频一区,二区,三区| 初美沙希中文字幕在线| 麻豆性色视频在线观看| 国产成人午夜精品福利| 国产在线观看黄色视频| av网址在线播放大全| 亚洲欧美一区二区三区电影| 人妻凌辱欧美丰满熟妇| 黑人巨大的吊bdsm| 日韩精品啪啪视频一道免费| 久久这里只有精品热视频| 一级黄片大鸡巴插入美女| 91chinese在线视频| 狠狠躁狠狠爱网站视频| 国产亚洲视频在线二区| 免费看高清av的网站| 91国内视频在线观看| brazzers欧熟精品系列| 偷拍3456eee| 亚洲最大黄了色网站| 亚洲欧美清纯唯美另类| 日韩精品电影亚洲一区| 天天操天天干天天日狠狠插 | 在线视频这里只有精品自拍| avjpm亚洲伊人久久| 国产熟妇乱妇熟色T区| 国产精品中文av在线播放| aaa久久久久久久久| 亚洲欧美一区二区三区电影| 高潮视频在线快速观看国家快速| 欧美一区二区三区四区性视频| 亚洲人妻国产精品综合| av俺也去在线播放| 午夜成午夜成年片在线观看| 一级黄色片夫妻性生活| 美味人妻2在线播放| 国产自拍黄片在线观看| 亚洲第一伊人天堂网| 国产精品精品精品999| 中文字幕熟女人妻久久久| 中文字幕无码日韩专区免费| 青青青爽视频在线播放| 午夜福利资源综合激情午夜福利资 | 国产日韩av一区二区在线| 小穴多水久久精品免费看| 亚洲在线免费h观看网站| 亚洲伊人色一综合网| 人妻熟女中文字幕aⅴ在线| 国产之丝袜脚在线一区二区三区| 国产av一区2区3区| 白白操白白色在线免费视频| 在线观看日韩激情视频| 国产黄色大片在线免费播放| 天天射夜夜操狠狠干| 最近中文字幕国产在线| 十八禁在线观看地址免费| 亚洲码av无色中文| 91精品国产黑色丝袜| 国产aⅴ一线在线观看| 揄拍成人国产精品免费看视频| 国产麻豆91在线视频| 免费在线观看污污视频网站| 中文字幕之无码色多多| 国产美女午夜福利久久| 91破解版永久免费| 91麻豆精品传媒国产黄色片| 色综合色综合色综合色| aaa久久久久久久久| 亚洲女人的天堂av| 成人伊人精品色xxxx视频| 绝色少妇高潮3在线观看| 538精品在线观看视频| 国产实拍勾搭女技师av在线| 欧美日本国产自视大全| 久草视频在线免播放| 日韩a级精品一区二区| 天天操,天天干,天天射| 国产一区自拍黄视频免费观看| av完全免费在线观看av| 欧美3p在线观看一区二区三区| 亚洲福利精品视频在线免费观看| 丝袜肉丝一区二区三区四区在线| 国产精品入口麻豆啊啊啊| av在线免费中文字幕| 4个黑人操素人视频网站精品91| 色婷婷久久久久swag精品| 久碰精品少妇中文字幕av| 夜夜骑夜夜操夜夜奸| 欧洲精品第一页欧洲精品亚洲| 日韩一个色综合导航| 成年午夜免费无码区| 精品人妻伦一二三区久| 亚洲公开视频在线观看| 精品亚洲中文字幕av| 久久久久久久精品成人热| 91超碰青青中文字幕| 成人国产小视频在线观看| 日韩加勒比东京热二区| 国产福利小视频大全| 99视频精品全部15| 中文字幕av熟女人妻| 国产真实灌醉下药美女av福利| chinese国产盗摄一区二区| 不卡一不卡二不卡三| 熟女国产一区亚洲中文字幕| 欧美亚洲少妇福利视频| 日本人竟这样玩学生妹| 国产精品久久久久久久久福交| 精品一区二区亚洲欧美| 亚洲国际青青操综合网站| av网站色偷偷婷婷网男人的天堂| 在线观看日韩激情视频| 91精品激情五月婷婷在线| 亚洲av琪琪男人的天堂| 狠狠躁夜夜躁人人爽天天久天啪| 久久精品久久精品亚洲人| 人妻素人精油按摩中出| 一区二区三区国产精选在线播放| 97超碰最新免费在线观看| 成人av免费不卡在线观看| 18禁精品网站久久| 男人天堂色男人av| 中文字幕+中文字幕| 极品性荡少妇一区二区色欲| 日本熟妇一区二区x x| av网址国产在线观看| 欧美日韩一区二区电影在线观看| 在线不卡成人黄色精品| 日韩精品电影亚洲一区| 青青草人人妻人人妻| 直接观看免费黄网站| 日韩写真福利视频在线观看| 欧美日本国产自视大全| 日本人妻少妇18—xx| 天天日夜夜干天天操| 自拍 日韩 欧美激情| 亚洲一区二区三区久久午夜| 18禁美女羞羞免费网站| 超碰97免费人妻麻豆| 91久久人澡人人添人人爽乱| 五色婷婷综合狠狠爱| 在线免费91激情四射 | 久碰精品少妇中文字幕av| 男人的网址你懂的亚洲欧洲av| av在线资源中文字幕| 人妻最新视频在线免费观看| 午夜免费体验区在线观看| 91人妻精品久久久久久久网站| 国产中文精品在线观看| 天天日天天干天天爱| 日韩一区二区三区三州| 毛片一级完整版免费| 日韩中文字幕在线播放第二页| 国产精品日韩欧美一区二区| 成人sm视频在线观看| 91超碰青青中文字幕| 狠狠的往里顶撞h百合| 超碰中文字幕免费观看| 亚洲欧美福利在线观看| 任你操视频免费在线观看| 国产成人精品av网站| 国内资源最丰富的网站| 绝顶痉挛大潮喷高潮无码| 国产+亚洲+欧美+另类| 午夜免费体验区在线观看| 91九色porny国产蝌蚪视频| 岛国免费大片在线观看 | 在线观看成人国产电影| 91欧美在线免费观看| 久久久久久久99精品| 日本美女性生活一级片| 国产视频在线视频播放| 亚洲一级av大片免费观看| 视频在线亚洲一区二区| 一区二区三区四区五区性感视频 | 亚洲 中文 自拍 另类 欧美| 特级无码毛片免费视频播放| 欧美视频不卡一区四区| 国产中文精品在线观看| 最新日韩av传媒在线| 亚洲一区久久免费视频| 538精品在线观看视频| 亚洲高清免费在线观看视频| 国产乱子伦精品视频潮优女| 国产精品国产三级麻豆| 久久香蕉国产免费天天| 伊人情人综合成人久久网小说| 少妇与子乱在线观看| 国产精彩对白一区二区三区| 青青青青草手机在线视频免费看| 久久久久只精品国产三级| 天天干天天啪天天舔| 最新国产精品网址在线观看| 国产在线观看黄色视频| 天天通天天透天天插| 丝袜长腿第一页在线| 亚洲精品成人网久久久久久小说| 免费观看理论片完整版| 国产大鸡巴大鸡巴操小骚逼小骚逼 | 午夜精彩视频免费一区| 性感美女高潮视频久久久| 色婷婷久久久久swag精品| 国产V亚洲V天堂无码欠欠| 婷婷久久久综合中文字幕| 大鸡巴操b视频在线| 国产91嫩草久久成人在线视频| 国产污污污污网站在线| 特级无码毛片免费视频播放| 国产成人精品久久二区91| 成人av免费不卡在线观看| 久久精品国产999| 自拍偷区二区三区麻豆| 午夜在线观看岛国av,com| 亚洲 中文 自拍 无码| 人人爽亚洲av人人爽av| 久久久久国产成人精品亚洲午夜| 91九色国产porny蝌蚪| 78色精品一区二区三区| 成年人黄视频在线观看| 麻豆性色视频在线观看| 欧美日韩人妻久久精品高清国产 | 亚洲第一黄色在线观看| 国产福利小视频二区| 日韩熟女系列一区二区三区| 国产成人午夜精品福利| 人人在线视频一区二区| 欧美精产国品一二三区| 在线观看免费视频网| 亚洲欧美激情人妻偷拍| 精品成人啪啪18免费蜜臀| 天天操天天干天天插| 含骚鸡巴玩逼逼视频| 91国产资源在线视频| 色伦色伦777国产精品| 一区二区三区欧美日韩高清播放| 色婷婷综合激情五月免费观看| 天天干天天操天天玩天天射| 香蕉91一区二区三区| 亚洲精品ww久久久久久| 粉嫩欧美美人妻小视频| 国产午夜男女爽爽爽爽爽视频 | 国产精品久久9999| 亚洲欧美激情人妻偷拍| 亚洲狠狠婷婷综合久久app| 十八禁在线观看地址免费| 国产熟妇人妻ⅹxxxx麻豆| 欧美日韩高清午夜蜜桃大香蕉| 久久人人做人人妻人人玩精品vr| 日本精品一区二区三区在线视频。| 噜噜色噜噜噜久色超碰| 欧美精品中文字幕久久二区| 天天摸天天亲天天舔天天操天天爽 | 免费看国产av网站| 中文字幕第三十八页久久| 国产精品黄大片在线播放| 综合页自拍视频在线播放| 91老师蜜桃臀大屁股| 老鸭窝日韩精品视频观看| 护士小嫩嫩又紧又爽20p| 五色婷婷综合狠狠爱| 日本三极片中文字幕| 国产午夜福利av导航| 在线观看欧美黄片一区二区三区| 岛国免费大片在线观看 | 大陆精品一区二区三区久久| 欧美80老妇人性视频| 亚洲在线一区二区欧美| 自拍偷拍亚洲另类色图| 中出中文字幕在线观看| 亚洲av黄色在线网站| 人妻熟女在线一区二区| 我想看操逼黄色大片| 97人妻总资源视频| 日本av熟女在线视频| 日韩国产乱码中文字幕| 人妻3p真实偷拍一二区| 久久精品美女免费视频| 无忧传媒在线观看视频| 日本18禁久久久久久| 91麻豆精品91久久久久同性| 中文字母永久播放1区2区3区| 91九色porny国产在线| 99热久久极品热亚洲| 丝袜亚洲另类欧美变态| 久精品人妻一区二区三区| 国产日韩精品电影7777| 中文字幕一区二区三区蜜月| 一级黄片大鸡巴插入美女| 在线 中文字幕 一区| 六月婷婷激情一区二区三区| 非洲黑人一级特黄片| 中文字幕无码日韩专区免费| 夜色撩人久久7777| 大香蕉伊人国产在线| 欧美成人一二三在线网| 熟女人妻在线观看视频| 国产91久久精品一区二区字幕| 亚洲精品乱码久久久久久密桃明 | 亚洲精品乱码久久久本| 欧美成人综合视频一区二区| 91国产在线免费播放| 香蕉av影视在线观看| av一本二本在线观看| 国产精品自拍视频大全| 丰满的继坶3中文在线观看| jiujiure精品视频在线| 国产 在线 免费 精品| 777奇米久久精品一区| 国产黄网站在线观看播放| 精品高跟鞋丝袜一区二区| 午夜福利资源综合激情午夜福利资 | 偷拍自拍 中文字幕| 中文字幕在线永久免费播放| 人妻3p真实偷拍一二区| 亚洲va欧美va人人爽3p| 欧美精产国品一二三区| 91传媒一区二区三区| gav成人免费播放| 五十路在线观看完整版| 亚洲精品福利网站图片| 欧美一区二区三区久久久aaa| 亚洲成人免费看电影| 99国内精品永久免费视频| 99av国产精品欲麻豆| 老司机免费视频网站在线看| 亚洲精品 欧美日韩| 97瑟瑟超碰在线香蕉| 黑人巨大精品欧美视频| av一本二本在线观看| 亚洲精品麻豆免费在线观看| 男人和女人激情视频| 99精品视频在线观看免费播放| 免费在线看的黄片视频| 亚洲少妇人妻无码精品| 日韩精品中文字幕在线| 色吉吉影音天天干天天操| 93精品视频在线观看| 欧美黑人巨大性xxxxx猛交| 一个色综合男人天堂| 国产精品久久久黄网站| 在线网站你懂得老司机| 午夜精品久久久久久99热| 性感美女高潮视频久久久| 国产精品久久久久久久女人18| 大屁股肉感人妻中文字幕在线| 丰满的子国产在线观看| 国产在线一区二区三区麻酥酥| 一本一本久久a久久精品综合不卡| 日本av在线一区二区三区| 亚洲区美熟妇久久久久| 天天射夜夜操综合网| 视频啪啪啪免费观看| 国产91嫩草久久成人在线视频| 久久三久久三久久三久久| 亚洲自拍偷拍综合色| 国产精品久久久黄网站| 亚洲欧美综合在线探花| 中文字幕AV在线免费看 | 日本高清撒尿pissing| 五色婷婷综合狠狠爱| 亚洲成高清a人片在线观看| 福利视频一区二区三区筱慧| 1024久久国产精品| 极品丝袜一区二区三区| 日本女人一级免费片| 亚洲另类综合一区小说| 美女小视频网站在线| av高潮迭起在线观看| 偷拍自拍国产在线视频| 天天干天天搞天天摸| 蜜臀av久久久久蜜臀av麻豆| 国产女孩喷水在线观看| 韩国女主播精品视频网站| 熟女俱乐部一二三区| 中文字幕免费福利视频6| 中文字幕1卡1区2区3区| 国产视频网站一区二区三区| 经典国语激情内射视频| 丝袜长腿第一页在线| 综合国产成人在线观看| 日本啪啪啪啪啪啪啪| 日韩北条麻妃一区在线| 韩国爱爱视频中文字幕| 青青草人人妻人人妻| 少妇一区二区三区久久久| 91精品啪在线免费| 91色秘乱一区二区三区| 人妻少妇性色欲欧美日韩| 天天干天天操天天摸天天射| 91p0rny九色露脸熟女| 中文字幕午夜免费福利视频| 国产夫妻视频在线观看免费| 18禁无翼鸟成人在线| 欧美精品欧美极品欧美视频| 绝色少妇高潮3在线观看| 亚洲麻豆一区二区三区| 伊人成人在线综合网| 宅男噜噜噜666免费观看| 国产一区二区视频观看| 色综合天天综合网国产成人| 狠狠鲁狠狠操天天晚上干干| 性感美女高潮视频久久久 | 久久久麻豆精亚洲av麻花| 在线可以看的视频你懂的| 专门看国产熟妇的网站| 亚洲天堂有码中文字幕视频| 欧美亚洲一二三区蜜臀| 888亚洲欧美国产va在线播放| 免费岛国喷水视频在线观看| 成人24小时免费视频| 中文字幕最新久久久| 欧美va亚洲va天堂va| 人妻自拍视频中国大陆| 久久久精品国产亚洲AV一| 亚洲美女美妇久久字幕组| 国产极品精品免费视频| 最新日韩av传媒在线| 91老熟女连续高潮对白| 9久在线视频只有精品| 蝴蝶伊人久久中文娱乐网| 又黄又刺激的午夜小视频| 青青伊人一精品视频| 又粗又长 明星操逼小视频| 人妻另类专区欧美制服| 中文字幕一区二区三区人妻大片| 丰满熟女午夜福利视频| 三级黄色亚洲成人av| 91福利在线视频免费观看| 天天色天天操天天透| 国产精品自拍视频大全| 黑人乱偷人妻中文字幕| 青娱乐最新视频在线| 又粗又硬又猛又爽又黄的| 天天日夜夜操天天摸| 夜夜躁狠狠躁日日躁麻豆内射 | 亚洲熟色妇av日韩熟色妇在线| 巨乳人妻日下部加奈被邻居中出| 色伦色伦777国产精品| 婷婷久久一区二区字幕网址你懂得 | 国产美女午夜福利久久| 国产黑丝高跟鞋视频在线播放| 日日摸夜夜添夜夜添毛片性色av| 中文字母永久播放1区2区3区| 日本真人性生活视频免费看| 天天日天天摸天天爱| 91国偷自产一区二区三区精品| 亚洲一区二区三区精品视频在线 | 熟女妇女老妇一二三区| 午夜在线一区二区免费| 啪啪啪操人视频在线播放| 国产精品国产精品一区二区| 日韩精品激情在线观看| 一个色综合男人天堂| 亚洲免费va在线播放| 亚洲中文字幕国产日韩| 老司机免费视频网站在线看| 色天天天天射天天舔| 狠狠躁夜夜躁人人爽天天天天97 | 国产麻豆国语对白露脸剧情| 欧美交性又色又爽又黄麻豆| 天堂中文字幕翔田av| 青青青青青青青青青国产精品视频| 国产精品日韩欧美一区二区| 青青擦在线视频国产在线| 成熟丰满熟妇高潮xx×xx| 在线观看一区二区三级| 果冻传媒av一区二区三区| 亚洲 中文 自拍 另类 欧美| 不卡一区一区三区在线| 中文字幕av第1页中文字幕| 男大肉棒猛烈插女免费视频| 福利视频广场一区二区| 在线播放国产黄色av| 亚洲中文字幕人妻一区| 天天日天天鲁天天操| 桃色视频在线观看一区二区| 亚洲va国产va欧美va在线| 高潮视频在线快速观看国家快速| 久草免费人妻视频在线| 激情五月婷婷免费视频| 免费福利av在线一区二区三区| 综合精品久久久久97| 日本少妇在线视频大香蕉在线观看 | v888av在线观看视频| 美味人妻2在线播放| 精品黑人巨大在线一区| 久久机热/这里只有| 风流唐伯虎电视剧在线观看| 国产精品欧美日韩区二区| 成人综合亚洲欧美一区| 天天草天天色天天干| 日韩精品激情在线观看| tube69日本少妇| 欧美精品一二三视频| 国产亚洲天堂天天一区| 欧美中文字幕一区最新网址| AV无码一区二区三区不卡| 亚洲区美熟妇久久久久| 五十路熟女av天堂| 国产女孩喷水在线观看| 国产高清在线观看1区2区| 欧美久久久久久三级网| 国产精品久久久久国产三级试频| 视频一区二区三区高清在线| 欧美日韩国产一区二区三区三州 | 99人妻视频免费在线| 日本18禁久久久久久| 不卡一不卡二不卡三| 日日夜夜大香蕉伊人| 亚洲 图片 欧美 图片| 亚洲av色香蕉一区二区三区| 欧美日本国产自视大全| 欧美偷拍自拍色图片| 这里有精品成人国产99| 成人资源在线观看免费官网| 91精品国产观看免费| sw137 中文字幕 在线| 欧美精品黑人性xxxx| 天天日天天干天天干天天日| 97人人妻人人澡人人爽人人精品| 1区2区3区不卡视频| 在线观看视频网站麻豆| 国产露脸对白在线观看| asmr福利视频在线观看| 黄色无码鸡吧操逼视频| 一区二区在线视频中文字幕| 亚洲免费va在线播放| 97年大学生大白天操逼| 在线不卡成人黄色精品| 欧美精品国产综合久久| 国产午夜激情福利小视频在线| 天天操天天干天天日狠狠插| 国产在线自在拍91国语自产精品| 色av色婷婷人妻久久久精品高清| 久久久久久久久久久久久97| 88成人免费av网站| 精品老妇女久久9g国产| 国产欧美精品一区二区高清| 75国产综合在线视频| 天天操天天插天天色| 免费无码人妻日韩精品一区二区| 国产va在线观看精品| 久久久久久99国产精品| 亚洲人成精品久久久久久久| 中文字幕日本人妻中出| 亚洲av一妻不如妾| 国产乱弄免费视频观看| 免费啪啪啪在线观看视频| 最新欧美一二三视频| 红杏久久av人妻一区| 天天操夜夜骑日日摸| 99av国产精品欲麻豆| 性色av一区二区三区久久久| 国产视频网站一区二区三区| 白白操白白色在线免费视频| 国产成人无码精品久久久电影| 韩国爱爱视频中文字幕| 国产精品亚洲а∨天堂免| 欧美精品伦理三区四区| 日本熟女精品一区二区三区| 欧美老鸡巴日小嫩逼| 93精品视频在线观看| 国产精品自拍偷拍a| 国产自拍在线观看成人| av中文字幕在线观看第三页| 欧美视频综合第一页| 亚洲第一黄色在线观看| 国产一区二区在线欧美| 日韩中文字幕精品淫| 1000部国产精品成人观看视频 | 一色桃子人妻一区二区三区| 亚洲va天堂va国产va久| 天堂女人av一区二区| 日韩美女综合中文字幕pp| 亚洲av无码成人精品区辽| 18禁精品网站久久| 精品国产成人亚洲午夜| 伊人网中文字幕在线视频| 在线观看av亚洲情色| 精品区一区二区三区四区人妻 | 播放日本一区二区三区电影| 极品粉嫩小泬白浆20p主播| 免费在线观看视频啪啪| 天美传媒mv视频在线观看| 亚洲在线观看中文字幕av| 1区2区3区不卡视频| 国产亚洲欧美视频网站| 93人妻人人揉人人澡人人| 55夜色66夜色国产精品站| 日本韩国免费福利精品| 揄拍成人国产精品免费看视频| 黄片大全在线观看观看| 亚洲国产欧美一区二区三区…| 日比视频老公慢点好舒服啊| 性生活第二下硬不起来| 在线观看的a站 最新| 性色蜜臀av一区二区三区| 天天日天天做天天日天天做| 欧美一区二区三区在线资源| 亚洲成人三级在线播放| 亚洲人一区二区中文字幕| 亚洲av极品精品在线观看| 亚洲av午夜免费观看| 亚洲第一伊人天堂网| 欧美黑人性暴力猛交喷水| 男人在床上插女人视频| 自拍偷区二区三区麻豆| 91高清成人在线视频| 视频一区二区综合精品| 亚洲天堂第一页中文字幕| 国产精品视频男人的天堂| av一本二本在线观看| 国产三级影院在线观看| 亚洲免费国产在线日韩| 人人爽亚洲av人人爽av| 亚洲人妻视频在线网| 国产一区成人在线观看视频| 亚洲 自拍 色综合图| 岳太深了紧紧的中文字幕| 91精品国产高清自在线看香蕉网 | 国产熟妇一区二区三区av | 五月婷婷在线观看视频免费| 香蕉aⅴ一区二区三区| 91久久国产成人免费网站| 国产精品久久久久网| 岛国av高清在线成人在线| 亚洲一区av中文字幕在线观看| 亚洲美女自偷自拍11页| 最新黄色av网站在线观看| 成年午夜免费无码区| 欧美特色aaa大片| 九色porny九色9l自拍视频| 成人av久久精品一区二区| 大骚逼91抽插出水视频| 66久久久久久久久久久| 亚洲av在线观看尤物| 亚洲熟色妇av日韩熟色妇在线| 偷拍3456eee| 2018在线福利视频| 五月天色婷婷在线观看视频免费| 免费国产性生活视频| 国产亚洲欧美45p| 40道精品招牌菜特色| 国产性感美女福利视频| 中文字幕综合一区二区| 丝袜国产专区在线观看| 国产成人精品一区在线观看| 老司机福利精品免费视频一区二区 | 综合一区二区三区蜜臀| 欧美成人综合色在线噜噜| 日韩成人免费电影二区| 天天操天天干天天日狠狠插 | 亚洲欧洲av天堂综合| 五十路熟女人妻一区二| 国产精品久久久久网| 一区国内二区日韩三区欧美| 亚洲高清视频在线不卡| 免费大片在线观看视频网站| 久久久久国产成人精品亚洲午夜| 清纯美女在线观看国产| 国产精品视频男人的天堂| 午夜精品一区二区三区城中村| av在线免费观看亚洲天堂| jiujiure精品视频在线| 端庄人妻堕落挣扎沉沦| 91色秘乱一区二区三区| 日本韩国在线观看一区二区| 亚洲码av无色中文| 日本男女操逼视频免费看| 日噜噜噜夜夜噜噜噜天天噜噜噜| 青青草在观免费国产精品| 宅男噜噜噜666免费观看| 日韩欧美高清免费在线| 天天操天天干天天日狠狠插| 狠狠嗨日韩综合久久| 桃色视频在线观看一区二区 | 精品欧美一区二区vr在线观看 | 啪啪啪啪啪啪啪啪av| 18禁网站一区二区三区四区| 国产1区,2区,3区| 亚洲青青操骚货在线视频| 大黑人性xxxxbbbb| 又粗又硬又猛又爽又黄的| 欧美亚洲免费视频观看| 亚洲精品在线资源站| 精品黑人巨大在线一区| 天天日天天天天天天天天天天| 蜜桃视频入口久久久| 又色又爽又黄又刺激av网站| 啊啊啊视频试看人妻| 沈阳熟妇28厘米大战黑人| 91福利视频免费在线观看| 中文字幕免费福利视频6| 欧美视频中文一区二区三区| 日韩欧美一级黄片亚洲| 粉嫩欧美美人妻小视频| 最新中文字幕免费视频| 男人靠女人的逼视频| 欧美亚洲一二三区蜜臀| 国产麻豆精品人妻av| 亚洲精品国产在线电影| 亚洲午夜电影之麻豆| 日韩亚洲高清在线观看| 91色老99久久九九爱精品| 最新中文字幕免费视频| 18禁网站一区二区三区四区| 中文字幕av第1页中文字幕| 丰满少妇人妻xxxxx| 亚洲av日韩精品久久久久久hd| 久久久精品国产亚洲AV一| 日本阿v视频在线免费观看| 内射久久久久综合网| 成人24小时免费视频| 精品一区二区三区午夜| 78色精品一区二区三区| 午夜大尺度无码福利视频| av资源中文字幕在线观看| 爆乳骚货内射骚货内射在线 | 玖玖一区二区在线观看| 不卡日韩av在线观看| 亚洲最大免费在线观看| 成年女人免费播放视频| 国产a级毛久久久久精品| 中文字幕人妻av在线观看| 9国产精品久久久久老师| 国产精品中文av在线播放| 欧美男人大鸡吧插女人视频| 日本三极片视频网站观看| 欧美viboss性丰满| av手机免费在线观看高潮| 精品av国产一区二区三区四区| 欧美一区二区中文字幕电影| 国产精品系列在线观看一区二区 | 老司机深夜免费福利视频在线观看| 99热国产精品666| 亚洲综合在线观看免费| 久久热久久视频在线观看| 91亚洲手机在线视频播放| 日曰摸日日碰夜夜爽歪歪| 老鸭窝日韩精品视频观看| 黄页网视频在线免费观看| 欧美精品国产综合久久| 日本美女性生活一级片| 亚洲图库另类图片区| 中国熟女一区二区性xx| 亚洲中文字字幕乱码| 国产精品国产三级国产午| 一区二区三区视频,福利一区二区 丰满的子国产在线观看 | av完全免费在线观看av| 亚洲精品福利网站图片| 福利片区一区二体验区| 国产日韩欧美美利坚蜜臀懂色| 黄色大片男人操女人逼| 亚洲成人av在线一区二区| 欧美亚洲少妇福利视频| 福利视频广场一区二区| 91麻豆精品91久久久久同性| 97香蕉碰碰人妻国产樱花| 亚洲欧美成人综合视频| 日韩美女搞黄视频免费| 夜女神免费福利视频| 天堂av在线官网中文| 国产精品污污污久久| 老鸭窝在线观看一区| 欧美专区第八页一区在线播放| aⅴ精产国品一二三产品| 亚洲码av无色中文| 中文字幕亚洲中文字幕| 超碰中文字幕免费观看| 人妻少妇一区二区三区蜜桃| 少妇人妻100系列| 综合精品久久久久97| 动漫黑丝美女的鸡巴| 久久艹在线观看视频| 中文字幕高清资源站| av久久精品北条麻妃av观看 | 亚洲国产成人最新资源| 国产真实灌醉下药美女av福利| 亚洲精品麻豆免费在线观看| 国产极品美女久久久久久| 亚洲一区二区人妻av| 91桃色成人网络在线观看| av在线shipin| 啊用力插好舒服视频| 色狠狠av线不卡香蕉一区二区| 成熟熟女国产精品一区| 国产精品午夜国产小视频| 97国产在线观看高清| 特大黑人巨大xxxx| 少妇被强干到高潮视频在线观看| av一区二区三区人妻| 红杏久久av人妻一区| 亚洲熟妇久久无码精品| 91精品高清一区二区三区| 红杏久久av人妻一区| 亚洲超碰97人人做人人爱| 初美沙希中文字幕在线| 精品人人人妻人人玩日产欧| 18禁网站一区二区三区四区 | 老司机免费福利视频网| 欧美在线一二三视频| 久久美欧人妻少妇一区二区三区 | 亚洲熟女女同志女同| 亚洲一区二区激情在线|