国产剧情视频在线观看-国产剧情麻豆女教师在线观看-国产剧情精品在线观看-国产剧情精品-国产剧情91-国产玖玖在线观看

以文本方式查看主題

-  曙海教育集團(tuán)論壇  (http://m.hufushizhe.com/bbs/index.asp)
--  Android應(yīng)用開(kāi)發(fā)  (http://m.hufushizhe.com/bbs/list.asp?boardid=45)
----  JNI技術(shù)與Android應(yīng)用  (http://m.hufushizhe.com/bbs/dispbbs.asp?boardid=45&id=2024)

--  作者:wangxinxin
--  發(fā)布時(shí)間:2010-12-3 11:15:40
--  JNI技術(shù)與Android應(yīng)用
1. 什么是 JNI
    JNI是Java Native Interface的縮寫(xiě)。從Java 1.1開(kāi)始,JNI標(biāo)準(zhǔn)成為java平臺(tái)的一部分,它允許Java和其他語(yǔ)言進(jìn)行交互。JNI一開(kāi)始為C和C++而設(shè)計(jì)的,但是它并不妨礙你使用其他語(yǔ) 言,只要調(diào)用約定受支持就可以了。使用java與本地已編譯的代碼交互,通常會(huì)喪失平臺(tái)可移植性。但是,有些情況下這樣做是可以接受的,甚至是必須的,比 如,使用一些舊的庫(kù),與硬件、操作系統(tǒng)進(jìn)行交互,或者為了提高程序的性能。關(guān)于 JNI 的用法很簡(jiǎn)單,有點(diǎn)像 java 里的 reflect 的工作機(jī)制,有興趣的朋友可以參看Java 本地接口規(guī)范 http://linux.computersci.net/art ... pec/jniTOC.doc.html
2.  Jni程序開(kāi)發(fā)的一般操作步驟如下:
(1) 編寫(xiě)帶有native聲明的方法的java類(lèi)
(2) 使用javac 或 IDE(JBuilder,eclipse等)編譯所編寫(xiě)的java類(lèi)
(3) 使用javah -jni java類(lèi)名生成擴(kuò)展名為h的頭文件
(4) 使用C++ 實(shí)現(xiàn)本地方法,對(duì)調(diào)用簽名可用 javap –s –p [類(lèi)全名] 查看(開(kāi)發(fā) C++ 動(dòng)態(tài)鏈接庫(kù)本例是用的 VC6)
注意要從 JDK下面的 include 文件夾中把 jni.h和 jni_md.h 兩個(gè)文件 copy 到你的 VC 工程里
(5) 在 Java 中 load 動(dòng)態(tài)鏈接庫(kù)文件,調(diào)用 native 方法.
或者說(shuō)將項(xiàng)目依賴(lài)的所有原生庫(kù)和資源加入到j(luò)ava項(xiàng)目的java.library.path,生成java程序
3. 開(kāi)發(fā)實(shí)例
(1). 編寫(xiě) Java 類(lèi):
package org.jm.jni;
import java.util.ArrayList;
public class BackgroundProcess {
static {
System.loadLibrary("org_jm_jni_BackgroundProcess");
}
// 三個(gè) native 方法和一個(gè) int 變量
public native boolean checkValid();
public native void processData(BackgroundProcess bg);
public native void processGarbage(String[] bg);
public int num = 5;
// C++ 中可以調(diào)用的方法
public String backProcess(ArrayList<String> p) {
System.out.println("這是 Java 里的方法,在 C++ 中調(diào)用。");
System.out.println("這個(gè)方法,是 java 中 native checkValid 方法調(diào)用的。");
return "look up process ->" + p;
}
public static void main(String[] args) {
String[] array = new String[4];
array[0] = "jack";
array[1] = "maggie";
array[2] = "rocket";
array[3] = "tom";
BackgroundProcess bgP = new BackgroundProcess();
// 調(diào)用 C++ DLL 中定義的方法。
bgP.checkValid();// 該方法回調(diào) java 中的 backProcess 方法,即java::checkValid->c++::checkValid->java::backProcess
bgP.processData(bgP);
bgP.processGarbage(array);
// C++ DLL 改變了該變量
System.out.println("number 現(xiàn)在的值是: " + bgP.num);
}
}
2. 生成 C++ 的頭文件(javah 命令生成,用javap –s –p [類(lèi)全名] 命令查看java 方法簽名)
/* DO NOT EDIT THIS FILE - it is machine generated */
#include "jni.h"
/* Header for class org_jm_jni_BackgroundProcess */
#ifndef _Included_org_jm_jni_BackgroundProcess
#define _Included_org_jm_jni_BackgroundProcess
#ifdef __cplusplus
extern "C" {
#endif
/*
* Class: org_jm_jni_BackgroundProcess
* Method: checkValid
* Signature: ()Z
*/
JNIEXPORT jboolean JNICALL Java_org_jm_jni_BackgroundProcess_checkValid
(JNIEnv *, jobject);
/*
* Class: org_jm_jni_BackgroundProcess
* Method: processData
* Signature: (Lorg/jm/jni/BackgroundProcess;)V
*/
JNIEXPORT void JNICALL Java_org_jm_jni_BackgroundProcess_processData
(JNIEnv *, jobject, jobject);
/*
* Class: org_jm_jni_BackgroundProcess
* Method: processGarbage
* Signature: ([Ljava/lang/String;)V
*/
JNIEXPORT void JNICALL Java_org_jm_jni_BackgroundProcess_processGarbage
(JNIEnv *, jobject, jobjectArray);
#ifdef __cplusplus
}
#endif
#endif
    這里JNIEXPORT和JNICALL都是JNI的關(guān)鍵字,表示此函數(shù)是要被JNI調(diào)用的。例如jint是以JNI為中介使JAVA的int類(lèi)型與本地 的int溝通的一種類(lèi)型,我們可以視而不見(jiàn),就當(dāng)做int使用。函數(shù)的名稱(chēng)是JAVA_再加上java程序的package路徑再加函數(shù)名組成的。參數(shù) 中,我們也只需要關(guān)心在JAVA程序中存在的參數(shù),至于JNIEnv*和jclass我們一般沒(méi)有必要去碰它。
3. 開(kāi)發(fā) C++ DLL 的原文件 (記得要加入 jni.h 和 jni_md.h 兩個(gè)文件)
發(fā)布 DLL 文件, 我是配置了 path 環(huán)境變量
#include "org_jm_jni_BackgroundProcess.h"
#include <iostream.h>
#include <windows.h>
#include "string.h"
char* jstringTostring(JNIEnv* env, jstring jstr)
{
char* rtn = NULL;
jclass clsstring = env->FindClass("java/lang/String");
jstring strencode = env->NewStringUTF("utf-8");
jmethodID mid = env->GetMethodID(clsstring, "getBytes", "(Ljava/lang/String;)[B");
jbyteArray barr= (jbyteArray)env->CallObjectMethod(jstr, mid, strencode);
jsize alen = env->GetArrayLength(barr);
jbyte* ba = env->GetByteArrayElements(barr, JNI_FALSE);
if (alen > 0)
{
rtn = (char*)malloc(alen + 1);
memcpy(rtn, ba, alen);
rtn[alen] = 0;
}
env->ReleaseByteArrayElements(barr, ba, 0);
return rtn;
}
//char* to jstring
jstring stoJstring(JNIEnv* env, const char* pat)
{
jclass strClass = env->FindClass("Ljava/lang/String;");
jmethodID ctorID = env->GetMethodID(strClass, "<init>", "([BLjava/lang/String;)V");
jbyteArray bytes = env->NewByteArray(strlen(pat));
env->SetByteArrayRegion(bytes, 0, strlen(pat), (jbyte*)pat);
jstring encoding = env->NewStringUTF("utf-8");
return (jstring)env->NewObject(strClass, ctorID, bytes, encoding);
}
/*
* Class: org_jm_jni_BackgroundProcess
* Method: checkValid
* Signature: ()Z
*/
JNIEXPORT jboolean JNICALL Java_org_jm_jni_BackgroundProcess_checkValid
(JNIEnv *env, jobject obj){
jclass bgpClass=env->GetObjectClass(obj);
jmethodID methodId=env->GetMethodID(bgpClass,"backProcess","(Ljava/util/ArrayList;)Ljava/lang/String;");
jobject str=env->CallObjectMethod(obj,methodId,NULL);
jfieldID fieldId=env->GetFieldID(bgpClass,"num","I");
jint number=env->GetIntField(obj,fieldId);
cout << "number 值是: " <<number << endl;
env->SetIntField(obj,fieldId,100L);
return 1;
}
/*
* Class: org_jm_jni_BackgroundProcess
* Method: processData
* Signature: (Lorg/jm/jni/BackgroundProcess;)V
*/
JNIEXPORT void JNICALL Java_org_jm_jni_BackgroundProcess_processData
(JNIEnv *env, jobject, jobject){
cout<< "this function do nothing " << endl;
}
/*
* Class: org_jm_jni_BackgroundProcess
* Method: processGarbage
* Signature: ([Ljava/lang/String;)V
*/
JNIEXPORT void JNICALL Java_org_jm_jni_BackgroundProcess_processGarbage
(JNIEnv *env, jobject, jobjectArray array){
jint size=env->GetArrayLength(array);
cout << "數(shù)組大小是: " << size << endl;
jstring tempObj=NULL;
char *pszSTR1 = NULL;
for(int i=0;i<size;i++){
cout << "current value is : " << i << endl;
tempObj=(jstring)env->GetObjectArrayElement(array,i);
const char * chars =env->GetStringUTFChars(tempObj, 0);
cout << chars << endl;
}
}
在此,針對(duì)andorid中c++與java中的方法互調(diào),引用參考說(shuō)明如下:
(1).andorid CPP調(diào)用java函數(shù)和訪問(wèn)其成員:原理 => CPP代碼找到j(luò)ava的那個(gè)class里面的函數(shù)的入口地址,然后在CPP代碼中調(diào)用java代碼
步驟1) 用FindClass()函數(shù)找到該java類(lèi)(如android.os.Binder)的實(shí)例對(duì)象的引用:
  jclass clazz = env->FindClass(kBinderPathName) = env->FindClass("android.os.Binder")
步驟2) 用GetFieldID()函數(shù)獲取到要訪問(wèn)的域(field: 實(shí)際上就是該java class中的某個(gè)成員變量的名字)的ID:
  gBinderOffsets.mObject = env->GetFieldID(clazz, "mObject", "I") // mObject為java class "Binder"里的一個(gè)成員變量
  -> 注意,這里將要訪問(wèn)的那個(gè)java對(duì)象的成員mObject的ID保存到了全局變量gBinderOffsets.mObject中,這樣做的前提和優(yōu)點(diǎn)如下:
  前提: android里面,每個(gè)java進(jìn)程中只允許有一個(gè)java虛擬機(jī)(sun公司原始的java架構(gòu)中,一個(gè)進(jìn)程中可以有多個(gè)java虛擬機(jī))
  優(yōu)點(diǎn): 除了第一次,以后每次要訪問(wèn)該java對(duì)象的成員mObject就非常快了(不用再去FindClass()和GetFieldID())
步驟3) 用GetMethodID()函數(shù)獲取到要訪問(wèn)的方法(Method: 實(shí)際上就是該java class中的某個(gè)成員函數(shù)的名字)的ID:
  gBinderOffsets.mExecTransact = env->GetMethodID(clazz, "execTransact", "(IIII)Z") // execTransact為java class "Binder"里的一個(gè)成員函數(shù)
步驟4) 用類(lèi)似于GetIntField()的函數(shù)獲取到該java對(duì)象的那個(gè)域(即成員)的值:
  IBinder* target = (IBinder*)env->GetIntField(obj,gBinderProxyOffsets.mObject)
     // 獲取java android.os.Binder類(lèi)型對(duì)象里面的成員mObject的值
步驟5) 用類(lèi)似于CallBooleanMethod()的函數(shù)調(diào)用到該java對(duì)象的那個(gè)成員函數(shù):
  jboolean res = env->CallBooleanMethod(mObject, gBinderOffsets.mExecTransact, code, (int32_t)&data, (int32_t)reply, flags)
(2).android java調(diào)用CPP函數(shù): 原理 => 相當(dāng)于java的那個(gè)class里面有的函數(shù)使用CPP代碼來(lái)實(shí)現(xiàn)了
1)通過(guò)結(jié)構(gòu)JNINativeMethod描述java代碼調(diào)用函數(shù)和CPP函數(shù)的對(duì)應(yīng)關(guān)系:
  typedef struct {
  const char* name; // java代碼調(diào)用CPP函數(shù)的入口
  const char* signature; // CPP函數(shù)的返回值
  void* fnPtr; // CPP的函數(shù)名
  } JNINativeMethod;
  => 例如: java代碼通過(guò)IBinder.transact()來(lái)調(diào)用CPP的函數(shù)android_os_BinderProxy_transact()
  {"transact", "(ILandroid/os/Parcel;Landroid/os/Parcel;I)Z", (void*)android_os_BinderProxy_transact},
2)將CPP函數(shù)注冊(cè)到j(luò)ava的某個(gè)class中: 使用函數(shù)AndroidRuntime::registerNativeMethods()來(lái)注冊(cè)
  => 這之后,java代碼就可以調(diào)用CPP函數(shù)了
3)java代碼調(diào)用CPP函數(shù)方法:
  IBinder.transact()
總結(jié)其原理:C/C++要調(diào)用JAVA程序,必須先加載JAVA虛擬機(jī),由JAVA虛擬機(jī)解釋執(zhí)行class文件。為了初始化JAVA虛擬機(jī),JNI提供了一系列的接口函數(shù),通過(guò)這些函數(shù)方便地加載虛擬機(jī)到內(nèi)存中。
1). 加載虛擬機(jī):
函數(shù):jint JNI_CreateJavaVM(JavaVM **pvm, void **penv, void args);
參數(shù)說(shuō)明:JavaVM **pvm JAVA虛擬機(jī)指針,第二個(gè)參數(shù)JNIEnv *env是貫穿整個(gè)調(diào)用過(guò)程的一個(gè)參數(shù),因?yàn)楹竺娴乃泻瘮?shù)都需要這個(gè)參數(shù),需注意的是第三個(gè)參數(shù),在jdk1.1與1.2版本有些不同,在JDK 1.1中第三個(gè)參數(shù)總是指向一個(gè)結(jié)構(gòu)JDK1_ 1InitArgs,這個(gè)結(jié)構(gòu)無(wú)法完全在所有版本的虛擬機(jī)中進(jìn)行無(wú)縫移植。所以為了保證可移植性,建議使用jdk1.2的方法加載虛擬機(jī)。
2). 獲取指定對(duì)象的類(lèi)定義:
有兩種方法可獲得類(lèi)定義,一是在已知類(lèi)名的情況使用FindClass來(lái)獲取;二是通過(guò)對(duì)象直接得到類(lèi)定義GetObjectClass
3). 獲取要調(diào)用的方法:
獲得非靜態(tài)方法:
jmethodID (JNICALL *GetMethodID)(JNIEnv *env, jclass clazz, const char *name, const char *sig);
獲得靜態(tài)方法:
jmethodID (JNICALL *GetStaticMethodID)(JNIEnv *env, jclass class, const char *name, const char *sig);
參數(shù)說(shuō)明:JNIEnv *env初始化是得到的JNI環(huán)境;jclass class前面已獲取到的類(lèi)定義;const char *name方法名;const char *sig方法參數(shù)定義
4). 調(diào)用JAVA類(lèi)方法:
函數(shù):CallObjectMethod(JNIEnv *env, jobject obj, jmethodID mid);
函數(shù):CallStaticObjectMethod((JNIEnv *env, jobject obj, jmethodID mid);
5). 獲得類(lèi)屬性的定義:
jfieldID (JNICALL *GetFieldID) (JNIEnv *env, jclass clazz, const char *name, const char *sig);
靜態(tài)屬性:
jfieldID (JNICALL *GetStaticFieldID) (JNIEnv *env, jclass clazz, const char *name, const char *sig);
6). 數(shù)組處理:
要?jiǎng)?chuàng)建數(shù)組首先要知道類(lèi)型及長(zhǎng)度,JNI提供了一系列的數(shù)組類(lèi)型及操作的函數(shù)如:
NewIntArray、NewLongArray、NewShortArray、NewFloatArray、NewDoubleArray、 NewBooleanArray、NewStringUTF、NewCharArray、NewByteArray、NewString,訪問(wèn)通過(guò) GetBooleanArrayElements、GetIntArrayElements等函數(shù)。
7). 異常:
由于調(diào)用了Java的方法,會(huì)產(chǎn)生異常。這些異常在C/C++中無(wú)法通過(guò)本身的異常處理機(jī)制來(lái)捕捉到,但可以通過(guò)JNI一些函數(shù)來(lái)獲取Java中拋出的異常信息。
8).多線程調(diào)用
我們知道JAVA是非常消耗內(nèi)存的,我們希望在多線程中能共享一個(gè)JVM虛擬機(jī),真正消耗大量系統(tǒng)資源的是JAVA虛擬機(jī)jvm而不是虛擬機(jī)環(huán)境 env,jvm是允許多個(gè)線程訪問(wèn)的,但是虛擬機(jī)環(huán)境只能被創(chuàng)建它本身的線程所訪問(wèn),而且每個(gè)線程必須創(chuàng)建自己的虛擬機(jī)環(huán)境env。JNI提供了兩個(gè)函 數(shù):AttachCurrentThread和DetachCurrentThread。便于子線程創(chuàng)建自己的虛擬機(jī)環(huán)境。
4.  java與dll交互的技術(shù)
    目前java與dll交互的技術(shù)主要有3種:jni,jawin和jacob。Jni(Java Native Interface)是sun提供的java與系統(tǒng)中的原生方法交互的技術(shù)(在windows\\linux系統(tǒng)中,實(shí)現(xiàn)java與native method互調(diào))。目前只能由c/c++實(shí)現(xiàn)。后兩個(gè)都是sourceforge上的開(kāi)源項(xiàng)目,同時(shí)也都是基于jni技術(shù)的windows系統(tǒng)上的一個(gè) 應(yīng)用庫(kù)。Jacob(Java-Com Bridge)提供了java程序調(diào)用microsoft的com對(duì)象中的方法的能力。而除了com對(duì)象外,jawin(Java/Win32 integration project)還可以win32-dll動(dòng)態(tài)鏈接庫(kù)中的方法。就功能而言:jni >> jawin>jacob,其大致的結(jié)構(gòu)如下圖:
圖片點(diǎn)擊可在新窗口打開(kāi)查看
就易用性而言,正好相反:jacob>jawin>>jni。
    Jvm封裝了各種操作系統(tǒng)實(shí)際的差異性的同時(shí),提供了jni技術(shù),使得開(kāi)發(fā)者可以通過(guò)java程序(代碼)調(diào)用到操作系統(tǒng)相關(guān)的技術(shù)實(shí)現(xiàn)的庫(kù)函數(shù),從而與 其他技術(shù)和系統(tǒng)交互,使用其他技術(shù)實(shí)現(xiàn)的系統(tǒng)的功能;同時(shí)其他技術(shù)和系統(tǒng)也可以通過(guò)jni提供的相應(yīng)原生接口開(kāi)調(diào)用java應(yīng)用系統(tǒng)內(nèi)部實(shí)現(xiàn)的功能。在 windows系統(tǒng)上,一般可執(zhí)行的應(yīng)用程序都是基于native的PE結(jié)構(gòu),windows上的jvm也是基于native結(jié)構(gòu)實(shí)現(xiàn)的。Java應(yīng)用體 系都是構(gòu)建于jvm之上。
圖片點(diǎn)擊可在新窗口打開(kāi)查看
    Jni對(duì)于應(yīng)用本身來(lái)說(shuō),可以看做一個(gè)代理模式。對(duì)于開(kāi)發(fā)者來(lái)說(shuō),需要使用c/c++來(lái)實(shí)現(xiàn)一個(gè)代理程序(jni程序)來(lái)實(shí)際操作目標(biāo)原生函數(shù),java程序中則是jvm通過(guò)加載并調(diào)用此jni程序來(lái)間接地調(diào)用目標(biāo)原生函數(shù)。
圖片點(diǎn)擊可在新窗口打開(kāi)查看
5. Android中jni的現(xiàn)有應(yīng)用
(1).從如何載入.so檔案談起
由于Android的應(yīng)用層的類(lèi)都是以Java寫(xiě)的,這些Java類(lèi)編譯為Dex型式的Bytecode之后,必須靠Dalvik虛擬機(jī)(VM: Virtual Machine)來(lái)執(zhí)行。VM在Android平臺(tái)里,扮演很重要的角色。此外,在執(zhí)行Java類(lèi)的過(guò)程中,如果Java類(lèi)需要與C組件溝通時(shí),VM就會(huì) 去載入C組件,然后讓Java的函數(shù)順利地調(diào)用到C組件的函數(shù)。此時(shí),VM扮演著橋梁的角色,讓Java與C組件能通過(guò)標(biāo)準(zhǔn)的JNI介面而相互溝通。應(yīng)用 層的Java類(lèi)是在虛擬機(jī)(VM: Vitual Machine)上執(zhí)行的,而C件不是在VM上執(zhí)行,那么Java程式又如何要求VM去載入(Load)所指定的C組件呢? 可使用下述指令:
System.loadLibrary(*.so的檔案名);
例如,Android框架里所提供的MediaPlayer.java類(lèi),含指令:
public class MediaPlayer{
static {
System.loadLibrary("media_jni");
}
}
  這要求VM去載入Android的/system/lib/libmedia_jni.so檔案。載入*.so之后,Java類(lèi)與*.so檔案就匯合起來(lái),一起執(zhí)行了。

国产剧情视频在线观看-国产剧情麻豆女教师在线观看-国产剧情精品在线观看-国产剧情精品-国产剧情91-国产玖玖在线观看
<dfn id="is4kg"></dfn>
  • <ul id="is4kg"></ul>
  • <abbr id="is4kg"></abbr>
  • <ul id="is4kg"></ul>
    <bdo id="is4kg"></bdo>
    精品久久中出| 国产欧美日韩综合一区在线观看| 成人免费在线视频网站| 日本在线观看不卡| 国产精品视频一| 欧美一区二区在线| 国产欧美一区二区| 天天久久人人| 51精品国产人成在线观看| 亚洲黄色成人久久久| 国产精品亚洲片夜色在线| 欧美一区二区高清在线观看| 国产精品爽爽ⅴa在线观看| 欧美一区二区三区在线播放 | 亚洲一区二区三区在线视频 | 亚洲一区三区视频在线观看| 亚洲精品日韩av| 久久噜噜噜精品国产亚洲综合| 99视频免费观看蜜桃视频| 国内自拍欧美激情| 欧美精品亚洲精品| 成人免费在线视频网址| 91国在线精品国内播放| 日韩欧美精品一区二区三区经典| 亚洲自拍偷拍色片视频| 日本精品久久久久影院| 一区二区三区我不卡| 国产一区二区自拍| 91欧美激情另类亚洲| 91精品国产91| 五月天亚洲综合情| 国产日韩欧美综合精品 | 一区二区冒白浆视频| 91视频婷婷| 国产精品久久久久久久电影| 久久久亚洲天堂| 欧洲视频一区二区三区| 古典武侠综合av第一页| 国产精品美乳一区二区免费 | 亚洲三区四区| 精品久久久久久亚洲| 成人综合网网址| 日本亚洲欧洲色α| 中文字幕一区二区三区有限公司| 蜜桃网站成人| 国产伦精品一区二区三区视频免费 | 成人在线视频网站| 热re91久久精品国99热蜜臀| 欧美精品18videos性欧美| 欧美婷婷久久| 久久99精品久久久久子伦| 2022国产精品| 91精品在线国产| 国产精品视频自拍| 国产不卡视频在线| 欧洲精品在线视频| 91大神在线播放精品| 欧美激情乱人伦一区| 新呦u视频一区二区| 欧美日韩综合精品| 蜜桃在线一区二区三区精品| 国产区日韩欧美| 动漫美女被爆操久久久| 成人欧美一区二区| 99热99热| 岛国视频一区| 俄罗斯精品一区二区| 成人黄色在线免费| 国产视频福利一区| 成人福利网站在线观看11| 国产精品亚洲美女av网站| 国产精品美女午夜av| 国产精品男人的天堂| 国产精品扒开腿做爽爽爽视频| 7m精品福利视频导航| 91av在线国产| 国产精品第一页在线| 国产精品免费久久久| 国产精品视频精品视频| 成人a视频在线观看| 成人精品一区二区三区| 成人有码视频在线播放| 4444kk亚洲人成电影在线| aa成人免费视频| 国产日韩一区二区三区| 欧美精品欧美精品系列c| 日韩妆和欧美的一区二区| 亚洲国产一区在线| 97视频在线观看成人| 欧美一级成年大片在线观看| 国产精品国内视频| 亚洲精品欧美极品| 国产精品久久精品国产| 乱一区二区三区在线播放| 日韩av电影免费播放| 亚洲永久激情精品| 91国内在线视频| 国产精品99久久久久久久久久久久 | 国产91免费看片| 国产精品电影一区| 亚洲一区中文字幕| 精品一区二区国产| 亚洲午夜精品久久久久久浪潮| 久久久这里只有精品视频| 日本中文字幕久久看| 国产日韩欧美日韩大片| 岛国视频一区| 手机看片福利永久国产日韩| 国模叶桐国产精品一区| 国产精品九九九| 成人av网站观看| 日本在线成人一区二区| 96精品视频在线| 91精品视频在线| 精品日韩欧美| 欧美精品videos性欧美| 国产精品嫩草影院久久久| 成人av免费电影| 色一情一乱一伦一区二区三区 | 国产精品 欧美在线| 国产专区欧美专区| 精品人伦一区二区三区| 中国人体摄影一区二区三区| 国产精品2018| 成人一区二区在线| 亚洲v国产v在线观看| 欧美一级片久久久久久久| 成人写真福利网| 欧美日韩亚洲一区二区三区四区| 久久全国免费视频| 91久久精品美女高潮| 你懂的视频在线一区二区| 91精品久久久久久蜜桃| 蜜桃麻豆91| 韩国精品久久久999| 国产精品亚洲第一区| 国产一区二区三区奇米久涩| 亚洲午夜久久久影院伊人| 日本精品视频网站| 91成人伦理在线电影| 日韩高清dvd| 欧美一区视频在线| 精品日本一区二区三区在线观看| 中文字幕一区二区三区有限公司 | 国产91免费看片| www国产亚洲精品| 日韩欧美手机在线| 国产精品第1页| 鲁鲁视频www一区二区| 欧美亚洲成人网| 国产精品国产一区二区| 久久久视频在线| 91久久偷偷做嫩草影院| 色综合久久悠悠| 96pao国产成视频永久免费| 色综合666| 成人国产在线激情| 亚洲欧洲久久| 成人xvideos免费视频| 欧美日韩亚洲一区二区三区四区| 热99精品里视频精品| 国产综合色一区二区三区| 久久人人爽人人爽人人片av高请 | 欧美做受高潮电影o| 福利视频久久| 欧美亚洲日本网站| 久久亚洲高清| 国产成人精品最新| 另类视频在线观看+1080p| 国产91ⅴ在线精品免费观看| 精品视频免费观看| 国产精品第1页| 午夜精品福利一区二区| 亚洲iv一区二区三区| 久久久久久一区二区三区| 产国精品偷在线| 欧美一级视频一区二区| 日韩成人av电影在线| 成人午夜激情免费视频| 97国产成人精品视频| 久久久久se| 国产精品视频免费观看www| 亚洲视频在线二区| 国产经品一区二区| 国产精品久久久久久久9999| 亚洲一区二区在线看| 国产二区不卡| 国产日韩av在线播放| 欧美国产视频一区二区| 精品久久久久久中文字幕动漫| 国产97在线观看| 亚洲欧美日韩另类精品一区二区三区| 99在线视频播放| 国产精品99久久久久久www| 亚洲日本japanese丝袜| 精品伦精品一区二区三区视频| 国产精品亚洲片夜色在线| 久久久免费精品| 日本精品一区二区三区视频| 国产精品裸体一区二区三区| 国产精品视频999| 97精品国产97久久久久久免费| 欧美人与物videos另类| 高清av免费一区中文字幕| 国产黑人绿帽在线第一区| 久久久久这里只有精品| 日本a级片久久久| 国产精品果冻传媒潘| 国产精品视频免费在线| 91wwwcom在线观看| 欧美国产日韩一区二区在线观看| 免费国产一区二区| 99porn视频在线| 国产日韩av高清| 国产91在线播放| 91精品国产色综合久久不卡98口| 一区二区三区久久网| 欧美久久久久久久| 国产精品一区二区三区四区五区| 成人在线激情视频| 国产精品久久久久久超碰| 91国内免费在线视频| 欧美激情第99页| 亚洲一区三区| 一区二区三区四区不卡| 日本免费一区二区三区| 国内一区在线| 国产伦精品一区二区三区视频免费| 91麻豆国产语对白在线观看| 国产精品露脸av在线| 欧洲日本亚洲国产区| 69av在线视频| 日本一区免费| 日韩一区不卡| 视频一区在线免费观看| 日韩av一区二区三区在线观看| 精品日本一区二区| 极品尤物一区二区三区| 国产午夜精品一区| 精品亚洲欧美日韩| 免费在线一区二区| 日韩精品第一页| 色一情一乱一伦一区二区三区 | 欧美激情欧美狂野欧美精品| 亚洲欧洲日夜超级视频| 亚洲欧洲三级| 亚洲综合五月天| 一区二区三视频| 久久久久久亚洲精品| 久久乐国产精品| 午夜精品国产精品大乳美女| 欧美一级大片视频| 国产成人欧美在线观看| 国产精品一区二区三区免费视频| 国产精品亚洲综合天堂夜夜| 91久久精品在线| av在线亚洲男人的天堂| 国产伦理一区二区三区| 快播亚洲色图| 亚洲精品视频一二三| 欧美高清videos高潮hd| 欧美一级bbbbb性bbbb喷潮片| 日本精品一区二区三区在线播放视频 | 国产视频观看一区| 91九色视频在线观看| 国产免费一区二区| 日韩性感在线| 午夜精品蜜臀一区二区三区免费 | 日韩av一区二区三区美女毛片| 日韩欧美精品一区二区三区经典| 中文字幕中文字幕在线中一区高清| 高清一区二区三区四区五区| 国产成人极品视频| 国产日韩欧美影视| 高清不卡日本v二区在线| 欧美下载看逼逼| 欧美激情精品久久久久| 日韩av免费在线看| 91丝袜美腿美女视频网站| 成人h视频在线观看| 欧美日产一区二区三区在线观看| 欧美第一黄色网| 国产精品久久久久久久7电影| 成人在线视频网| 久久国产精品 国产精品| 欧美韩国理论所午夜片917电影| 日本免费久久高清视频| 91丨九色丨国产| 日本在线视频一区| 欧美在线视频免费播放| 成人欧美一区二区三区在线 | 国产这里只有精品| 九九九九精品| 欧美精品aaa| 国产日韩在线观看av| 性色av香蕉一区二区| 一区二区三区视频| 91国内在线视频| 国产情人节一区| 久久综合九色99| 久久久久久国产免费| 国产精品久久一区主播| 国产精品国产三级国产专区53| 日韩欧美激情一区二区| 国产91精品高潮白浆喷水| 成人亚洲欧美一区二区三区| 欧美精品七区| 欧美又大粗又爽又黄大片视频| 亚洲在线一区二区| 亚洲色图自拍| 国产欧美一区二区| 欧美日韩国产综合在线| 欧美在线激情网| 国产免费高清一区| 欧美极度另类性三渗透| 成人精品久久久| 日本一区二区高清视频| 国产极品jizzhd欧美| 国产在线欧美日韩| 欧美一级视频在线观看| 成人情视频高清免费观看电影| 亚洲在线观看一区| 91视频免费在线| 在线观看欧美一区| 成人激情春色网| 色综合久久久久久久久五月| 国产经典一区二区| 欧美成人蜜桃| 国产精品盗摄久久久| 欧美日韩免费精品| 国产精品视频免费观看www| 91九色国产视频| 久久久久久久久久久久av| 99久久99久久| 97在线观看视频国产| 国产精品永久入口久久久| 91精品国产91久久久久久吃药| 国产成人精品日本亚洲11| 性日韩欧美在线视频| 国产一区国产精品| 国产精品久久久久不卡| 天堂一区二区三区 | 国产精品久久久久久久久久东京| 欧洲亚洲一区二区| 国产综合色香蕉精品| 在线电影看在线一区二区三区| 97人人做人人人难人人做| 韩国日本不卡在线| 久久av免费一区| 国产精品久久久久久久久免费看| 亚洲高清视频一区| 高清不卡日本v二区在线| 日韩av毛片网| 亚洲一区二区三区精品视频| 国产免费一区二区三区| 国产精品免费一区豆花| 欧美疯狂性受xxxxx另类| 激情伦成人综合小说| 国产精品男人的天堂| 中文字幕中文字幕在线中一区高清 | 国产精品成人久久久久| 日韩一区二区电影在线观看| 91偷拍精品一区二区三区| 2020久久国产精品| 国产视频精品网| 国产精品尤物福利片在线观看| 中文字幕一区二区三区有限公司| 国产在线欧美日韩| 成人网址在线观看| 欧美中文在线免费| 中文精品视频一区二区在线观看| 国产日韩欧美一区二区| 国产一区视频在线| 奇米四色中文综合久久| 中文字幕久精品免| 日韩精品资源| 国产欧美日韩伦理| 成人免费xxxxx在线观看| 欧美在线观看网站| 欧美激情18p| 亚洲高清不卡一区| 欧美精品欧美精品系列c| 国产伦精品一区二区三区照片91| 国产综合福利在线| 国产高清视频一区三区| 午夜精品久久久久久久久久久久久| 日韩av电影免费在线| 好看的日韩精品| 国产精品免费在线| 亚洲尤物视频网| 国产一区视频在线播放| 国产精品电影久久久久电影网| 97在线观看免费高清| 欧美福利视频在线| 国产一区二区三区四区五区加勒比| 91文字幕巨乱亚洲香蕉| 亚洲xxxx3d| 成人啪啪免费看| 国产欧美一区二区三区在线| 国产精品成人一区| 国产97人人超碰caoprom| 欧美性受xxxx黑人猛交| 97久久精品人搡人人玩| 高清欧美性猛交xxxx| 欧美高清无遮挡| 在线视频欧美一区| 欧美多人乱p欧美4p久久| 亚洲最大免费| 欧美激情2020午夜免费观看| 欧美高清性猛交| 欧美激情图片区| 欧美激情一区二区三区久久久 | 国产精品久久电影观看| 欧美在线观看日本一区| 奇米四色中文综合久久| 日本伊人精品一区二区三区介绍| 日本a级片久久久| 欧美三日本三级少妇三99| 欧美精品七区| 日韩一区免费观看| 中文字幕中文字幕99| 久久乐国产精品| 国产91ⅴ在线精品免费观看| 国产成人精品久久久| 国产精品直播网红| 亚洲自拍偷拍视频| 99视频在线播放| 精品久久久久久一区二区里番| 蜜桃av噜噜一区二区三| 亚洲在线色站| 午夜精品视频在线| 国产精品福利片| 成人国产亚洲精品a区天堂华泰| 91在线看www| 国产伦精品一区二区三区四区免费| 蜜桃在线一区二区三区精品| 亚洲看片网站| 91禁外国网站| 国产精品色视频| 99高清视频有精品视频| 久久久综合香蕉尹人综合网| 亚洲欧美日韩在线综合| 性欧美xxxx视频在线观看| 亲爱的老师9免费观看全集电视剧| 国产精品美女999| 成人免费在线看片| 日本一区二区三区精品视频| 韩国欧美亚洲国产| 国产精品久久久久av| 2014亚洲精品| 欧美日韩系列| 国产69精品99久久久久久宅男| 日韩美女视频免费看| 97人人模人人爽人人喊38tv| 免费成人在线观看av| 一区二区三区欧美在线| 欧美在线视频观看免费网站| 成人午夜小视频| 精品免费视频123区| 影音先锋欧美资源| 国产精品第一页在线| 俄罗斯精品一区二区三区| 手机在线观看国产精品| 欧美在线欧美在线| 亚洲一区二区三区视频| 欧洲一区二区日韩在线视频观看免费 | 欧美第一淫aaasss性| 国产精品日韩欧美综合| 国产精品一区而去| 一区二区三区四区视频在线| 国产成人精品免高潮费视频| 国产一区二区三区高清| 韩日欧美一区二区| 亚洲淫片在线视频| 青青影院一区二区三区四区| 欧美制服第一页| 亚洲一区二区三区四区在线播放| 日韩国产精品一区二区| 国产精品久久在线观看| 久久国产一区二区| 97超碰国产精品女人人人爽| 亚洲综合自拍一区| 一区二区三区|亚洲午夜| 国产精品一区二区三区久久| 日本一区二区三区www| 国产成人一区二| 久久精品国产精品国产精品污 | 午夜精品视频在线| 99一区二区三区| 欧美激情视频一区二区| 91亚洲人电影| 综合一区中文字幕| 亚洲一区精品电影| 久久久久免费视频| 国产精华一区二区三区| 69久久夜色精品国产69乱青草| 亚洲xxxx视频| 久久久久成人精品| 成人欧美一区二区三区黑人免费| 91国产美女在线观看| 国产区日韩欧美| 欧美专区中文字幕| 欧美日韩亚洲一区二区三区在线观看| 日韩**中文字幕毛片| 欧美日韩国产免费一区二区三区| 欧美在线一级视频| 欧美精品一区在线| 国产乱肥老妇国产一区二| 亚洲高清123| 91久久精品国产91久久性色tv| 欧美精品福利在线| 狠狠色综合欧美激情| 国产91九色视频| 视频二区一区| 99视频网站| 国产精品福利网站| 亚洲国产成人不卡| 成人欧美一区二区三区在线观看 | 免费在线国产精品| 国产精品旅馆在线| 欧美激情成人在线视频| 97国产超碰| 茄子视频成人在线| 色99中文字幕| 粉嫩精品一区二区三区在线观看| 国产成人av在线| 亚洲成人第一| 国产乱人伦精品一区二区| 国产精品成人一区| 一区二区三区四区视频在线观看| 国产视频精品网| 国产欧美日韩视频| 性欧美xxxx交| 欧美性天天影院| 99re国产| 91精品免费看| 欧美在线视频播放| 亚洲午夜激情| 精品乱码一区| 91日韩在线播放| 国产精品成久久久久三级| 色综合视频网站| 欧美极品视频一区二区三区| 成人羞羞国产免费| 日本一欧美一欧美一亚洲视频| 在线视频不卡一区二区| 欧美另类视频在线| 成人欧美视频在线| 国产又爽又黄的激情精品视频| 2019av中文字幕| 欧美大片大片在线播放| 日本一区视频在线观看| 国产精品对白一区二区三区| 国产原创欧美精品| 国产成人福利视频| 2020国产精品视频| 久久露脸国产精品| 综合久久国产| 视频一区二区在线观看| 久久本道综合色狠狠五月| 成人欧美一区二区三区视频 | 97超级碰碰人国产在线观看| 亚洲一区美女| 久久久久成人精品免费播放动漫| 国产精品国产一区二区| 91精品久久久久久久久久| 国产成人久久久精品一区| 2019中文在线观看| 欧美夜福利tv在线| 性欧美视频videos6一9| 欧美激情第三页| 一区二区三区我不卡| 亚洲一区二区三区免费看| 亚洲精品一区二区三区av| 日本日本精品二区免费| 欧美区高清在线| 久久偷看各类wc女厕嘘嘘偷窃| 久久99精品久久久久久青青日本 | 欧洲高清一区二区| 欧洲亚洲一区二区| 欧美日韩亚洲一区二区三区四区| 久久资源av| 欧美成人蜜桃| 欧美黑人xxxxx| 日韩国产欧美精品| 秋霞毛片久久久久久久久| 欧美日韩大片一区二区三区| 欧美另类高清视频在线| 色一情一乱一伦一区二区三区丨| 奇米888一区二区三区| 人偷久久久久久久偷女厕| 日本一区高清不卡| 日韩久久久久久久| 在线免费观看成人| 国产69精品99久久久久久宅男| 欧美黄色三级网站| 91国内精品久久| 国产精品久久久91| 91性高湖久久久久久久久_久久99| 亚洲最大福利视频|