青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-250  評論-20  文章-55  trackbacks-0

CreateFile

The CreateFile function creates or opens the following objects and returns a handle that can be used to access
the object:
 files
 pipes
 mailslots
 communications resources
 disk devices(Windows NT only)
 consoles
 directories(open only)

CreateFile 函數創建或打開下列對象,并返回一個可以用來訪問這些對象的句柄。
 
文件
 pipes
 
郵槽
 
通信資源
 
磁盤驅動器(僅適用于 windowsNT
 
控制臺
 
文件夾(僅用于打開)

HANDLE CreateFile(
 LPCTSTR lpFileName,    //
指向文件名的指針
 DWORD dwDesiredAccess,    //
訪問模式(寫 / 讀)
 DWORD dwShareMode,    //
共享模式
 LPSECURITY_ATTRIBUTES lpSecurityAttributes, //
指向安全屬性的指針
 DWORD dwCreationDisposition,   //
如何創建
 DWORD dwFlagsAndAttributes,   //
文件屬性
 HANDLE hTemplateFile    //
用于復制文件句柄
);

Parametes
參數列表

參數

類型及說明

lpFileName

String ,要打開的文件的名字

dwDesiredAccess

Long ,如果為 GENERIC_READ 表示允許對設備進行讀訪問;如果為 GENERIC_WRITE 表示允許對設備進行寫訪問(可組合使用);如果為零,表示只允許獲取與一個設備有關的信息

dwShareMode

Long ,零表示不共享; FILE_SHARE_READ / FILE_SHARE_WRITE 表示允許對文件進行共享訪問

lpSecurityAttributes

SECURITY_ATTRIBUTES ,指向一個 SECURITY_ATTRIBUTES 結構的指針,定義了文件的安全特性(如果操作系統支持的話)

dwCreationDisposition

Long ,下述常數之一:

CREATE_NEW

創建文件;如文件存在則會出錯

CREATE_ALWAYS

創建文件,會改寫前一個文件

OPEN_EXISTING

文件必須已經存在。由設備提出要求

OPEN_ALWAYS

如文件不存在則創建它

TRUNCATE_EXISTING

講現有文件縮短為零長度

dwFlagsAndAttributes

Long ,一個或多個下述常數

FILE_ATTRIBUTE_ARCHIVE

標記歸檔屬性

FILE_ATTRIBUTE_COMPRESSED

將文件標記為已壓縮,或者標記為文件在目錄中的默認壓縮方式

FILE_ATTRIBUTE_NORMAL

默認屬性

FILE_ATTRIBUTE_HIDDEN

隱藏文件或目錄

FILE_ATTRIBUTE_READONLY

文件為只讀

FILE_ATTRIBUTE_SYSTEM

文件為系統文件

FILE_FLAG_WRITE_THROUGH

操作系統不得推遲對文件的寫操作

FILE_FLAG_OVERLAPPED

允許對文件進行重疊操作

FILE_FLAG_NO_BUFFERING

禁止對文件進行緩沖處理。文件只能寫入磁盤卷的扇區塊

FILE_FLAG_RANDOM_ACCESS

針對隨機訪問對文件緩沖進行優化

FILE_FLAG_SEQUENTIAL_SCAN

針對連續訪問對文件緩沖進行優化

FILE_FLAG_DELETE_ON_CLOSE

關閉了上一次打開的句柄后,將文件刪除。特別適合臨時文件

也可在 Windows NT 下組合使用下述常數標記:

SECURITY_ANONYMOUS SECURITY_IDENTIFICATION , SECURITY_IMPERSONATION SECURITY_DELEGATION SECURITY_CONTEXT_TRACKING SECURITY_EFFECTIVE_ONLY

hTemplateFile

Long ,如果不為零,則指定一個文件句柄。新文件將從這個文件中復制擴展屬性

返回值

如執行成功,則返回文件句柄。 INVALID_HANDLE_VALUE 表示出錯,會設置 GetLastError 。即使函數成功,但若文件存在,且指定了 CREATE_ALWAYS OPEN_ALWAYS , GetLastError 也會設為 ERROR_ALREADY_EXISTS

lpFileName
 Pointer to a null-terminated string that specifies the name of the object(file, pipe, mailslot,
 communications resource, disk device, console, or directory) to create or open.
 
指向一個空結尾字符串。該參數指定了用于創建或打開句柄的對象。

 if *lpFileName is a path, there is a default string size limit of MAX_PATH characters, This limit is
 related to how the CreateFile function parses paths.
 
如果 lpFileName 的對象是一個路徑,則有一個最大字符數的限制。不能超過常量 (MAX_PATH). 這個限制指示了
 CreateFile
函數如何解析路徑 .

dwDesiredAccess
 Specifies the type of access to the object. An application can obtain read access, write access,
 read-write access, or device query access, This parameter can be any combination of the following
 values
 
指定對象的訪問方式 , 程序可以獲得讀訪問權 , 寫訪問權 , 讀寫訪問權或者是詢問設備 ("device query") 訪問權 .
 
這個參數可以是下列值的任意組合
 
 Value(
)  Meaning( 含義 )
 0   Specifies device query access to the object. An application can query device
    attributes without accessing the device.
    
指定詢問訪問權 . 程序可以在不直接訪問設備的情況下查詢設備的屬性 .

 GENERIC_READ  Specifies read access to the object, Data can be read from the file and the
    file pointer can be moved. Combine with GENERIC_WRITE for read-write access.
    
指定讀訪問權 . 可以從文件中讀取數據 , 并且移動文件指針 . 可以和 GENERIC_WRITE 組合
    
成為 " 讀寫訪問權 ".

 GENERIC_WRITE  specifies write access to the object. Data can be written to the file and the
    file pointer can be moved. Combine with GENERIC_READ fro read-write access
    
指定寫訪問權 . 可以從文件中寫入數據 , 并且移動文件指針 . 可以和 GENERIC_READ 組合
    
成為 " 讀寫訪問權 ".

dwShareMode
 Set of bit flags that specifies how the object can be shared, If dwShareMode is 0, the object cannot
 be shared. Subsequent open operations on the object will fail, until the handle is closed.
 
設置位標志指明對象如休共享 . 如果參數是 0, 對象不能夠共享 . 后續的打開對象的操作將會失敗 , 直到該對象的句
 
柄關閉 .

 To share the object, use a combination of one or more of the following values:
 
使用一個或多個下列值的組合來共享一個對象 .
 Value(
)  Meaning( 含義 )
 FILE_SHARE_DELETE WindowsNT: Subsequent open operations on the object will succeed only if
    delete access is requested.
    WINDOWS NT:
后續的僅僅請求刪除訪問權的打開操作將會成功 .

 FILE_SHARE_READ  Subsequent open operations on the object will successd only if read access
    is requested.
    
后續的僅僅請求讀訪問權的打開操作將會成功 .

 FILE_SHARE_WRITE Subsequent open operations on the object will succeed only if write access
    is requested.
    
后續的僅僅請求寫訪問權的打開操作將會成功 .

lpSecurityAttributes
 pointer to a SECURITY_ATTRIBUTES structure that determines whether the returned handle can be
 inherited by child processes, if lpSecurityAttributes is NULL, the handle cannot be inherited.
 
指向一個 SECURITY_ATTRIBUTES 結構的指針用于確定如何在子進程中繼承這個句柄 . 如果這個參數是 NULL,
 
則該句柄不可繼承 .

dwCreationDisposition
 Specifies which action to take on files that exist, and which action to take when files do not exist.
 For more information about this parameter, see the remarks section. This parameter must be one of the
 following values
 
指定當文件存在或者不存在時如何動作。關于這個參數更多的信息,參考批注部分。這個參數必須是一個或多個
 
下列值。

 VALUE( )  Neaning( 含義 )
 CREATE_NEW  Creates a new file. The function fails if the specified file already exists
    
創建一個新文件 . 如果該文件已經存在函數則會失敗 .
 
 CREATE_ALWAYS  Creates a new file. If the file exsts, the function overwrites the file and
    clears the existing attributes.
    
創建一個新文件 . 如果該文件已經存在 , 函數將覆蓋已存在的文件并清除已存在的文件屬性

 OPEN_EXISTING  Opens the file. The function fails if the file does not exist.
    See the Remarks section for a discussion of why you should use the
    OPEN_EXISTING flag if you are using the CreateFile function for devices,
    including the console.
    
打開一個文件 , 如果文件不存在函數將會失敗 .
    
如查你使用 CreateFile 函數為設備裝載控制臺 . 請查看批注中的 " 為什么使用
    OPEN_EXISTING
標志 " 的部分 .
    
 OPEN_ALWAYS  Opens the file, if it exsts. If the file does not exist, the function creates
    the file as if dwCreationDisposition were CREATE_NEW.
    
如果文件存在 , 打開文件 . 如果文件不存在 , 并且參數中有 CREATE_NEW 標志 , 則創建文件 .

 TRUNCATE_EXISTING Opens the file. Once opened, the file is truncated so that its size is zero
    bytes The calling process must open the file with at least GENERIC_WRITE access.
    The function fails if the file does not exist.
    
打開一個文件 , 每次打開 , 文件將被截至 0 字節 . 調用進程必須用 GENERIC_WRITE 訪問模式打
    
開文件 . 如果文件不存在則函數就會失敗 .

dwFlagsAndatributes
 Specifies the file attributes and flags for the file.
 
為文件指定屬性和標志位

 Any combination of the following attributes is acceptable for the dwFlagsAndAttributes parameter,
 except all other file attributes override FILE_ATTRIBUTE_NORMAL.
 
該參數可以接收下列屬性的任意組合 . 除非其它所有的文件屬性忽略 FILE_ATTRIBUTE_NORMAL.
 Attribute(
屬性 )   Meaning( 標志 )
 FILE_ATTRIBUTE_ARCHIVE  The ifle should be archived. Application use this attribute to mark
     files for backup or removal.
     
文件將被存檔 , 程序使用此屬性來標志文件去備份或移除

 FILE_ATTRIBUTE_HIDDEN  The file is hidden. It is not to be included in an ordinary directory
     listing.
     
文件被隱藏 , 它不會在一般文件夾列表中被裝載 .

 FILE_ATTRIBUTE_NORMAL  The file has no other attributes set. This attribute is valid only if
     used alone
     
文件沒有被設置任何屬性 .


 FILE_ATTRIBUTE_OFFLINE  The data of the file is not immediately available. Indicates that the
     file data has been physically moved to offline storage.
     
文件的數據沒有被立即用到。指出正在脫機使用該文件。

 FILE_ATTRIBUTE_READONLY  The file is read only.Applications can read the file but cannot write
     to it or delete it
     
這個文件只可讀取 . 程序可以讀文件 , 但不可以在上面寫入內容 , 也不可刪除 .

 FILE_ATTRIBUTE_SYSTEM  The file is part of or is used exclusively by the operation system.
     
文件是系統的一部分 , 或是系統專用的 .

 FILE_ATTRIBUTE_TEMPORARY The file is being used for temporary storage. File systems attempt
     to keep all of the data in memory for quicker access rather than
     flushing the data back to mass storage. A temporary file should be
     deleted by the application as soon as it is no longer needed.
     
文件被使用后,文件系統將努力為(文件的)所有數據的迅迅訪問保持一塊
     
內存。臨時文件應當在程序不用時及時刪除。

 Any combination of the following flags is acceptable for the dwFlagsAndAttributes parameter.
 dwFlagAndAttributes
可以接受下列標志的任意組合。

 FLAG (標志)    Meaning( 含義 )
 FILE_FLAG_WRITE_THROUGH  Instructs the system to write through any intermediate cache and go
     directly to disk. The system can still cache write operations, but
     cannot lazily flush them.
     
指示系統通過快速緩存直接寫入磁盤,

 FILE_FLAG_OVERLAPPED  Instructs the system to initialize the object, so that operations that
     take a significant amount of time to process return ERROR_IO_PENDING.
     When the operation is finished, the specified event is set to the
     signaled state.
     
指示系統初始化對象 , 此操作將對進程設置一個引用計數并返回 ERROR_IO_PENDING.
     
處理完成后 , 指定對象將被設置為信號狀態 .

     When you specify FILE_FLAG_OVERLAPPED, the file read and write functions
     must specify an OVERLAPPED structure. That is, when FILE_FLAG_OVERLAPPED
     is specified, an application must perform overlapped parameter(pointing
     to an OVERLAPPED structure)to the file read and write functions.
     This flag also enables more than one operation to be performed
     simultaneously with the handle(a simultaneous read and write operation,
     for example).
     
當你指定 FILE_FLAG_OVERLAPPED , 讀寫文件的函數必須指定一個 OVERLAPPED 結構 .
     
并且 . FILE_FLAG_OVERLAPPED 被指定 , 程序必須執行重疊參數 ( 指向 OVERLAPPED
     
結構 ) 去進行文件的讀寫 .
     
這個標志也可以有超過一個操作去執行 .

 FILE_FLAG_NO_BUFFERING  Instructs the system to open the file with no intermediate buffering or
     caching.When combined with FILE_FLAG_OVERLAPPED, the flag gives maximum
     asynchronous performance, because the I/O does not rely on the synchronous
     operations of the memory manager. However, some I/O operations will take
     longer, because data is not being held in the cache.
     
指示系統不使用快速緩沖區或緩存,當和 FILE_FLAG_OVERLAPPED 組合 , 該標志給出最
     
大的異步操作量 , 因為 I/O 不依賴內存管理器的異步操作 . 然而 , 一些 I/O 操作將會運行
     
得長一些 , 因為數據沒有控制在緩存中 .

     An application must meet certain requirements when working with files
     opened with FILE_FLAG_NO_BUFFERING:
     
當使用 FILE_FLAG_NO_BUFFERING 打開文件進行工作時 , 程序必須達到下列要求 :
     
      File access must begin at byte offsets within the file that are
      integer multiples of the volume's sector size.
      
文件的存取開頭的字節偏移量必須是扇區尺寸的整倍數 .
      
      File access must be for numbers of bytes that are integer
      multiples of the volume's sector size. For example, if the sector
      size is 512 bytes, an application can request reads and writes of
      512, 1024, or 2048 bytes, but not of 335, 981, or 7171bytes.
      
文件存取的字節數必須是扇區尺寸的整倍數 . 例如 , 如果扇區尺寸是 512 字節
      
程序就可以讀或者寫 512,1024 或者 2048 字節 , 但不能夠是 335,981 或者 7171
      
字節 .

      buffer addresses for read and write operations must be sector
      aligned(aligned on addresses in memory that are integer multiples
      of the volume's sector size).
      
進行讀和寫操作的地址必須在扇區的對齊位置 , 在內存中對齊的地址是扇區
      
尺寸的整倍數 .

     One way to align buffers on integer multiples of the volume sector size is
     to use VirtualAlloc to allocate the buffers, It allocates memory that is
     aligned on addresses that are integer multiples of the operating system's
     memory page size. Because both memory page and volume sector sizes are
     powers of 2, this memory is also aligned on addresses that are integer
     multiples of a volume's sector size.
     
一個將緩沖區與扇區尺寸對齊的途徑是使用 VirtualAlloc 函數 . 它分配與操作系統
     
內存頁大小的整倍數對齊的內存地址 . 因為內存頁尺寸和扇區尺寸 --2 都是它們的冪 .
     
這塊內存在地址中同樣與扇區尺寸大小的整倍數對齊 .

     An application can determine a volume's sector size by calling the
     GetDiskFreeSpace function
     
程序可以通過調用 GetDiskFreeSpace 來確定扇區的尺寸 .

 FILE_FLAG_RANDOM_ACCESS
     Indicates that the file is accessed randomly. The system can use this as
     a hint to optimize file caching.
     
指定文件是隨機訪問 , 這個標志可以使系統優化文件的緩沖 .


 FILE_FLAG_SEQUENTIAL_SCAN 
     Indicates that the file is to be accessed sequentially from beginning to
     end. The system can use this as a hint to optimize file caching. If an
     application moves the file pointer for random access, optimum caching may
     not occur; however, correct operation is still guaranteed.
     
指定文件將從頭到尾連續地訪問 . 這個標志可以提示系統優化文件緩沖 . 如果程序在
     
隨機訪問文件中移動文件指針 , 優化可能不會發生 ; 然而 , 正確的操作仍然可以得到保
     

     
     Specifying this flag can increase performance for applications that read
     large files using sequential access, performance gains can be even more
     noticeable for applications that read large files mostly sequentially,
     but occasionally skip over small ranges of bytes.
     
指定這個標志可以提高程序以順序訪問模式讀取大文件的性能 , 性能的提高在許多
     
程序讀取一些大的順序文件時是異常明顯的 . 但是可能會有小范圍的字節遺漏 .


 FILE_FLAG_DELETE_ON_CLOSE Indicates that the operating system is to delete the file immediately
     after all of its handles have been closed, not just the handle for which
     you specified FILE_FLAG_DELETE_ON_CLOSE.
     
指示系統在文件所有打開的句柄關閉后立即刪除文件 . 不只有你可以指定 FILE_FLAG_DELETE_ON_CLOSE
     
     Subsequent open requests for the file will fail, unless FILE_SHARE_DELETE
     is used.
     
如果沒有使用 FILE_SHARE_DELETE, 后續的打開文件的請求將會失敗 .

 FILE_FLAG_BACKUP_SEMANTICS  WINDOWS NT:Indicates that the file is being opened or created for a backup
     or restore operation.The system ensures that the calling process overrides
     file security checks, provided it has the necessary privileges. The
     relevant privileges are SE_BACKUP_NAME and SE_RESTORE_NAME.
     WINDOWS NT:
指示系統為文件的打開或創建執行一個備份或恢復操作 . 系統保證調
     
用進程忽略文件的安全選項 , 倘若它必須有一個特權 . 則相關的特權則是 SE_BACKUP_NAME
     
SE_RESTORE_NAME.

     You can also set this flag to obtain a handle to a directory. A directory
     handle can be passed to some Win32 functions in place of a file handle.
     
你也可以使用這個標志獲得一個文件夾的句柄,一個文件夾句柄能夠象一個文件句柄
     
一樣傳給某些 Win32 函數。

 FILE_FLAG_POSIX_SEMANTICS Indicates that the file is to be accessed according to POSIX rules. This
     includes allowing multiple files with names, differing only in case, for file
     systems that support such naming. Use care when using this option because
     files created with this flag may not be accessible by applications written
     for MS-DOS or 16-bit Windows.
     
指明文件符合 POSIX 標準 . 這是在 MS-DOS 16 Windows 下的標準 .

 FILE_FLAG_OPEN_REPARSE_POINT Specifying this flag inhibits the reparse behavior of NTFS reparse points.
     When the file is opened, a file handle is returned, whether the filter that
     controls the reparse point is operational or not. This flag cannot be used
     with the CREATE_ALWAYS flag.
     
指定這個標志制約 NTFS 分區指針 . 該標志不能夠和 CREAT_ALWAYS 一起使用 .

 FILE_FLAG_OPEN_NO_RECALL Indicates that the file data is requested,but it should continue to reside in
     remote storage. It should not be transported back to local storage. This flag
     is intended for use by remote storage systems or the Hierarchical Storage
     Management system.
     
指明需要文件數據 , 但是將繼續從遠程存儲器中接收 . 它不會將數據存放在本地存儲器中 .
     
這個標志由遠程存儲系統或等級存儲管理器系統使用 .

hTemplateFile
 Specifies a handle with GENERIC_READ access to a template file. The template file supplies file attributes and
 extended attributes for the file being created.
 
GENERIC_READ 訪問的模式指定一個句柄到模板文件 . 模板文件在文件開始創建后提供文件屬性和擴展屬性 .

Return Values
返回值

If the function succeeds, the return value is an open handle to the specified file. If the specified file exists before
the function call and dwCreation is CREATE_ALWAYS or OPEN_ALWAYS, a call to GetLastError returns ERROR_ALREADY_EXISTS
(even though the function has succeeded). If the file does not exist before the call, GetLastError returns zero.
如果函數成功 , 返回一個打開的指定文件的句柄 . 如果指定文件在函數調用前已經存在并且 dwCreation 參數是 CREATE_ALWAYS 或者
OPEN_ALWAYS,
調用 GetLastError 就會返回 ERROR_ALREADY_EXISTS( 表示函數成功 ). 如果函數文件在調用前不存在則會返回 0.

If the function fails, the return value is INVALID_HANDLE_VALUE.To get extended error information, call GetLastError.
如果函數失敗 , 返會值會是 INVALID_HANDLE_VALUE. 更多的錯誤信息可以調用 GetLastError 來獲得 .

posted on 2007-03-10 17:54 jay 閱讀(123633) 評論(12)  編輯 收藏 引用 所屬分類: 多線程

評論:
# re: CreateFile函數詳解 2008-04-08 11:38 | bay
Thanks a lot!  回復  更多評論
  
# re: CreateFile函數詳解 2008-10-19 16:17 | 好色仙人
感謝摟主 !!  回復  更多評論
  
# re: CreateFile函數詳解 2008-11-09 22:42 | qm
感謝^_~  回復  更多評論
  
# re: CreateFile函數詳解 2009-01-09 17:16 | 魏華
找到這么好的文章不容易,謝謝樓主
還有一事不明,想請教
我在createfile創建文件后用writefile向文件中寫入東東時,
這次的寫入將會覆蓋上次的東西
不向用fopen,,fread,fwrite好使,想在文件末尾追加寫入的話,是不是在createfile時就得設置這個屬性啊,
還是在writefile之前單獨設置哪?
指教  回復  更多評論
  
# re: CreateFile函數詳解[未登錄] 2009-02-24 15:40 | heidaizx
佩服博主的耐心  回復  更多評論
  
# re: CreateFile函數詳解 2009-03-28 00:43 | dospeng
萬分感謝博主,有些不明白為什么windows里面這么多的io函數,fopen open createfile。  回復  更多評論
  
# re: CreateFile函數詳解[未登錄] 2009-03-28 06:07 | snow
請問,在C語言中用CreateFile函數時,是不是要加預處理文件之類的?比如#include<....... .h>。
如果不需要加預處理文件,那怎樣能使編譯通過?(錯誤只出現在CreateFile及其周圍)  回復  更多評論
  
# re: CreateFile函數詳解 2009-06-22 16:58 | cxb
好人啦!  回復  更多評論
  
# re: CreateFile函數詳解 2011-03-05 15:09 | MOMO
@snow
只要包含windows.h,因為這個是windows函數  回復  更多評論
  
# re: CreateFile函數詳解[未登錄] 2011-10-01 19:47 | xxx
在writefile之前用setfilepointer將文件中的指針指向文件末尾。  回復  更多評論
  
# re: CreateFile函數詳解[未登錄] 2012-05-22 09:22 | ming
@dospeng
createfile 不禁禁是對文件的操作 還有對系統設備的IO的操作!  回復  更多評論
  
# re: CreateFile函數詳解 2013-07-28 08:55 | chamgin
好文章力頂啊  回復  更多評論
  

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美日韩第一区| 亚洲作爱视频| 亚洲毛片视频| 欧美三级资源在线| 亚洲欧美日韩国产中文| 久久九九国产精品怡红院| 一区二区三区在线视频播放| 欧美fxxxxxx另类| 一区二区久久久久| 欧美在线999| 最新国产成人在线观看| 欧美无砖砖区免费| 欧美专区一区二区三区| 欧美激情亚洲视频| 亚洲欧美日韩国产综合在线 | 一本一本久久| 久久久久久久精| 亚洲精品午夜| 国产视频久久| 欧美极品影院| 欧美在线观看网站| 亚洲精品一区二区在线| 久久久福利视频| 亚洲美女视频网| 国产亚洲成精品久久| 欧美sm视频| 欧美一区二区在线播放| 最新国产成人av网站网址麻豆| 宅男精品导航| 亚洲福利视频网站| 国产毛片精品视频| 欧美激情四色| 久久嫩草精品久久久久| 亚洲午夜久久久久久久久电影网| 美日韩精品视频| 欧美中文字幕在线视频| 亚洲午夜av在线| 亚洲精品孕妇| 在线精品一区| 国产精品一区二区在线观看网站| 欧美精品一区二区三区蜜桃| 久久精品一区二区| 亚洲欧美久久久久一区二区三区| 亚洲欧洲精品一区二区三区| 老司机免费视频一区二区三区 | 91久久精品国产91性色| 久久网站免费| 久久国产精品一区二区| 99成人精品| 亚洲日本欧美| 亚洲丰满少妇videoshd| 国产午夜精品理论片a级大结局 | 欧美国产免费| 久久一区二区三区av| 香蕉免费一区二区三区在线观看 | 欧美噜噜久久久xxx| 麻豆国产精品777777在线| 欧美专区在线播放| 性欧美激情精品| 亚洲综合国产精品| 亚洲一区二区三区欧美| 一区二区国产在线观看| 亚洲最新色图| 亚洲午夜激情| 亚洲一区在线观看视频 | 国内精品伊人久久久久av一坑| 国产精品成人一区二区艾草| 欧美日韩在线免费视频| 欧美精品亚洲一区二区在线播放| 欧美国产先锋| 欧美电影在线观看完整版| 欧美成人中文字幕在线| 欧美精品二区三区四区免费看视频| 欧美1区2区视频| 欧美激情一区三区| 欧美日韩视频在线一区二区| 欧美三日本三级少妇三99| 欧美日韩精品一区二区在线播放 | 99国产精品视频免费观看一公开| 亚洲精品久久久蜜桃| 日韩五码在线| 亚洲一区在线免费| 欧美一区二区三区在线视频| 久久久国产精品一区二区中文| 久久久免费av| 欧美激情视频在线播放 | 亚洲欧美日产图| 久久av二区| 蜜乳av另类精品一区二区| 欧美人与性禽动交情品| 国产精品视频专区| 极品少妇一区二区三区精品视频| 亚洲国产欧美在线人成| 中文在线资源观看网站视频免费不卡 | 久久av一区二区| 麻豆成人av| 欧美三级午夜理伦三级中视频| 国产精品久久久对白| 国产性做久久久久久| 亚洲激情中文1区| 中文精品视频| 美女被久久久| 亚洲理论在线| 久久成人资源| 欧美日韩激情小视频| 国产亚洲精品综合一区91| 91久久久亚洲精品| 欧美一区二区三区视频免费播放| 欧美www在线| 一本久道久久久| 久久激情五月婷婷| 欧美日韩精品国产| 很黄很黄激情成人| 在线一区二区三区四区五区| 久久精品一二三| 亚洲精品欧洲| 久久精品一级爱片| 国产精品美女一区二区| 亚洲国产欧美日韩精品| 欧美一区二区久久久| 亚洲啪啪91| 久久久久久久一区| 国产精品每日更新| 日韩亚洲国产欧美| 美国十次了思思久久精品导航| 亚洲网站视频| 欧美精品亚洲二区| 亚洲高清免费| 久久亚洲免费| 亚洲女ⅴideoshd黑人| 欧美片第一页| 亚洲国产一区二区三区青草影视| 欧美一级在线亚洲天堂| 亚洲精品四区| 欧美va天堂在线| 一区二区三区在线观看欧美| 欧美一区二区三区在线视频| 亚洲美女av黄| 欧美成人一区二免费视频软件| 激情婷婷久久| 久久久久**毛片大全| 亚洲香蕉网站| 国产精品草莓在线免费观看| 亚洲毛片av| 亚洲人成绝费网站色www| 久久久久久尹人网香蕉| 国产在线麻豆精品观看| 欧美一区二区黄| 亚洲天堂网在线观看| 国产精品草草| 亚洲免费在线电影| 亚洲免费精彩视频| 欧美高清视频www夜色资源网| 亚洲电影免费观看高清完整版在线观看| 欧美一区二区三区在线观看视频 | 久久国产欧美| 国产一区二区三区日韩欧美| 久久精品国产第一区二区三区最新章节 | 国产日韩欧美日韩大片| 性伦欧美刺激片在线观看| 亚洲视频欧洲视频| 国产精品久线观看视频| 欧美一级成年大片在线观看| 亚洲一区欧美激情| 国产乱码精品一区二区三区av | 麻豆精品在线播放| 最近中文字幕日韩精品| 91久久精品国产91性色| 欧美另类一区| 亚洲一区二区三区激情| 亚洲一区欧美二区| 国产午夜精品一区二区三区欧美| 欧美在线免费看| 久久精品欧洲| 亚洲欧洲中文日韩久久av乱码| 亚洲青色在线| 国产精品久久久久秋霞鲁丝| 午夜欧美精品| 久久福利电影| 亚洲福利视频专区| 亚洲精品网址在线观看| 国产精品久久久久毛片软件| 久久成人久久爱| 麻豆成人91精品二区三区| 99精品国产在热久久婷婷| 在线视频欧美精品| 激情婷婷久久| 亚洲精品美女久久久久| 国产欧美日韩精品在线| 欧美成人a∨高清免费观看| 欧美伦理91i| 欧美一区国产在线| 久热这里只精品99re8久| 一区二区三区.www| 性做久久久久久久免费看| 亚洲激情专区| 亚洲欧美中日韩| 亚洲欧洲精品一区二区精品久久久 | 国产免费成人在线视频| 欧美成ee人免费视频|