国产无遮挡裸体免费直播视频,久久精品国产蜜臀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)論

99久久99一区二区三区| 成人av天堂丝袜在线观看| 亚洲女人的天堂av| 国产一区二区久久久裸臀| 青娱乐在线免费视频盛宴| 人妻丝袜精品中文字幕| 国产极品美女久久久久久| 中文字幕在线第一页成人| 国产av自拍偷拍盛宴| 97a片免费在线观看| 新97超碰在线观看| 天天日天天干天天插舔舔| 国产成人一区二区三区电影网站| 在线观看欧美黄片一区二区三区| 欧美日韩一级黄片免费观看| 日韩av中文在线免费观看| 日韩亚洲高清在线观看| 五十路人妻熟女av一区二区| 91试看福利一分钟| 天天想要天天操天天干| aaa久久久久久久久| av中文字幕电影在线看| 91久久国产成人免费网站| 欧美偷拍自拍色图片| 18禁网站一区二区三区四区| 一级黄色片夫妻性生活| 天天干天天啪天天舔| 欧美性受xx黑人性猛交| 91精品一区二区三区站长推荐| 一区二区三区另类在线| 天天通天天透天天插| 91麻豆精品传媒国产黄色片| 中文亚洲欧美日韩无线码| 国产精品国产三级麻豆| 亚洲成人午夜电影在线观看| 国产自拍在线观看成人| 午夜的视频在线观看| 97超碰免费在线视频| 午夜大尺度无码福利视频| 亚洲天堂第一页中文字幕| jiuse91九色视频| 综合激情网激情五月五月婷婷| 国产男女视频在线播放| 国产精品久久久久久久精品视频| 欧美成人综合色在线噜噜| av天堂加勒比在线| 午夜激情精品福利视频| 9l人妻人人爽人人爽| 亚洲av日韩高清hd| 888欧美视频在线| 亚洲欧美激情人妻偷拍| 亚洲自拍偷拍精品网| 亚洲va国产va欧美va在线| 51国产偷自视频在线播放| 91极品大一女神正在播放| 激情啪啪啪啪一区二区三区| 另类av十亚洲av| 亚洲麻豆一区二区三区| 秋霞午夜av福利经典影视| 天堂av狠狠操蜜桃| 在线免费观看日本片| 欧美成人精品欧美一级黄色| 免费看国产又粗又猛又爽又黄视频 | 非洲黑人一级特黄片| 欧美一区二区三区久久久aaa| 青草青永久在线视频18| 成人区人妻精品一区二视频| 欧美日本在线观看一区二区| japanese日本熟妇另类| 日韩激情文学在线视频| 黄色成年网站午夜在线观看| 国产乱弄免费视频观看| 久久麻豆亚洲精品av| 国产熟妇人妻ⅹxxxx麻豆| 晚上一个人看操B片| 韩国黄色一级二级三级| 综合精品久久久久97| 欧美在线偷拍视频免费看| 人妻少妇亚洲精品中文字幕| 国产妇女自拍区在线观看| 91中文字幕最新合集| 欧美性受xx黑人性猛交| 一区二区三区的久久的蜜桃的视频 | 中文字幕日本人妻中出| 最新97国产在线视频| 久久丁香婷婷六月天| 午夜福利资源综合激情午夜福利资 | chinese国产盗摄一区二区| 激情国产小视频在线| 人妻凌辱欧美丰满熟妇| 亚洲人妻30pwc| 亚洲最大黄 嗯色 操 啊| 日本午夜久久女同精女女| 亚洲av色图18p| 欧美日韩一区二区电影在线观看| 在线免费观看日本伦理| 粉嫩av懂色av蜜臀av| 综合精品久久久久97| 精品黑人一区二区三区久久国产| 91久久国产成人免费网站| 中文字幕 人妻精品| 91精品高清一区二区三区| 好吊视频—区二区三区| 97精品视频在线观看| 免费费一级特黄真人片| 亚洲特黄aaaa片| 99精品久久久久久久91蜜桃| 天天操天天操天天碰| 在线国产中文字幕视频| 不卡日韩av在线观看| 99久久99一区二区三区| 人妻无码色噜噜狠狠狠狠色 | 亚洲福利天堂久久久久久 | 黄网十四区丁香社区激情五月天| 夜夜骑夜夜操夜夜奸| 国产亚洲四十路五十路| 国产精彩对白一区二区三区| 午夜精品久久久久久99热| 成人国产小视频在线观看| 亚洲一区二区三区偷拍女厕91 | 成年人黄色片免费网站| 国产精品久久久久久美女校花| 国产精品人妻熟女毛片av久| av在线免费观看亚洲天堂| 91自产国产精品视频| 色婷婷综合激情五月免费观看| 77久久久久国产精产品| 男女之间激情网午夜在线| 岛国黄色大片在线观看| 中文字幕一区二区三区蜜月| 日韩美av高清在线| 欧美一区二区三区高清不卡tv| 亚洲男人让女人爽的视频| 久久丁香婷婷六月天| 欧洲亚洲欧美日韩综合| 在线观看成人国产电影| 91色网站免费在线观看| 精品首页在线观看视频| 99精品视频之69精品视频| 欧洲国产成人精品91铁牛tv| 精品乱子伦一区二区三区免费播 | 综合国产成人在线观看| 夏目彩春在线中文字幕| 自拍偷拍日韩欧美亚洲| 97人妻夜夜爽二区欧美极品| 直接能看的国产av| 粉嫩小穴流水视频在线观看| 婷婷激情四射在线观看视频| 偷青青国产精品青青在线观看| 亚洲一区二区三区av网站| 97少妇精品在线观看| aⅴ五十路av熟女中出| 午夜激情精品福利视频| 非洲黑人一级特黄片| 青青擦在线视频国产在线| 边摸边做超爽毛片18禁色戒| 欧美日韩激情啪啪啪| 91人妻人人做人人爽在线| 青娱乐在线免费视频盛宴| 少妇露脸深喉口爆吞精| 五月天色婷婷在线观看视频免费| 最新中文字幕乱码在线| 亚洲变态另类色图天堂网| 中文字幕亚洲中文字幕| 在线观看欧美黄片一区二区三区| 成人免费公开视频无毒 | 早川濑里奈av黑人番号| 黄片大全在线观看观看| 精品久久久久久高潮| 青青青青操在线观看免费| 桃色视频在线观看一区二区 | 97人妻夜夜爽二区欧美极品| 青青青激情在线观看视频| 人妻无码色噜噜狠狠狠狠色| 91片黄在线观看喷潮| 成人福利视频免费在线| 欧亚日韩一区二区三区观看视频| 红桃av成人在线观看| 成人久久精品一区二区三区| 中文字幕在线乱码一区二区| 午夜毛片不卡免费观看视频| 福利视频一区二区三区筱慧 | brazzers欧熟精品系列| 中文字幕在线观看极品视频| 国产精品国色综合久久| 青青青国产片免费观看视频| 99的爱精品免费视频| 亚洲成人国产综合一区| 五色婷婷综合狠狠爱| 激情五月婷婷免费视频| 国产女人露脸高潮对白视频| 美洲精品一二三产区区别| 日本免费午夜视频网站| 亚洲人妻av毛片在线| 久久久久久9999久久久久| 久久久久只精品国产三级| 国产女孩喷水在线观看| 综合页自拍视频在线播放| 久久永久免费精品人妻专区| 亚洲成人av在线一区二区| 国产精品系列在线观看一区二区| 国产极品精品免费视频| 中文字幕熟女人妻久久久| av在线资源中文字幕| 久久久久久久99精品| 国产白袜脚足J棉袜在线观看| 青青草人人妻人人妻| 黑人变态深video特大巨大| 欧美一区二区三区激情啪啪啪| 亚国产成人精品久久久| 手机看片福利盒子日韩在线播放 | av在线观看网址av| 成人免费公开视频无毒| 91she九色精品国产| 亚洲少妇高潮免费观看| 男人和女人激情视频| 天天插天天色天天日| 最新日韩av传媒在线| 成人av久久精品一区二区| 久久一区二区三区人妻欧美| 中文字幕高清免费在线人妻 | 国产精品自拍视频大全| 福利视频网久久91| 日本免费视频午夜福利视频| 亚洲激情,偷拍视频| 9久在线视频只有精品| 国产内射中出在线观看| 一区二区三区美女毛片| 国产污污污污网站在线| 亚洲国产免费av一区二区三区| 国产又粗又黄又硬又爽| 密臀av一区在线观看| 青青青青青免费视频| 少妇人妻久久久久视频黄片| 日本av在线一区二区三区| 这里只有精品双飞在线播放| 色综合久久五月色婷婷综合| 免费在线看的黄片视频| 国产伦精品一区二区三区竹菊| 超级av免费观看一区二区三区| 日本av熟女在线视频| 精产国品久久一二三产区区别| 中国黄片视频一区91| 黑人乱偷人妻中文字幕| 国产精品自拍在线视频| 真实国模和老外性视频| 日本一二三区不卡无| av大全在线播放免费| 日日爽天天干夜夜操| 免费男阳茎伸入女阳道视频| 福利在线视频网址导航| 日美女屁股黄邑视频| 亚洲区欧美区另类最新章节| 美女福利视频网址导航| 亚洲av可乐操首页| 中文字母永久播放1区2区3区| 激情内射在线免费观看| 大黑人性xxxxbbbb| 亚洲欧美一卡二卡三卡| 抽查舔水白紧大视频| 免费在线福利小视频| 人妻av无码专区久久绿巨人| 色偷偷伊人大杳蕉综合网| 9久在线视频只有精品| 久久这里只有精品热视频| 中国熟女@视频91| 蜜臀成人av在线播放| 99热碰碰热精品a中文| 日韩剧情片电影在线收看| 91国偷自产一区二区三区精品| 91人妻人人做人人爽在线| 97精品人妻一区二区三区精品| wwwxxx一级黄色片| 91国偷自产一区二区三区精品| 男人插女人视频网站| 夫妻在线观看视频91| 欧亚乱色一区二区三区| 国产精品国产精品一区二区| 午夜91一区二区三区| 自拍 日韩 欧美激情| 精品一区二区三区午夜| 一级黄色片夫妻性生活| 午夜国产免费福利av| 国产精品黄页网站视频| 亚洲精品午夜久久久久| 国产午夜福利av导航| 精品视频中文字幕在线播放| 国产福利小视频二区| 天天射,天天操,天天说| 美女张开腿让男生操在线看| 18禁美女无遮挡免费| 92福利视频午夜1000看| 天天操夜夜骑日日摸| 熟女在线视频一区二区三区| weyvv5国产成人精品的视频| 成人性黑人一级av| 欧美80老妇人性视频| 欧美地区一二三专区| 蝴蝶伊人久久中文娱乐网| 一区二区三区另类在线| 久久久噜噜噜久久熟女av| 2021天天色天天干| 五月婷婷在线观看视频免费| 日本裸体熟妇区二区欧美| 国产又大又黄免费观看| 瑟瑟视频在线观看免费视频| asmr福利视频在线观看| 精品一区二区三区三区色爱| 美女张开两腿让男人桶av| 人人妻人人爽人人添夜| 韩国爱爱视频中文字幕| 日韩少妇人妻精品无码专区| 日韩在线中文字幕色| 97精品人妻一区二区三区精品| 一个人免费在线观看ww视频| 欧美成人一二三在线网| 岛国免费大片在线观看| 黄色成年网站午夜在线观看| 超黄超污网站在线观看| 亚洲va国产va欧美精品88| 欧美另类重口味极品在线观看| 亚国产成人精品久久久| 都市激情校园春色狠狠| 91成人在线观看免费视频| 日本av熟女在线视频| 少妇与子乱在线观看| 狠狠嗨日韩综合久久| 亚洲欧美在线视频第一页| 97精品综合久久在线| 中国产一级黄片免费视频播放| 国产精品国产三级国产精东 | 亚洲国产精品免费在线观看| 欧美成人综合色在线噜噜| 成人资源在线观看免费官网| 国产一区二区火爆视频| 天天做天天干天天舔| 老司机福利精品免费视频一区二区 | 亚洲自拍偷拍精品网| 亚洲综合一区成人在线| 日视频免费在线观看| 欧美精品久久久久久影院| 亚洲国产中文字幕啊啊啊不行了| 久久久久久97三级| 色综合久久久久久久久中文| jiujiure精品视频在线| 婷婷色国产黑丝少妇勾搭AV| 女同久久精品秋霞网| 亚洲精品国产在线电影| 日韩近亲视频在线观看| 啪啪啪啪啪啪啪免费视频| 青青色国产视频在线| 特级欧美插插插插插bbbbb| 一区二区三区日本伦理| www日韩毛片av| 国产又粗又硬又大视频| 国产午夜亚洲精品不卡在线观看| 91天堂精品一区二区| 亚洲欧美一区二区三区爱爱动图| 777奇米久久精品一区| 成年午夜免费无码区| av中文字幕网址在线| 中文字幕在线观看国产片| 韩国男女黄色在线观看| 天堂中文字幕翔田av| aiss午夜免费视频| 天天日天天舔天天射进去| 综合精品久久久久97| 日韩成人综艺在线播放| 97人妻无码AV碰碰视频| av手机在线免费观看日韩av| 天天日夜夜干天天操| 亚洲av黄色在线网站| www,久久久,com| 九色porny九色9l自拍视频| 日韩av中文在线免费观看| 国产综合视频在线看片| 亚洲免费在线视频网站| 91香蕉成人app下载| 中文字幕免费在线免费| 国产乱子伦一二三区| 在线免费观看av日韩| 欧美美女人体视频一区| 孕妇奶水仑乱A级毛片免费看| 91精品国产91青青碰| 日本美女性生活一级片| 国产性色生活片毛片春晓精品| 日韩av有码中文字幕| 亚洲1卡2卡三卡4卡在线观看| 日本精品一区二区三区在线视频。| 国产麻豆剧传媒精品国产av蜜桃| 777奇米久久精品一区| 啊啊啊想要被插进去视频| 人妻少妇精品久久久久久| 2021最新热播中文字幕| 成人蜜桃美臀九一一区二区三区| 亚洲成人线上免费视频观看| 动漫av网站18禁| 国产视频一区在线观看| 日本熟妇丰满厨房55| 精品91高清在线观看| 亚洲特黄aaaa片| 偷拍自拍福利视频在线观看| 国产一级精品综合av| 国产一区二区在线欧美| 国产性色生活片毛片春晓精品| 任你操视频免费在线观看| 91色秘乱一区二区三区| av天堂中文免费在线| 一区国内二区日韩三区欧美| 久草视频在线免播放| 亚洲高清自偷揄拍自拍| 一区二区三区综合视频| 男女第一次视频在线观看| 亚洲精品午夜aaa久久| 天天日天天玩天天摸| 国产a级毛久久久久精品| 中文人妻AV久久人妻水| 久久久久只精品国产三级| 日韩中文字幕在线播放第二页| 国产精品久久久久久久女人18| 97精品综合久久在线| 免费看高清av的网站| 婷婷色中文亚洲网68| 亚洲一区二区三区久久午夜 | 午夜福利资源综合激情午夜福利资| 亚洲变态另类色图天堂网| 一级a看免费观看网站| 国产真实灌醉下药美女av福利| 亚洲嫩模一区二区三区| 一区二区三区综合视频| 中文字幕在线乱码一区二区 | 中文字幕在线乱码一区二区| 亚洲va欧美va人人爽3p| 天堂av在线官网中文| 成人区人妻精品一区二视频| 涩爱综合久久五月蜜臀| 亚洲av成人网在线观看| 青青青青青青草国产| 国产普通话插插视频| 亚洲色偷偷综合亚洲AV伊人| 久久一区二区三区人妻欧美| 国产一级麻豆精品免费| 日韩三级电影华丽的外出| 亚洲国产美女一区二区三区软件| 中文字幕1卡1区2区3区| 久久免费看少妇高潮完整版| 人妻爱爱 中文字幕| 38av一区二区三区| 天天干天天日天天干天天操| 中英文字幕av一区| 亚洲欧美另类手机在线| 中文乱理伦片在线观看| 一个色综合男人天堂| 欧美日韩高清午夜蜜桃大香蕉| 亚洲成人熟妇一区二区三区| 人妻爱爱 中文字幕| 久久久久久久亚洲午夜综合福利| 福利视频广场一区二区| 亚洲精品乱码久久久本| 久久机热/这里只有| caoporn蜜桃视频| 5528327男人天堂| 少妇人妻二三区视频| 国产日韩精品免费在线| 亚洲欧美日韩视频免费观看| 天天摸天天干天天操科普 | av在线shipin| 一级a看免费观看网站| 久久久久久久一区二区三| 性欧美日本大妈母与子| 久久久制服丝袜中文字幕| 1024久久国产精品| 天天色天天舔天天射天天爽| 欧美成人猛片aaaaaaa| 久久久久只精品国产三级| 精品一区二区三区三区88 | 一区二区三区国产精选在线播放 | 亚洲狠狠婷婷综合久久app| 又粗又硬又猛又爽又黄的| 在线观看911精品国产| 久久这里只有精彩视频免费| 国产白嫩美女一区二区| 精品黑人一区二区三区久久国产| 国产精品午夜国产小视频| 久久久久久久亚洲午夜综合福利| 扒开让我视频在线观看| 在线免费91激情四射| 亚洲午夜高清在线观看| 99热这里只有精品中文| 日视频免费在线观看| 精品国产在线手机在线| 日本真人性生活视频免费看| 欧美黑人巨大性xxxxx猛交| 国产91久久精品一区二区字幕| 精品人妻一二三区久久| 亚洲熟女综合色一区二区三区四区| 日本后入视频在线观看| 57pao国产一区二区| 特大黑人巨大xxxx| 99热这里只有精品中文| 国产精品精品精品999| 日本后入视频在线观看| 97瑟瑟超碰在线香蕉| 青娱乐在线免费视频盛宴 | 亚洲 中文 自拍 另类 欧美 | 日噜噜噜夜夜噜噜噜天天噜噜噜| 3344免费偷拍视频| 自拍偷拍日韩欧美亚洲| 日韩美女综合中文字幕pp| 特一级特级黄色网片| av中文字幕在线导航| av在线观看网址av| 国产亚洲精品视频合集| 韩国爱爱视频中文字幕| 青青青视频自偷自拍38碰| 天天干天天插天天谢| 欧美一区二区三区啪啪同性| 啊啊啊视频试看人妻| 丰满熟女午夜福利视频| 大胆亚洲av日韩av| 亚洲 中文 自拍 另类 欧美| 青青色国产视频在线| 国产日韩一区二区在线看| 久草视频在线一区二区三区资源站| 被大鸡吧操的好舒服视频免费| 99婷婷在线观看视频| 日本一道二三区视频久久 | 91精品一区二区三区站长推荐| 在线视频这里只有精品自拍| 涩爱综合久久五月蜜臀| 成人影片高清在线观看| 欧洲国产成人精品91铁牛tv| 欧美麻豆av在线播放| 日本后入视频在线观看| 热久久只有这里有精品| 超pen在线观看视频公开97| 韩国黄色一级二级三级| nagger可以指黑人吗| 国产三级片久久久久久久 | 777奇米久久精品一区| 亚洲国产精品免费在线观看| 888欧美视频在线| 日本人妻欲求不满中文字幕| 男人的网址你懂的亚洲欧洲av| 久久尻中国美女视频| 黄色三级网站免费下载| 无忧传媒在线观看视频| 午夜福利资源综合激情午夜福利资| 可以在线观看的av中文字幕| 搞黄色在线免费观看| 老师啊太大了啊啊啊尻视频| 日本黄色三级高清视频| 人妻自拍视频中国大陆| 自拍偷拍亚洲欧美在线视频| av大全在线播放免费| 天天射,天天操,天天说| 久久精品美女免费视频| 中文字幕日韩精品日本| 亚洲国产最大av综合| 国产精品成人xxxx| 久久久久久九九99精品| 九九热99视频在线观看97| 伊人情人综合成人久久网小说| 精品国产午夜视频一区二区| 免费看高清av的网站| 免费av岛国天堂网站| 亚洲欧美自拍另类图片| 亚洲综合另类欧美久久| 国产精品久久久黄网站| 91国产在线免费播放| 精品91高清在线观看| 4个黑人操素人视频网站精品91| 黄色片一级美女黄色片| 888欧美视频在线| 成人性爱在线看四区| www久久久久久久久久久| 大尺度激情四射网站| 精品久久久久久久久久久久人妻| 成人色综合中文字幕| 日韩中文字幕福利av| 成人蜜臀午夜久久一区| 国产福利小视频大全| 日韩欧美一级黄片亚洲| 动漫av网站18禁| 在线观看的a站 最新| h国产小视频福利在线观看| 福利视频一区二区三区筱慧| eeuss鲁片一区二区三区| 天天日天天添天天爽| 后入美女人妻高清在线| 999九九久久久精品| 大鸡吧插入女阴道黄色片| 国产日本精品久久久久久久| 1区2区3区4区视频在线观看| 久久精品36亚洲精品束缚| 中文字幕一区二区三区人妻大片| 天堂av狠狠操蜜桃| 最新的中文字幕 亚洲| 国产视频一区二区午夜| av手机免费在线观看高潮| AV无码一区二区三区不卡| av完全免费在线观看av| 1000部国产精品成人观看视频| 青青草原色片网站在线观看| 人妻熟女中文字幕aⅴ在线| 啪啪啪啪啪啪啪免费视频| 亚洲精品无码久久久久不卡| 久久亚洲天堂中文对白| 国产视频一区在线观看| 伊人综合aⅴ在线网| 日本xx片在线观看| 丰满的继坶3中文在线观看| 中文字幕第一页国产在线| 韩国爱爱视频中文字幕| 秋霞午夜av福利经典影视| 老师啊太大了啊啊啊尻视频| 香蕉aⅴ一区二区三区| 只有精品亚洲视频在线观看| 美女操逼免费短视频下载链接 | 精品一区二区三区在线观看| 中文字幕人妻三级在线观看| 天天日天天干天天要| 国产黄色片在线收看| 亚洲精品福利网站图片| 免费黄色成人午夜在线网站| 午夜美女少妇福利视频| 熟女人妻一区二区精品视频| 欧美精品国产综合久久| 好了av中文字幕在线| 日韩av有码中文字幕| 女警官打开双腿沦为性奴| 天天操天天干天天日狠狠插| 青青草在观免费国产精品| 人妻少妇av在线观看| 天天干夜夜操天天舔| 国产精品黄页网站视频| 性欧美激情久久久久久久| 欧美亚洲一二三区蜜臀| av资源中文字幕在线观看| 91国语爽死我了不卡| 超碰97免费人妻麻豆| 青娱乐极品视频青青草| 91一区精品在线观看| 日韩加勒比东京热二区| 亚洲少妇高潮免费观看| 天天综合天天综合天天网| 男女之间激情网午夜在线| 91久久人澡人人添人人爽乱| jiuse91九色视频| 日本人妻欲求不满中文字幕| 青青青青操在线观看免费| 欧美80老妇人性视频| 香蕉片在线观看av| 中文字幕日韩无敌亚洲精品| 骚货自慰被发现爆操| 亚洲av琪琪男人的天堂| 国产a级毛久久久久精品| 女生自摸在线观看一区二区三区| 亚洲欧美久久久久久久久| 天天射夜夜操综合网| 一区二区久久成人网| 91中文字幕最新合集| 91chinese在线视频| 操人妻嗷嗷叫视频一区二区| 91传媒一区二区三区| 日韩写真福利视频在线观看| 中文字幕高清在线免费播放| 97精品综合久久在线| 一区二区三区久久久91| 日韩三级电影华丽的外出| 成年人午夜黄片视频资源| 18禁精品网站久久| 久久久久五月天丁香社区| 亚洲午夜精品小视频| 99热久久这里只有精品8| 毛茸茸的大外阴中国视频| 在线国产精品一区二区三区| 国产伦精品一区二区三区竹菊| 免费福利av在线一区二区三区| 中国视频一区二区三区| 粉嫩av懂色av蜜臀av| 日韩二区视频一线天婷婷五| 中文字幕高清资源站| 国际av大片在线免费观看| 日韩写真福利视频在线观看| 国产中文精品在线观看| 最新中文字幕免费视频| 亚洲男人在线天堂网| 边摸边做超爽毛片18禁色戒| 亚洲图片偷拍自拍区| 9国产精品久久久久老师| 国产揄拍高清国内精品对白| 91 亚洲视频在线观看| 日本熟妇一区二区x x| 东游记中文字幕版哪里可以看到| 姐姐的朋友2在线观看中文字幕| 极品丝袜一区二区三区| 影音先锋女人av噜噜色| 韩国爱爱视频中文字幕| 亚洲熟妇x久久av久久| 日本三极片视频网站观看| 女警官打开双腿沦为性奴| 高潮喷水在线视频观看| 午夜成午夜成年片在线观看 | 97青青青手机在线视频 | 人妻av无码专区久久绿巨人| 高清成人av一区三区| 把腿张开让我插进去视频| av网站色偷偷婷婷网男人的天堂| 中文字幕—97超碰网| 国产成人精品福利短视频| 91精品激情五月婷婷在线| 色噜噜噜噜18禁止观看| 换爱交换乱高清大片| 最新激情中文字幕视频| 在线可以看的视频你懂的 | 亚洲欧美综合在线探花| 91麻豆精品秘密入口在线观看| 2022国产精品视频| 韩国亚洲欧美超一级在线播放视频| 国产精品久久久黄网站| 97青青青手机在线视频| 在线网站你懂得老司机| 岛国免费大片在线观看| 麻豆精品成人免费视频| 成人高潮aa毛片免费| 欧美一区二区三区在线资源 | 亚洲一区久久免费视频| 91精品一区二区三区站长推荐| 国产精品国产三级国产午| 一区二区三区蜜臀在线| 在线视频国产欧美日韩| 水蜜桃一区二区三区在线观看视频| 亚洲福利午夜久久久精品电影网| 超级av免费观看一区二区三区| 大香蕉伊人中文字幕| 青青社区2国产视频| 中出中文字幕在线观看| 99人妻视频免费在线| 成人av久久精品一区二区| 亚洲视频在线观看高清| 第一福利视频在线观看| 亚洲va国产va欧美va在线| 国产成人精品福利短视频| 国产av一区2区3区| 亚洲 中文 自拍 另类 欧美| 激情五月婷婷免费视频| 中文字幕中文字幕人妻| 免费看美女脱光衣服的视频| 久草视频中文字幕在线观看| 啪啪啪18禁一区二区三区 | 成人av免费不卡在线观看| 亚洲一区二区三区五区| 天天日天天干天天舔天天射| 国产乱子伦精品视频潮优女| 日日爽天天干夜夜操| 亚洲国产精品久久久久久6| 亚洲综合在线视频可播放| 午夜激情久久不卡一区二区 | 风流唐伯虎电视剧在线观看| 亚洲最大黄了色网站| 国产性生活中老年人视频网站| 一级A一级a爰片免费免会员| av中文字幕在线观看第三页| 亚洲国产40页第21页| 日本美女性生活一级片| 亚洲视频在线视频看视频在线| 青青在线视频性感少妇和隔壁黑丝| 日韩欧美一级aa大片| 亚洲一区二区三区久久受| 国产久久久精品毛片| 在线国产日韩欧美视频| 国产之丝袜脚在线一区二区三区| 国产V亚洲V天堂无码欠欠 | 动漫黑丝美女的鸡巴| 99国产精品窥熟女精品| 欧美日韩一区二区电影在线观看| 人妻少妇中文有码精品| 欧美aa一级一区三区四区| 欧美黄色录像免费看的| 精品国产在线手机在线| 一区二区三区精品日本| 国产精品黄页网站视频| 99国产精品窥熟女精品| 青青青青草手机在线视频免费看| 唐人色亚洲av嫩草| 国产精品三级三级三级| 欧美一区二区三区高清不卡tv| 美女小视频网站在线| 国产亚洲天堂天天一区| 成人区人妻精品一区二视频| 日韩美女综合中文字幕pp| 日日夜夜大香蕉伊人| 97国产在线av精品| 91p0rny九色露脸熟女| 91精品国产黑色丝袜| 亚洲图片偷拍自拍区| 欧美一区二区三区久久久aaa| 欧美一区二区三区啪啪同性| 精品成人午夜免费看| 欧美日本在线视频一区| 日韩无码国产精品强奸乱伦| 亚国产成人精品久久久| 亚洲成人情色电影在线观看| 免费观看污视频网站| 一区二区三区蜜臀在线| 久久久人妻一区二区| 亚洲熟女女同志女同| 九九视频在线精品播放| 欧美日韩激情啪啪啪| 亚洲av色图18p| 999热精品视频在线| 欧美日韩精品永久免费网址 | aⅴ精产国品一二三产品| 直接观看免费黄网站| www日韩a级s片av| 国产精品一区二区三区蜜臀av| 国产精品一区二区三区蜜臀av| 午夜国产免费福利av| 欧美日韩一级黄片免费观看| 在线不卡日韩视频播放| 99av国产精品欲麻豆| 亚洲av自拍偷拍综合| 亚洲av色图18p| 18禁精品网站久久| 蜜桃视频入口久久久| gav成人免费播放| 国际av大片在线免费观看| 91精品国产高清自在线看香蕉网| 动漫av网站18禁| 欧美亚洲免费视频观看| 内射久久久久综合网| 1区2区3区不卡视频| 经典国语激情内射视频| 66久久久久久久久久久| 97精品成人一区二区三区| 五十路熟女人妻一区二| 乱亲女秽乱长久久久| 天天做天天干天天操天天射| 久久亚洲天堂中文对白| 人妻丝袜榨强中文字幕| 青青青国产片免费观看视频| 在线观看日韩激情视频| 蜜臀av久久久久久久| 青青草人人妻人人妻| 国产精品国产三级国产午| 大胆亚洲av日韩av| 亚洲一区二区三区uij| 99久久久无码国产精品性出奶水| 亚洲国产精品黑丝美女| 亚洲va天堂va国产va久| 国产不卡av在线免费| 91精品国产高清自在线看香蕉网| 午夜蜜桃一区二区三区| 视频一区 视频二区 视频| 中文字幕av男人天堂| 视频一区二区综合精品| 在线免费观看黄页视频| 精品国产在线手机在线| 中文字幕第1页av一天堂网| 在线播放一区二区三区Av无码| 性生活第二下硬不起来| 欧美亚洲国产成人免费在线 | 57pao国产一区二区| 美女福利写真在线观看视频| 91九色porny蝌蚪国产成人| 亚洲色偷偷综合亚洲AV伊人| 91精品国产黑色丝袜| mm131美女午夜爽爽爽| 欧美香蕉人妻精品一区二区| 中文字幕高清免费在线人妻| 肏插流水妹子在线乐播下载 | 丁香花免费在线观看中文字幕| av网站色偷偷婷婷网男人的天堂| 欧美日韩熟女一区二区三区| 精品亚洲中文字幕av | 亚洲欧美国产综合777| 亚洲另类伦春色综合小| 美女张开腿让男生操在线看| 99热这里只有精品中文| 91九色porny国产蝌蚪视频| 91国偷自产一区二区三区精品| 青青青爽视频在线播放| 国产一区二区久久久裸臀| 青青青激情在线观看视频| 亚洲Av无码国产综合色区| 亚洲福利精品福利精品福利| 偷拍自拍国产在线视频| 中文字幕一区二区三区蜜月| 污污小视频91在线观看| 天天摸天天日天天操| 99热这里只有国产精品6| 中文字幕在线永久免费播放| 成人乱码一区二区三区av| 亚洲码av无色中文| 亚洲精品无码久久久久不卡| 亚洲熟妇x久久av久久| 青娱乐极品视频青青草| 综合一区二区三区蜜臀| 中文字幕—97超碰网| 97超碰免费在线视频| 久久久超爽一二三av| 青青青aaaa免费| av在线shipin| 91老熟女连续高潮对白| 欧美黑人与人妻精品| 黄色成年网站午夜在线观看| 大尺度激情四射网站| 欧美80老妇人性视频| 亚洲天堂精品福利成人av| 在线免费观看欧美小视频| 中文字幕+中文字幕| 果冻传媒av一区二区三区| 亚洲精品国偷自产在线观看蜜桃| 成年人黄色片免费网站| 九九热99视频在线观看97| 国产剧情演绎系列丝袜高跟| asmr福利视频在线观看| 天天日天天摸天天爱| 男生用鸡操女生视频动漫| 最新91九色国产在线观看| 亚洲精品乱码久久久久久密桃明 | 亚洲欧美激情中文字幕| 91精品资源免费观看| 黄网十四区丁香社区激情五月天 | 久久久久久久亚洲午夜综合福利 | 亚洲激情偷拍一区二区| 人妻丰满熟妇综合网| 日韩美女搞黄视频免费| 色花堂在线av中文字幕九九| 久久久久91精品推荐99| 99热这里只有国产精品6| 极品粉嫩小泬白浆20p主播| 大香蕉福利在线观看| 91破解版永久免费| 少妇高潮无套内谢麻豆| 人妻久久久精品69系列| 国产剧情演绎系列丝袜高跟| 精品黑人一区二区三区久久国产| 55夜色66夜色国产精品站| 国产日韩欧美美利坚蜜臀懂色| av日韩在线观看大全| 又黄又刺激的午夜小视频| 人人爱人人妻人人澡39| 亚洲国产精品免费在线观看| 亚洲综合另类精品小说| 偷偷玩弄新婚人妻h视频| 在线亚洲天堂色播av电影| 人妻自拍视频中国大陆| 色婷婷精品大在线观看| 国产成人精品久久二区91| 亚洲免费视频欧洲免费视频| 熟女少妇激情五十路| 精品视频一区二区三区四区五区| 91麻豆精品久久久久| 亚洲成人av一区在线| 2020中文字幕在线播放| 极品丝袜一区二区三区| av在线免费中文字幕| 女生自摸在线观看一区二区三区 | 精品一区二区三四区| 日本黄色特一级视频| av资源中文字幕在线观看| 亚洲va天堂va国产va久| 亚洲av香蕉一区区二区三区犇| 婷婷五月亚洲综合在线| 美女骚逼日出水来了| 91 亚洲视频在线观看| 成人在线欧美日韩国产| 精品国产午夜视频一区二区| 一二三中文乱码亚洲乱码one| 姐姐的朋友2在线观看中文字幕| 97香蕉碰碰人妻国产樱花| 天天日天天添天天爽| 中文字幕1卡1区2区3区| 性色蜜臀av一区二区三区| 欧美性感尤物人妻在线免费看| 日本丰满熟妇BBXBBXHD| 欧美国产亚洲中英文字幕| 欧美天堂av无线av欧美| 少妇人妻真实精品视频| 夜色撩人久久7777| 91中文字幕最新合集| aⅴ五十路av熟女中出| 久久这里有免费精品| 九色精品视频在线播放| 在线观看视频一区麻豆| 中文字幕高清在线免费播放| 男人操女人逼逼视频网站| 视频二区在线视频观看| 美女在线观看日本亚洲一区| 国产内射中出在线观看| 香蕉片在线观看av| 操人妻嗷嗷叫视频一区二区| 天天干天天操天天玩天天射 | 天天干夜夜操啊啊啊| 天天通天天透天天插| 北条麻妃av在线免费观看| 亚洲欧洲一区二区在线观看| 国产成人一区二区三区电影网站| 国产乱子伦一二三区| 99re久久这里都是精品视频| 天天日天天干天天要| 中文字幕一区二 区二三区四区| 亚洲精品色在线观看视频| 视频一区 视频二区 视频| 亚洲 中文 自拍 无码| 巨乳人妻日下部加奈被邻居中出| 偷拍自拍国产在线视频| 中文字幕视频一区二区在线观看| 福利一二三在线视频观看| 亚洲人人妻一区二区三区| 懂色av之国产精品| 国产精品久久久久网| 国产av自拍偷拍盛宴| 国产精品探花熟女在线观看| 国产真实灌醉下药美女av福利| 精品av国产一区二区三区四区| 东京干手机福利视频| 91免费黄片可看视频| 国产片免费观看在线观看| 日日夜夜大香蕉伊人| 99热色原网这里只有精品| 黄色无码鸡吧操逼视频| 伊人成人综合开心网| 国产在线免费观看成人| 1区2区3区不卡视频| 日韩视频一区二区免费观看| 国产熟妇人妻ⅹxxxx麻豆| 在线免费观看日本伦理| 亚洲中文字幕校园春色| 亚洲免费福利一区二区三区| 超碰在线中文字幕一区二区| 黄片色呦呦视频免费看| 男人天堂av天天操| 韩国三级aaaaa高清视频| 亚洲 中文 自拍 无码| 天美传媒mv视频在线观看| 年轻的人妻被夫上司侵犯| 日本a级视频老女人| 精品区一区二区三区四区人妻| 国产内射中出在线观看| 在线新三级黄伊人网| 少妇一区二区三区久久久| 都市激情校园春色狠狠| 久久久久久九九99精品| 欧美另类重口味极品在线观看| 亚洲精品无码色午夜福利理论片| 阿v天堂2014 一区亚洲| 国产亚洲精品品视频在线| 天天日天天干天天舔天天射| tube69日本少妇| 亚洲激情av一区二区| www日韩毛片av| 青草亚洲视频在线观看| 中文字幕日韩精品就在这里| 欧美精品黑人性xxxx| 女同性ⅹxx女同h偷拍| 欧美男同性恋69视频| 精品人妻伦一二三区久 | 婷婷午夜国产精品久久久| av新中文天堂在线网址| 岛国毛片视频免费在线观看| japanese五十路熟女熟妇| 国产卡一卡二卡三乱码手机| 白嫩白嫩美女极品国产在线观看| 国产男女视频在线播放| 中文字幕 亚洲av| 久久99久久99精品影院| 成人激情文学网人妻| 韩国三级aaaaa高清视频 | 亚洲综合在线观看免费| 欧美色呦呦最新网址| 亚洲人一区二区中文字幕| 大香蕉伊人国产在线| av天堂中文字幕最新| 久碰精品少妇中文字幕av| 欧美成人猛片aaaaaaa| yellow在线播放av啊啊啊| 日本一区美女福利视频| 中国产一级黄片免费视频播放| 91中文字幕最新合集| 伊人精品福利综合导航| 蜜桃视频17c在线一区二区| 伊人成人在线综合网| 美女骚逼日出水来了| 粉嫩欧美美人妻小视频| 欧美一级色视频美日韩| 亚洲精品久久视频婷婷| 天天摸天天干天天操科普| caoporn蜜桃视频| 在线观看911精品国产| 免费黄页网站4188| 边摸边做超爽毛片18禁色戒| 最新中文字幕乱码在线| 一区二区三区日韩久久| 日本熟女50视频免费| 国产又粗又猛又爽又黄的视频在线 | 中文字幕欧美日韩射射一| 亚洲1069综合男同| 日本精品一区二区三区在线视频。| 国产福利在线视频一区| 成人高清在线观看视频| 在线观看av2025| 999热精品视频在线| 99热99re在线播放| 日本美女性生活一级片| 国产品国产三级国产普通话三级| 午夜精品在线视频一区| 久久久久久久久久久久久97| 国产黄色大片在线免费播放| 午夜极品美女福利视频| 欧美日本在线观看一区二区 | 啊啊好慢点插舔我逼啊啊啊视频| 久草视频福利在线首页| 国产性生活中老年人视频网站| 大香蕉福利在线观看| 少妇被强干到高潮视频在线观看| 精产国品久久一二三产区区别| 91传媒一区二区三区| 五月天久久激情视频| 啪啪啪啪啪啪啪啪啪啪黄色| 岛国青草视频在线观看| 一区二区三区久久中文字幕| 国产一级精品综合av| 成人免费公开视频无毒| 99精品久久久久久久91蜜桃| 成人亚洲国产综合精品| 岛国黄色大片在线观看| 中英文字幕av一区| 欧美一区二区三区乱码在线播放| 在线观看亚洲人成免费网址| 一区二区三区日韩久久| 国产内射中出在线观看| 日本黄色特一级视频| 91精品激情五月婷婷在线| 色哟哟在线网站入口| 欧美亚洲免费视频观看| 亚洲国产欧美一区二区丝袜黑人| 国产成人午夜精品福利| 人妻激情图片视频小说| 狠狠的往里顶撞h百合| 亚洲Av无码国产综合色区| 97超碰人人搞人人| 国产日本欧美亚洲精品视| 国产老熟女伦老熟妇ⅹ| 日韩成人性色生活片| 国产一区自拍黄视频免费观看| 在线观看免费岛国av| 成年女人免费播放视频| 在线不卡成人黄色精品| 精品一区二区三区午夜| av中文字幕电影在线看| 国产精品自拍在线视频| 国产美女午夜福利久久| 亚洲午夜高清在线观看| 亚洲精品国产综合久久久久久久久| 午夜免费体验区在线观看| 51国产成人精品视频| 日韩精品二区一区久久| aiss午夜免费视频| 精品区一区二区三区四区人妻 | 免费69视频在线看| av老司机精品在线观看| 日本少妇高清视频xxxxx| 久久香蕉国产免费天天| 白白操白白色在线免费视频| 国产福利小视频免费观看| 亚洲女人的天堂av| 亚洲精品一线二线在线观看| 成人av久久精品一区二区| 大学生A级毛片免费视频| 鸡巴操逼一级黄色气| 免费观看理论片完整版| 97资源人妻免费在线视频| 一区二区三区另类在线| 狠狠躁夜夜躁人人爽天天天天97| 亚洲av极品精品在线观看| 精品国产乱码一区二区三区乱| 国产一区自拍黄视频免费观看| 天天躁日日躁狠狠躁躁欧美av| 国产男女视频在线播放| 欧美一区二区三区久久久aaa| 欧美日韩高清午夜蜜桃大香蕉| 日本一二三区不卡无| 中文字幕在线乱码一区二区| aⅴ五十路av熟女中出| 日韩在线视频观看有码在线| 亚洲国产美女一区二区三区软件| 青青青青青免费视频| 自拍偷拍亚洲欧美在线视频| 97少妇精品在线观看| 老司机福利精品免费视频一区二区| 婷婷久久久久深爱网| 狠狠的往里顶撞h百合| 日本美女性生活一级片| 99久久99久国产黄毛片| 欧美精品免费aaaaaa| 国产精品女邻居小骚货| 成人24小时免费视频| 毛茸茸的大外阴中国视频| 亚国产成人精品久久久| 精品久久婷婷免费视频| 青青青激情在线观看视频| a v欧美一区=区三区| 懂色av之国产精品| 日本高清成人一区二区三区| 一区二区三区四区五区性感视频| 欧美精品国产综合久久| 欧美特级特黄a大片免费| 黄色的网站在线免费看| av大全在线播放免费| 99精品视频在线观看婷婷| 97精品人妻一区二区三区精品| 特级无码毛片免费视频播放| 免费成人va在线观看| 狠狠的往里顶撞h百合| 欧美精品亚洲精品日韩在线| 午夜精品一区二区三区福利视频| 中文字幕无码日韩专区免费| 777奇米久久精品一区| 99精品一区二区三区的区| 端庄人妻堕落挣扎沉沦| 日本女人一级免费片| 美女骚逼日出水来了| av资源中文字幕在线观看| 亚洲福利精品视频在线免费观看| asmr福利视频在线观看| 91桃色成人网络在线观看| AV无码一区二区三区不卡| 91老师蜜桃臀大屁股| 97国产精品97久久| 福利片区一区二体验区| 亚洲va国产va欧美va在线| 日本熟妇喷水xxx| 美女小视频网站在线| 亚洲伊人av天堂有码在线| 亚洲免费国产在线日韩| 国产午夜男女爽爽爽爽爽视频| 亚洲欧美激情人妻偷拍| 在线成人日韩av电影| 蜜臀成人av在线播放| 青青青视频自偷自拍38碰| 国产精品人久久久久久| 亚洲天天干 夜夜操| 91社福利《在线观看| 国产性感美女福利视频| 日本熟女50视频免费| 日韩午夜福利精品试看| 亚洲在线观看中文字幕av| 在线观看欧美黄片一区二区三区 | 香蕉片在线观看av| 青青在线视频性感少妇和隔壁黑丝| 岛国免费大片在线观看| 亚洲成人av在线一区二区| 久久久久久久精品成人热| 91人妻精品一区二区在线看| 国产福利小视频免费观看| 免费一级黄色av网站| 天天干天天操天天玩天天射| 91中文字幕免费在线观看| 欧美日韩国产一区二区三区三州| 欧洲国产成人精品91铁牛tv| 五月天久久激情视频| 国产欧美精品一区二区高清| 91极品大一女神正在播放| 黑人借宿ntr人妻的沦陷2| 中文字幕亚洲中文字幕| 亚洲一区二区人妻av| 成人亚洲精品国产精品| www久久久久久久久久久| 久久综合老鸭窝色综合久久| 国产精品入口麻豆啊啊啊| 亚洲精品ww久久久久久| 欧美特色aaa大片| 天堂女人av一区二区| 亚洲激情唯美亚洲激情图片| 天天干天天操天天玩天天射| 午夜极品美女福利视频| 99久久激情婷婷综合五月天| 午夜在线观看岛国av,com| av手机在线免费观看日韩av| 啪啪啪18禁一区二区三区| 国产福利小视频大全| 亚洲老熟妇日本老妇| 中文字幕最新久久久| 日韩美女福利视频网| 日本丰满熟妇BBXBBXHD| 欧美区一区二区三视频| 日本www中文字幕| 国产一区二区神马久久| 精品国产成人亚洲午夜| 亚洲精品国产综合久久久久久久久| 天天日天天舔天天射进去| 男人的天堂一区二区在线观看| 一级A一级a爰片免费免会员| 国产精品手机在线看片| 午夜福利资源综合激情午夜福利资| 天天干天天日天天谢综合156| 亚洲1069综合男同| 91社福利《在线观看| 91试看福利一分钟| 岛国一区二区三区视频在线| 97超碰国语国产97超碰| 青青伊人一精品视频| 日本一本午夜在线播放| 国产中文字幕四区在线观看| 在线免费观看国产精品黄色| 老有所依在线观看完整版| 青青青视频自偷自拍38碰| 在线观看操大逼视频| 夜夜骑夜夜操夜夜奸| 亚洲国产精品免费在线观看| 亚洲国产最大av综合| gogo国模私拍视频| 大白屁股精品视频国产| 真实国产乱子伦一区二区| 男人的天堂av日韩亚洲| 97精品成人一区二区三区| 在线观看av2025| 国产成人无码精品久久久电影| 色哟哟国产精品入口| 国产av国片精品一区二区| 80电影天堂网官网| 精品久久久久久高潮| 中文人妻AV久久人妻水| 天天射,天天操,天天说| 欧美日韩情色在线观看| 久久久久久久久久性潮| 日韩黄色片在线观看网站| 老司机福利精品免费视频一区二区 | 福利视频网久久91| 成人乱码一区二区三区av| 日本av在线一区二区三区| 国产在线观看免费人成短视频| 国产露脸对白在线观看| 玩弄人妻熟妇性色av少妇| 欧美精品久久久久久影院| 国产成人精品福利短视频| 人人妻人人爽人人澡人人精品| 青青青国产免费视频| 亚洲成人免费看电影| 中国产一级黄片免费视频播放| 日韩少妇人妻精品无码专区| av俺也去在线播放| 中文字幕高清在线免费播放 | 国产露脸对白在线观看| 337p日本大胆欧美人| 中文字幕在线观看国产片| 黄色资源视频网站日韩| 午夜精品久久久久麻豆影视| 黑人变态深video特大巨大| 无码日韩人妻精品久久| 91大屁股国产一区二区| 亚洲男人让女人爽的视频| 国产日韩精品电影7777| 国产精品久久久久网| 蜜桃专区一区二区在线观看| 亚洲午夜福利中文乱码字幕| 亚洲天堂第一页中文字幕| 91精品国产观看免费| 久久美欧人妻少妇一区二区三区| 成人伊人精品色xxxx视频| av视网站在线观看| 成人精品视频99第一页| 午夜精品久久久久久99热| 亚洲综合一区成人在线| 在线成人日韩av电影| 日本三极片中文字幕| 天天干天天操天天玩天天射| 青青社区2国产视频| 高潮喷水在线视频观看| 日日夜夜精品一二三| 91人妻精品久久久久久久网站| 色偷偷伊人大杳蕉综合网| 中文字幕在线观看极品视频| 亚洲欧美日韩视频免费观看| 婷婷五月亚洲综合在线| 一区二区三区日韩久久| 丝袜亚洲另类欧美变态| 黑人大几巴狂插日本少妇| 丰满的继坶3中文在线观看| 丝袜长腿第一页在线| 午夜美女少妇福利视频| 99久久99一区二区三区| 亚洲伊人色一综合网| 中文字幕之无码色多多| 狠狠躁狠狠爱网站视频| 啊啊啊想要被插进去视频| 在线观看的a站 最新| v888av在线观看视频| 亚洲精品中文字幕下载| 人妻少妇性色欲欧美日韩| 青青尤物在线观看视频网站| 中文字幕在线永久免费播放| 伊人精品福利综合导航| 亚洲青青操骚货在线视频| 午夜激情久久不卡一区二区 | 51国产成人精品视频| 久久久久久cao我的性感人妻| 大陆胖女人与丈夫操b国语高清| 天天日天天干天天插舔舔| 97国产在线观看高清| 中国视频一区二区三区| av天堂中文字幕最新| 天干天天天色天天日天天射| 欧美地区一二三专区| 97人妻无码AV碰碰视频| 中文字幕乱码av资源| 亚洲一级美女啪啪啪| 丝袜肉丝一区二区三区四区在线| 亚洲自拍偷拍综合色| 亚洲护士一区二区三区| 国产成人无码精品久久久电影| 久久热这里这里只有精品| 青青草亚洲国产精品视频| aiss午夜免费视频| 国产综合高清在线观看| 国产黄色高清资源在线免费观看| 久久热久久视频在线观看| 国产性感美女福利视频| 啊啊啊想要被插进去视频| 日韩黄色片在线观看网站| 大屁股熟女一区二区三区| 青青青aaaa免费| 国产成人精品久久二区91| 熟女人妻在线中出观看完整版| 国产女人露脸高潮对白视频| 蜜桃色婷婷久久久福利在线| 99精品免费观看视频| 亚洲av无硬久久精品蜜桃| 亚洲中文字幕综合小综合| 孕妇奶水仑乱A级毛片免费看| 大陆精品一区二区三区久久| 天天日天天鲁天天操| 少妇一区二区三区久久久| 欧美视频一区免费在线| 美女视频福利免费看| 男人的网址你懂的亚洲欧洲av| 欧美视频综合第一页| 亚洲国产美女一区二区三区软件 | 蜜桃色婷婷久久久福利在线| 人妻熟女在线一区二区| 91人妻人人做人人爽在线| 成人30分钟免费视频| 蜜桃色婷婷久久久福利在线| av资源中文字幕在线观看| 日韩欧美亚洲熟女人妻| av在线shipin| 特级无码毛片免费视频播放| 在线免费观看视频一二区| 性欧美日本大妈母与子| 国产亚洲四十路五十路| 国产av福利网址大全| 伊人网中文字幕在线视频| 75国产综合在线视频| 自拍 日韩 欧美激情| 国产午夜男女爽爽爽爽爽视频| 亚洲 人妻 激情 中文| 欧美黑人与人妻精品| 国产又大又黄免费观看| 91色九色porny| 亚洲区美熟妇久久久久| 亚洲成人线上免费视频观看| 欧美一区二区三区啪啪同性| 97人妻总资源视频| 密臀av一区在线观看| 国产卡一卡二卡三乱码手机| 欧美一区二区中文字幕电影| 国产亚洲国产av网站在线| 丝袜肉丝一区二区三区四区在线| 九一传媒制片厂视频在线免费观看 | 国产精品一区二区久久久av| 婷婷激情四射在线观看视频| 精内国产乱码久久久久久| 宅男噜噜噜666免费观看| 大肉大捧一进一出好爽在线视频| 特级欧美插插插插插bbbbb| 99热久久这里只有精品| 韩国AV无码不卡在线播放| 懂色av蜜桃a v| 亚洲精品麻豆免费在线观看| 天堂女人av一区二区| 日比视频老公慢点好舒服啊| 亚洲欧美激情国产综合久久久 | 天天操天天射天天操天天天| 亚洲av第国产精品| 阴茎插到阴道里面的视频| av手机在线免费观看日韩av| 2018最新中文字幕在线观看| 国产成人综合一区2区| 一区二区三区av高清免费| 久久免看30视频口爆视频| 欧美精产国品一二三区| 日本后入视频在线观看| 男大肉棒猛烈插女免费视频| 91高清成人在线视频| 91麻豆精品91久久久久同性| 免费观看国产综合视频| 日韩影片一区二区三区不卡免费| av手机在线免费观看日韩av| 国产成人精品亚洲男人的天堂| 日韩av有码中文字幕| 日韩一区二区电国产精品| 2018最新中文字幕在线观看| 18禁美女无遮挡免费| 91天堂精品一区二区| 午夜精彩视频免费一区| 国产一区二区在线欧美| 国产福利小视频二区| 香蕉91一区二区三区| 欧美精品亚洲精品日韩在线| 78色精品一区二区三区| 一区二区三区麻豆福利视频| 国产一区二区神马久久| 亚洲成a人片777777| 久久丁香婷婷六月天| 做爰视频毛片下载蜜桃视频1| 成人av久久精品一区二区| 亚洲护士一区二区三区| 黄色视频成年人免费观看| 福利视频一区二区三区筱慧| 日韩美女福利视频网| 91www一区二区三区| okirakuhuhu在线观看| 一级a看免费观看网站| 99国产精品窥熟女精品| 丝袜亚洲另类欧美变态| 五月天色婷婷在线观看视频免费| 在线不卡日韩视频播放| 欧美一区二区三区高清不卡tv| 91免费福利网91麻豆国产精品| 99热这里只有国产精品6| 手机看片福利盒子日韩在线播放| 天天插天天狠天天操| 动漫av网站18禁| 男女啪啪视频免费在线观看| 漂亮 人妻被中出中文| 日本少妇高清视频xxxxx| 亚洲伊人久久精品影院一美女洗澡| 黄色录像鸡巴插进去| 偷偷玩弄新婚人妻h视频| 夜女神免费福利视频| 大陆av手机在线观看| 操人妻嗷嗷叫视频一区二区| 久久www免费人成一看片| 欧美地区一二三专区| 亚洲欧美成人综合视频| 亚洲图库另类图片区| 国产黄色高清资源在线免费观看| 老师啊太大了啊啊啊尻视频| 日韩精品二区一区久久| 成熟丰满熟妇高潮xx×xx | 亚洲va欧美va人人爽3p| 天天日天天鲁天天操| av网址在线播放大全| 超碰97人人做人人爱| eeuss鲁片一区二区三区| 国产乱子伦一二三区| av日韩在线观看大全| 大白屁股精品视频国产| 二区中出在线观看老师| 精品国产成人亚洲午夜| 色婷婷综合激情五月免费观看| 五十路在线观看完整版| 中文字幕无码一区二区免费| 成年美女黄网站18禁久久| 日本人妻少妇18—xx| 在线观看国产网站资源| 欧美少妇性一区二区三区| 天堂av在线官网中文| 亚洲欧美综合在线探花| 亚洲 中文 自拍 无码| 久久久人妻一区二区| 伊人情人综合成人久久网小说| 成人色综合中文字幕| 精品日产卡一卡二卡国色天香| 国产一区二区三免费视频| 国产大学生援交正在播放| 色吉吉影音天天干天天操 | 成人动漫大肉棒插进去视频| 日韩成人综艺在线播放| 毛片一级完整版免费| 久久香蕉国产免费天天| 青青青青青青草国产| 欧美精产国品一二三产品区别大吗| 国产91精品拍在线观看| 快插进小逼里大鸡吧视频| 亚洲人人妻一区二区三区| 在线视频国产欧美日韩| 色偷偷伊人大杳蕉综合网| 欧美麻豆av在线播放| 国产变态另类在线观看| 懂色av之国产精品| 免费在线观看污污视频网站| 欧美黄片精彩在线免费观看| aⅴ五十路av熟女中出| 蜜桃精品久久久一区二区| av天堂中文免费在线| 亚洲一级 片内射视正片| 大骚逼91抽插出水视频| 天天操天天干天天艹| 日韩人妻xxxxx| 伊人成人在线综合网| 大香蕉伊人中文字幕| 午夜国产福利在线观看| jiujiure精品视频在线| 2020久久躁狠狠躁夜夜躁| 福利视频网久久91| 久草福利电影在线观看| 热久久只有这里有精品| 亚洲一区二区三区av网站| 动漫美女的小穴视频| 精品国产午夜视频一区二区| 男人插女人视频网站| 2018最新中文字幕在线观看| 综合国产成人在线观看| av在线观看网址av| 超碰97人人做人人爱| 天天操天天污天天射| 亚洲av色图18p| 欧美老鸡巴日小嫩逼| 亚洲 国产 成人 在线| 超碰中文字幕免费观看| 不卡日韩av在线观看| 九色精品视频在线播放| 一区二区视频在线观看视频在线| 99av国产精品欲麻豆| 在线免费观看欧美小视频| 91精品资源免费观看| 视频久久久久久久人妻| 高清成人av一区三区| 综合国产成人在线观看| 日本少妇在线视频大香蕉在线观看| av新中文天堂在线网址| 中文字幕av第1页中文字幕| 久久一区二区三区人妻欧美| 少妇人妻100系列| 日韩三级黄色片网站| 亚洲另类综合一区小说| 懂色av蜜桃a v| 天天操天天弄天天射| 日韩av免费观看一区| 国产亚洲精品欧洲在线观看| 夜色17s精品人妻熟女| 在线国产中文字幕视频| 国产精品中文av在线播放| 国产一区二区火爆视频| 欧美精品亚洲精品日韩在线| 极品丝袜一区二区三区| 日本女大学生的黄色小视频| 国产精品国产三级国产午| 黄片色呦呦视频免费看| 久久人人做人人妻人人玩精品vr| 夜夜操,天天操,狠狠操| 国产九色91在线观看精品| 美女 午夜 在线视频| 精品久久久久久久久久中文蒉 | 免费在线看的黄片视频| 一区二区三区久久久91| 欧美日韩不卡一区不区二区| 美女操逼免费短视频下载链接| 人妻少妇精品久久久久久| 精品亚洲在线免费观看| 视频一区二区综合精品| 黄片色呦呦视频免费看| 日韩熟女av天堂系列| 亚洲av午夜免费观看| 亚洲va国产va欧美精品88| 激情色图一区二区三区| rct470中文字幕在线| 在线 中文字幕 一区| 性欧美日本大妈母与子| 欧美区一区二区三视频| 亚洲一区二区三区精品乱码| 亚洲av成人网在线观看| 播放日本一区二区三区电影 | 在线成人日韩av电影| 97欧洲一区二区精品免费| 欧美日韩精品永久免费网址| 天天干夜夜操啊啊啊| 亚洲av极品精品在线观看| 国产精彩对白一区二区三区 | sspd152中文字幕在线| 男人操女人的逼免费视频| 亚洲美女高潮喷浆视频| 91香蕉成人app下载| 亚洲无线观看国产高清在线| 青青青青青青青青青国产精品视频| 啊用力插好舒服视频| 91精品国产麻豆国产| 18禁免费av网站| 超碰97免费人妻麻豆| 午夜青青草原网在线观看| 亚洲成人熟妇一区二区三区 | 欧美成人综合视频一区二区| 香蕉片在线观看av| 国产精品一区二区av国| 无码日韩人妻精品久久| 91高清成人在线视频| 中国黄片视频一区91| 午夜在线观看一区视频| 亚洲av天堂在线播放| 黄色片年轻人在线观看| 亚洲综合另类精品小说| jul—619中文字幕在线| 在线亚洲天堂色播av电影| 成人av电影免费版| 午夜激情久久不卡一区二区 | 午夜精品福利91av| 亚国产成人精品久久久| 天天射,天天操,天天说| 亚洲成人三级在线播放| 日韩欧美一级黄片亚洲| 精品国产污污免费网站入口自| 国产极品精品免费视频| 国产综合精品久久久久蜜臀| 欧美日韩中文字幕欧美| 亚洲一区二区人妻av| 日本人妻欲求不满中文字幕| 91色秘乱一区二区三区| 午夜的视频在线观看| 天堂av狠狠操蜜桃| 福利午夜视频在线观看| 日日日日日日日日夜夜夜夜夜夜| aiss午夜免费视频| 国产一区av澳门在线观看| 精品黑人一区二区三区久久国产| 清纯美女在线观看国产| 成人高清在线观看视频| 老司机深夜免费福利视频在线观看| 青青草成人福利电影| 久久久久久97三级| 一个色综合男人天堂| 99av国产精品欲麻豆| 国产91久久精品一区二区字幕| 任我爽精品视频在线播放| 另类av十亚洲av| 动漫黑丝美女的鸡巴| 黑人3p华裔熟女普通话| 激情内射在线免费观看| 这里有精品成人国产99| 日本www中文字幕| 中文字幕中文字幕 亚洲国产| 爆乳骚货内射骚货内射在线| 成人蜜臀午夜久久一区| 中文字幕一区的人妻欧美日韩| 中文字幕中文字幕 亚洲国产| 孕妇奶水仑乱A级毛片免费看 | 午夜精品福利一区二区三区p| 免费黄高清无码国产| 福利午夜视频在线观看| 欧美日韩一级黄片免费观看| 韩国AV无码不卡在线播放| 香蕉av影视在线观看| 久久热久久视频在线观看| 毛片一级完整版免费| 92福利视频午夜1000看| 38av一区二区三区| 东京干手机福利视频| 只有精品亚洲视频在线观看| 亚洲成人午夜电影在线观看| 亚洲日本一区二区三区| 国产极品精品免费视频 | 欧美日韩情色在线观看| 青青青青青操视频在线观看| 999热精品视频在线| 亚洲免费成人a v| 伊人情人综合成人久久网小说 | av老司机亚洲一区二区| 欧美成一区二区三区四区| 一区二区三区四区视频在线播放| 欧美地区一二三专区| 欧美视频中文一区二区三区| 最近中文2019年在线看| 女同互舔一区二区三区| 国产一区自拍黄视频免费观看| 亚洲熟女综合色一区二区三区四区| 日韩中文字幕福利av| 亚洲一区二区激情在线| 久久这里只有精品热视频| 天天射,天天操,天天说| 日韩精品中文字幕福利| 首之国产AV医生和护士小芳| 超级av免费观看一区二区三区| 亚洲中文字幕校园春色| 午夜精彩视频免费一区| 午夜国产福利在线观看| 夜夜躁狠狠躁日日躁麻豆内射 | 天天干天天搞天天摸| 婷婷综合亚洲爱久久| 91大神福利视频网| 97人妻总资源视频| 亚洲国产中文字幕啊啊啊不行了 | 亚洲中文字幕校园春色| 成人av免费不卡在线观看| 中文字幕一区二 区二三区四区 | 亚洲午夜在线视频福利| 青青草国内在线视频精选| 91chinese在线视频| 青草亚洲视频在线观看| 特级无码毛片免费视频播放| 亚洲 人妻 激情 中文| 亚洲伊人av天堂有码在线| 男生用鸡操女生视频动漫| 亚洲av天堂在线播放| 狠狠嗨日韩综合久久| 日本xx片在线观看| 偷拍自拍国产在线视频| 青青在线视频性感少妇和隔壁黑丝 | 日日夜夜精品一二三| 日本男女操逼视频免费看| 日本美女性生活一级片| 亚洲 自拍 色综合图| 亚洲福利天堂久久久久久| 日本a级视频老女人| 亚洲成人国产综合一区| 熟女视频一区,二区,三区| 在线播放 日韩 av| 精品91高清在线观看| 天天干天天日天天干天天操| 插逼视频双插洞国产操逼插洞| 新婚人妻聚会被中出| 人妻另类专区欧美制服| av天堂加勒比在线| 亚洲推理片免费看网站| nagger可以指黑人吗| 老司机深夜免费福利视频在线观看| 性色av一区二区三区久久久| 91在线视频在线精品3| 日本韩国免费一区二区三区视频| 快点插进来操我逼啊视频| 欧美一区二区三区激情啪啪啪| 国产九色91在线观看精品| 一区二区三区综合视频| 插逼视频双插洞国产操逼插洞| 少妇一区二区三区久久久| 欧美日韩情色在线观看| 亚洲成人黄色一区二区三区| 美女张开两腿让男人桶av| 国产在线91观看免费观看| 2022国产精品视频| 91色九色porny| 在线免费视频 自拍| 欧美区一区二区三视频| av网址国产在线观看| 欧美乱妇无乱码一区二区| 国产激情av网站在线观看| 亚洲区欧美区另类最新章节| 福利片区一区二体验区| 欧洲黄页网免费观看| 91av精品视频在线| 成人av亚洲一区二区| 亚洲天天干 夜夜操| 57pao国产一区二区| 亚洲午夜精品小视频| 午夜成午夜成年片在线观看| 日韩av中文在线免费观看| 亚洲欧美清纯唯美另类 | 欧美成人精品欧美一级黄色| 91老熟女连续高潮对白| av中文字幕福利网| 都市家庭人妻激情自拍视频| 女人精品内射国产99| 五十路熟女人妻一区二区9933| 狠狠躁狠狠爱网站视频| 2022国产精品视频| 久草视频 久草视频2| 91精品国产91久久自产久强| 亚欧在线视频你懂的| 国产精品久久久久久久久福交| 99国产精品窥熟女精品| 欧美精产国品一二三产品价格| 成年午夜影片国产片| 人妻av无码专区久久绿巨人| 换爱交换乱高清大片| 美女福利写真在线观看视频| 在线网站你懂得老司机| 亚洲国产欧美国产综合在线| 亚洲欧美福利在线观看| 在线新三级黄伊人网| 特黄老太婆aa毛毛片| 亚洲最大免费在线观看| 日本精品美女在线观看| 天天色天天舔天天射天天爽| 亚洲蜜臀av一区二区三区九色| 色婷婷久久久久swag精品| 日韩剧情片电影在线收看| 9l人妻人人爽人人爽| 国产成人综合一区2区| 色婷婷精品大在线观看| 亚洲精品午夜久久久久| 91大神福利视频网| 天天干天天操天天玩天天射| 成熟丰满熟妇高潮xx×xx| 亚洲护士一区二区三区| 亚洲综合一区二区精品久久| 午夜大尺度无码福利视频| 91中文字幕最新合集| 中文字幕在线欧美精品| 国产麻豆国语对白露脸剧情| 日本熟妇喷水xxx| 欧美成人精品在线观看| 激情图片日韩欧美人妻| 天天日天天玩天天摸| 无码精品一区二区三区人 | 91欧美在线免费观看| 狍和女人的王色毛片| 美日韩在线视频免费看| 91人妻精品一区二区久久| 日韩特级黄片高清在线看| 欧美一区二区中文字幕电影| 女同性ⅹxx女同h偷拍| 天堂av在线最新版在线| 精品人人人妻人人玩日产欧| 老司机99精品视频在线观看| 国产黄色a级三级三级三级| 91国产在线免费播放| 成人18禁网站在线播放| 美女福利视频导航网站| 综合页自拍视频在线播放| 91九色国产熟女一区二区| 人妻无码色噜噜狠狠狠狠色| 欧亚日韩一区二区三区观看视频| 亚洲欧美国产麻豆综合| 粉嫩小穴流水视频在线观看| 亚洲av色图18p| 欧美视频综合第一页| 一区二区三区四区中文| 在线免费91激情四射| 欧洲亚洲欧美日韩综合| 国产亚洲视频在线二区| 久久久麻豆精亚洲av麻花| 日本阿v视频在线免费观看| 播放日本一区二区三区电影| 人妻少妇一区二区三区蜜桃| 亚洲精品国品乱码久久久久| 91中文字幕最新合集| 老司机免费福利视频网| 午夜婷婷在线观看视频| 成人区人妻精品一区二视频 | 做爰视频毛片下载蜜桃视频1| 香蕉91一区二区三区| 888亚洲欧美国产va在线播放| 一区二区三区四区中文| 久久久久久久精品老熟妇| 日韩美女综合中文字幕pp| 亚洲日产av一区二区在线| 成人精品在线观看视频| 国产亚洲精品欧洲在线观看| 黄色中文字幕在线播放| 亚洲国产成人av在线一区| av在线shipin| 免费看高清av的网站| 五十路av熟女松本翔子| 日本人妻精品久久久久久| 在线网站你懂得老司机| 日本特级片中文字幕| www天堂在线久久| 日本av在线一区二区三区| 91国产资源在线视频| 在线国产精品一区二区三区| 国产精品久久久久久久精品视频| 青青青aaaa免费| av俺也去在线播放| 男生舔女生逼逼视频| 人妻3p真实偷拍一二区| 欧美视频中文一区二区三区| 国产白袜脚足J棉袜在线观看| 91免费黄片可看视频| 抽查舔水白紧大视频| 国产乱弄免费视频观看| 欧美日韩不卡一区不区二区| 涩爱综合久久五月蜜臀| 中文字幕在线欧美精品| 日韩国产乱码中文字幕| 亚洲成人精品女人久久久| 色伦色伦777国产精品| 免费在线看的黄片视频| 国产chinesehd精品麻豆| 清纯美女在线观看国产| 日比视频老公慢点好舒服啊| 女生自摸在线观看一区二区三区 | 经典av尤物一区二区| 岛国一区二区三区视频在线| 亚洲熟女综合色一区二区三区四区| 久久久人妻一区二区| 日韩一区二区三区三州| 男人的天堂一区二区在线观看| 国产一区二区火爆视频| 久久久久久国产精品| 五月色婷婷综合开心网4438| 曰本无码人妻丰满熟妇啪啪| 偷拍3456eee| 超碰公开大香蕉97| 欧美乱妇无乱码一区二区| 亚洲狠狠婷婷综合久久app| 日韩欧美制服诱惑一区在线| 激情伦理欧美日韩中文字幕| 日日夜夜精品一二三| 亚洲少妇高潮免费观看| 欧美精品一区二区三区xxxx| 熟女91pooyn熟女| 无套猛戳丰满少妇人妻| 这里有精品成人国产99| 黄色成人在线中文字幕| 亚洲 色图 偷拍 欧美| 蜜桃色婷婷久久久福利在线| 自拍偷拍亚洲欧美在线视频| 扒开腿挺进肉嫩小18禁视频| 任你操任你干精品在线视频| 久久精品36亚洲精品束缚| 亚洲中文字幕人妻一区| 午夜激情久久不卡一区二区 | 国产精品成人xxxx| 天天日天天摸天天爱| 日本黄在免费看视频| 国产又大又黄免费观看| 国产亚洲天堂天天一区| 中文字幕第一页国产在线| 综合激情网激情五月天| 伊人精品福利综合导航| 日韩精品中文字幕播放| 国产日韩av一区二区在线| 骚货自慰被发现爆操| 1769国产精品视频免费观看| 青青青青青青青在线播放视频| 国产熟妇乱妇熟色T区| jiuse91九色视频| 久久久久久97三级| 国产精品视频男人的天堂| 久草视频中文字幕在线观看| 丰满的继坶3中文在线观看| 久久www免费人成一看片| 天天操天天爽天天干| 大白屁股精品视频国产| 少妇人妻100系列| 被大鸡吧操的好舒服视频免费| 国产精品黄大片在线播放| 99精品一区二区三区的区| 97国产福利小视频合集| 亚洲成人av一区在线| 人人在线视频一区二区| 国产亚洲视频在线观看| 四虎永久在线精品免费区二区| 精品国产午夜视频一区二区| 亚洲va国产va欧美va在线| 一区二区三区美女毛片| 亚洲av无女神免非久久| 操人妻嗷嗷叫视频一区二区| 婷婷综合蜜桃av在线| 黄色成人在线中文字幕| 91社福利《在线观看| 老司机福利精品免费视频一区二区| 久精品人妻一区二区三区 | 精品国产在线手机在线| 天天操天天射天天操天天天| 2012中文字幕在线高清| 视频一区 二区 三区 综合| 福利在线视频网址导航| 亚洲福利天堂久久久久久| 天天躁日日躁狠狠躁躁欧美av| 91av中文视频在线| 91国产在线视频免费观看| 天天日天天爽天天干| av天堂中文字幕最新| 视频二区在线视频观看| 动色av一区二区三区| 日韩av免费观看一区| 国产精品视频男人的天堂| 国产无遮挡裸体免费直播视频| 熟女人妻一区二区精品视频| 天堂av在线最新版在线| 色av色婷婷人妻久久久精品高清| 亚洲推理片免费看网站| 亚洲va国产va欧美精品88| 不卡精品视频在线观看| 青青草人人妻人人妻| 久草视频福利在线首页| 国产精品视频男人的天堂| 五色婷婷综合狠狠爱| 欧美在线偷拍视频免费看| 日本美女性生活一级片| 99久久中文字幕一本人| 人人超碰国字幕观看97| 99精品国自产在线人| 又大又湿又爽又紧A视频| 久草视频在线一区二区三区资源站| 开心 色 六月 婷婷| 91麻豆精品传媒国产黄色片| av线天堂在线观看| 99国内小视频在现欢看| 人人爱人人妻人人澡39| 一区二区在线观看少妇| 大香蕉福利在线观看| 婷婷六月天中文字幕| 2o22av在线视频| 亚洲伊人久久精品影院一美女洗澡| 国产一区二区欧美三区| 色狠狠av线不卡香蕉一区二区| 韩国女主播精品视频网站| 日韩欧美国产一区ab| 亚洲天堂第一页中文字幕| 无套猛戳丰满少妇人妻| 绝色少妇高潮3在线观看| 日日夜夜狠狠干视频| 狠狠嗨日韩综合久久| 久久久精品999精品日本| 国产精品福利小视频a| 强行扒开双腿猛烈进入免费版 | 国产福利小视频免费观看| 一区二区三区在线视频福利| 亚洲欧美福利在线观看| 黄页网视频在线免费观看| 97国产在线观看高清| 久久久91蜜桃精品ad| 亚洲成人国产av在线| 国产精彩对白一区二区三区 | 久久久久久久精品老熟妇| 三上悠亚和黑人665番号| 一区二区三区美女毛片| 97国产在线观看高清| 91亚洲国产成人精品性色| 欲乱人妻少妇在线视频裸| 18禁美女羞羞免费网站| 一区二区三区日韩久久| 一区二区三区四区视频| 夜夜骑夜夜操夜夜奸| 青青草视频手机免费在线观看| 日韩剧情片电影在线收看| 亚洲美女高潮喷浆视频| 日本女大学生的黄色小视频| 玖玖一区二区在线观看| 国产精品中文av在线播放| 天天日天天干天天爱| 亚洲一区二区人妻av| 大陆精品一区二区三区久久| 天天做天天爽夜夜做少妇| 亚洲人成精品久久久久久久| 亚洲女人的天堂av| 国产三级精品三级在线不卡| 综合激情网激情五月天| 亚洲变态另类色图天堂网| 色爱av一区二区三区| 91人妻精品一区二区久久| 中文字幕在线免费第一页| 51国产成人精品视频| 婷婷色中文亚洲网68| 亚洲国产香蕉视频在线播放| 久草福利电影在线观看| 免费在线福利小视频| 欧美aa一级一区三区四区| 亚洲av色图18p| 丝袜美腿视频诱惑亚洲无 | 偷青青国产精品青青在线观看| 亚洲Av无码国产综合色区| 日韩欧美一级aa大片| 99久久超碰人妻国产| 日韩亚洲高清在线观看| 偷拍自拍福利视频在线观看| 亚洲国产香蕉视频在线播放| 国产在线自在拍91国语自产精品| 国产日本精品久久久久久久| 亚洲成人精品女人久久久| av新中文天堂在线网址| 成人免费公开视频无毒| 九色porny九色9l自拍视频| 亚洲av极品精品在线观看| 最新激情中文字幕视频| 护士小嫩嫩又紧又爽20p| 热久久只有这里有精品| 久久精品视频一区二区三区四区| 97人妻无码AV碰碰视频| 国产精选一区在线播放| 嫩草aⅴ一区二区三区| 亚洲av无乱一区二区三区性色| 午夜av一区二区三区| 淫秽激情视频免费观看| 青青青激情在线观看视频| 亚洲av色香蕉一区二区三区| 国产91精品拍在线观看| 久草福利电影在线观看| 国产av自拍偷拍盛宴| 夫妻在线观看视频91| 大尺度激情四射网站| 9久在线视频只有精品| 欧美xxx成人在线| 亚洲av自拍天堂网| av老司机精品在线观看| 99热碰碰热精品a中文| 亚洲1卡2卡三卡4卡在线观看| 沙月文乃人妻侵犯中文字幕在线| 美女av色播在线播放| 老司机你懂得福利视频| 国产精品久久综合久久| 97人妻无码AV碰碰视频| 成人动漫大肉棒插进去视频| 色综合色综合色综合色| 久久久人妻一区二区| 日韩av免费观看一区| 久久精品国产亚洲精品166m| 亚洲熟色妇av日韩熟色妇在线| 伊人情人综合成人久久网小说 | 中文字幕熟女人妻久久久| 日本少妇人妻xxxxxhd| 日韩人妻丝袜中文字幕| 激情色图一区二区三区| 人妻丝袜诱惑我操她视频| 日韩美女精品视频在线观看网站| 亚洲天堂av最新网址| 91精品国产91青青碰| 天天干天天日天天谢综合156| 久久久人妻一区二区| 男人天堂色男人av| 懂色av之国产精品| 亚洲男人让女人爽的视频| 美女视频福利免费看| 男人操女人的逼免费视频| 欧美 亚洲 另类综合| 色噜噜噜噜18禁止观看| 免费啪啪啪在线观看视频| 日韩少妇人妻精品无码专区| 亚洲精品欧美日韩在线播放| 青青青艹视频在线观看| 深田咏美亚洲一区二区| 天天干天天爱天天色| 欧美一区二区三区啪啪同性| 中国产一级黄片免费视频播放| 日韩二区视频一线天婷婷五| 四虎永久在线精品免费区二区| 天天摸天天亲天天舔天天操天天爽| 国产精品自拍偷拍a| 亚洲一区二区激情在线| 国产女人叫床高潮大片视频| 老司机福利精品视频在线| 亚洲激情av一区二区| 日韩成人免费电影二区| 91 亚洲视频在线观看| 婷婷六月天中文字幕| 亚洲国产精品久久久久蜜桃| 爆乳骚货内射骚货内射在线| 精品高跟鞋丝袜一区二区| 亚洲欧美综合在线探花| sspd152中文字幕在线| 18禁美女黄网站色大片下载| 欧美va亚洲va天堂va| 亚洲欧美另类自拍偷拍色图| 91福利在线视频免费观看| 老鸭窝在线观看一区| 欧美一区二区三区激情啪啪啪 | 欧美韩国日本国产亚洲| 又色又爽又黄又刺激av网站| 国产精品一区二区av国| 亚洲高清国产自产av| 中文字幕免费福利视频6| 婷婷综合亚洲爱久久| 九一传媒制片厂视频在线免费观看 | 成年人午夜黄片视频资源| 人人在线视频一区二区| 97国产在线av精品| 大胸性感美女羞爽操逼毛片| 青青青艹视频在线观看| 一区二区三区日韩久久| 绝色少妇高潮3在线观看| 第一福利视频在线观看| 亚洲精品麻豆免费在线观看| 欧美男人大鸡吧插女人视频| 91高清成人在线视频| 亚洲 自拍 色综合图| 日韩三级黄色片网站| 天天夜天天日天天日| 一区二区三区 自拍偷拍| 国产美女一区在线观看| 东京干手机福利视频| 精品国产乱码一区二区三区乱| 久草视频 久草视频2| 欧美老鸡巴日小嫩逼| 国产欧美精品免费观看视频| 久久久麻豆精亚洲av麻花| wwwxxx一级黄色片| 熟女人妻在线中出观看完整版| 秋霞午夜av福利经典影视| 巨乳人妻日下部加奈被邻居中出 | 538精品在线观看视频| 中文字幕—97超碰网| 美女福利视频网址导航| 免费成人va在线观看| 成人高清在线观看视频| 91色网站免费在线观看| 国产精品自拍视频大全| 国产真实乱子伦a视频| 91啪国自产中文字幕在线| 在线观看操大逼视频| 香港一级特黄大片在线播放| 性色av一区二区三区久久久 | 91精品综合久久久久3d动漫| 国产成人精品福利短视频| 一区国内二区日韩三区欧美| 自拍偷区二区三区麻豆| 亚洲欧美成人综合视频| 亚洲综合乱码一区二区| 老司机福利精品免费视频一区二区| 亚洲欧洲av天堂综合| 色伦色伦777国产精品| 午夜极品美女福利视频| 免费av岛国天堂网站| 天堂av在线官网中文| heyzo蜜桃熟女人妻| 国产视频一区在线观看| 亚洲激情唯美亚洲激情图片| 538精品在线观看视频| 91极品大一女神正在播放| 十八禁在线观看地址免费 | 在线不卡成人黄色精品| 黄片色呦呦视频免费看| 97精品成人一区二区三区 | 免费看国产又粗又猛又爽又黄视频| 亚洲一区二区三区在线高清| 久久这里只有精彩视频免费| 亚洲第17页国产精品| 美女福利视频导航网站| 日本午夜福利免费视频| 被大鸡吧操的好舒服视频免费| 国产超码片内射在线| 精内国产乱码久久久久久| 亚洲av天堂在线播放| www久久久久久久久久久| 日本特级片中文字幕| brazzers欧熟精品系列| 91片黄在线观看喷潮| 一区二区三区欧美日韩高清播放| 天码人妻一区二区三区在线看| 亚洲护士一区二区三区| 亚洲欧美自拍另类图片| 青青青国产片免费观看视频| 亚洲另类在线免费观看| 国产揄拍高清国内精品对白| 欧美日本在线视频一区| 日本成人一区二区不卡免费在线| 亚洲欧美激情中文字幕| 含骚鸡巴玩逼逼视频| 美女张开两腿让男人桶av| 中文字幕在线第一页成人| 亚洲天堂成人在线观看视频网站| 操人妻嗷嗷叫视频一区二区 | 天天做天天干天天操天天射| 99精品国产自在现线观看| 国产麻豆精品人妻av| 色在线观看视频免费的| 一区二区三区麻豆福利视频| 婷婷久久久综合中文字幕| 91精品国产综合久久久蜜| 2019av在线视频| 精品suv一区二区69| 欧美黑人与人妻精品| 精品老妇女久久9g国产| 亚洲激情唯美亚洲激情图片| 亚洲av成人免费网站| 欧美另类一区二区视频| 亚洲另类综合一区小说| 国产美女一区在线观看| 精彩视频99免费在线| 欧美第一页在线免费观看视频| 天天操天天干天天日狠狠插 | 美女视频福利免费看| 91色老99久久九九爱精品| chinese国产盗摄一区二区| 自拍 日韩 欧美激情| 99婷婷在线观看视频| 可以在线观看的av中文字幕| 日韩欧美国产一区不卡| 成人伊人精品色xxxx视频| 午夜免费体验区在线观看| 青青青aaaa免费| 97成人免费在线观看网站| 黄片色呦呦视频免费看| 中文字幕日韩91人妻在线| 亚洲一区二区三区久久午夜| 青青青青青操视频在线观看| 一级A一级a爰片免费免会员| 中文字幕人妻一区二区视频| 欧美亚洲中文字幕一区二区三区| 一区二区久久成人网| 伊拉克及约旦宣布关闭领空| 亚洲一区二区人妻av| 一色桃子久久精品亚洲| 亚洲麻豆一区二区三区| av中文字幕网址在线| 人妻丝袜av在线播放网址| 黄色中文字幕在线播放| 亚洲区欧美区另类最新章节| 日韩中文字幕福利av| 无套猛戳丰满少妇人妻| 亚欧在线视频你懂的| 亚洲国产精品黑丝美女| 日韩不卡中文在线视频网站| 天天干夜夜操啊啊啊| 国产免费高清视频视频| 93人妻人人揉人人澡人人| 日韩三级黄色片网站| 一区二区三区久久中文字幕| 日辽宁老肥女在线观看视频| 人妻最新视频在线免费观看| 亚洲在线一区二区欧美| 国产女人叫床高潮大片视频| 欧美老鸡巴日小嫩逼| 中文人妻AV久久人妻水| 100%美女蜜桃视频| 天天操天天干天天日狠狠插| 欧美在线精品一区二区三区视频| 热久久只有这里有精品| 日本午夜爽爽爽爽爽视频在线观看 | 边摸边做超爽毛片18禁色戒 | 亚洲 人妻 激情 中文| 日韩欧美国产一区ab| 亚洲高清自偷揄拍自拍| 欧美久久一区二区伊人| 精品一区二区三区午夜| 在线观看视频网站麻豆| 日日摸夜夜添夜夜添毛片性色av| 大白屁股精品视频国产| 91传媒一区二区三区| 精品国产高潮中文字幕| 任你操任你干精品在线视频| 国产极品精品免费视频| 91福利在线视频免费观看| 国产精品久久久黄网站| 成人性黑人一级av| gogo国模私拍视频|