日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java - IO流学习笔记

發布時間:2024/3/13 java 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java - IO流学习笔记 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1、文件和文件夾

內存中存放的數據信息在計算機關機后就會消失,如果想要長久的保存數據,就需要使用到光盤、硬盤等設備,為了便于數據的管理以及檢索,引入了“文件”的概念。一篇文章,一個圖片,一個視頻、一個可執行的程序等等,都可以被保存成一個文件。

從文件的功能上,可以吧文件分成 文本文件,視頻文件,音頻文件,可執行文件,圖像文件等等類別,但是從數據存儲的角度看,所有的文件本質上都是一樣的,都是由一個個字節組成,歸根到底都是由0/1組成的,只不過呈現出了不同的狀態。

大量的文件如果不進行分類,那么使用起來會十分不方便,因此,可以用文件夾對文件進行管理。

2、Java對 File 對象的一些操作

package IO;import java.io.File; import java.io.IOException;public class TestFile {public static void main(String[] args) throws IOException {// win下是\ ,Linux 下為/File file = new File("e:\\test.txt");// File.separator 可以獲取當前操作系統路徑的拼接符號File file1 = new File("e:" + File.separator + "test.txt");file.canRead(); // 文件是否可讀file.canWrite(); // 文件是否可寫file.getName(); // 獲取文件名稱file.getParent(); // 獲取上級目錄file.isDirectory(); // 是否是目錄file.isFile();// 是否是文件file.isHidden();// 文件是否隱藏file.length();// 文件的大小file.exists(); // 文件是否存在System.out.println(file == file1); // falseSystem.out.println(file.equals(file1)); // true , 比較的是兩個對象的文件路徑System.out.println(file.exists());// if (file.exists()) {// file.delete(); //文件存在就刪除// } else {// file.createNewFile(); // 文件不存在就創建// }file.toString(); // 和相對路徑一樣System.out.println(file.getPath());// 相對路徑:相對位置System.out.println(file.getAbsolutePath());// 絕對路徑:真實的準確的完整的路徑// 文件夾相關的,上述有關文件的方法都可以對文件夾進行操作File file2 = new File("e:\\kaoshi\\kexin");//file2.mkdir(); // 幫你在創建文件夾,單層目錄file2.mkdirs(); // 創建多層目錄file2.delete(); // 刪除只能刪除最內層的目錄,并且前提是這個內層目錄是空的,如果不為空則不會刪除String[] list = file2.list(); // 當前目錄下,目錄或者文件名稱的數組File[] files = file2.listFiles(); // 當前目錄下,files 對象的數組} }

上面File 類的學習,可以發現File對象只能獲取到一些比較表層的數據,比如路徑,文件名,但是并沒有獲取到文件內的信息。如何獲得文件的內容信息呢,IO流可以幫我們實現這一需求。

3、I/O 流的概念

簡單來說I/O 流 可以當做是一根管子,是程序和數據源之間溝通的橋梁,所有的數據被串行化(串行化就是數據按照順序進行輸入輸出)的被輸入和輸出。站在程序的角度,往里面讀就是輸入input,往外面寫就是輸出output。

四個抽象類型的基類

?處理數據的單位

處理數據的方向

字節流字符流
輸入流InputStreamReader
輸出流OutputStreamWriter

4、FileReader 和 FileWriter 操作文本文件。

FileReader的使用

public class TestFileReader {public static void main(String[] args) throws IOException {//程序從文件中讀取內容,一個字符一個字符的// 有一個文件-----》創建一個File對象File file = new File("e:\\test\\test.txt");// 利用 FileReader 這個流,將“管子” 懟到源文件上去FileReader fileReader = new FileReader(file);// 利用管子,進行讀取的動作int n = fileReader.read(); //每次只能讀一個字符,如果到了文件的末尾,返回的值是-1;while (n != -1) {System.out.print((char) n); // 讀取的是Unicode碼,可以轉換為字符輸出n = fileReader.read();}System.out.println();//管子不用了,就把管子關閉; ----->手動關閉流fileReader.close();//程序從文件中讀取內容,多個字符多字符的// 有一個文件-----》創建一個File對象File file1 = new File("e:\\test\\test.txt");// 利用 FileReader 這個流,將“管子” 懟到源文件上去FileReader fileReader1 = new FileReader(file);// 利用管子,進行讀取的動作char[] chars = new char[5]; // 一次性讀取五個字符int read = fileReader1.read(chars); // 返回值是char數組的長度while (read >= chars.length) {System.out.print(chars);read = fileReader1.read(chars);}//管子不用了,就把管子關閉; ----->手動關閉流fileReader.close();} }

FileWriter的使用

public class TestFileWriter {public static void main(String[] args) throws IOException {// 創建一個文件對象File file = new File("e:\\test\\test.txt");// 創建FileWriter對象,將管子懟到文件上去// 沒有文件會自動創建一個文件,如果有文件則會覆蓋文件,append如果設置為true,則不會覆蓋文件,而是在之前的文件后面進行追加。FileWriter fileWriter = new FileWriter(file, true);// 開始往外寫文件String str = "創建FileWriter對象,開始往外寫文件";// 一個字符一個字符的寫for (int i = 0; i < str.length(); i++) {fileWriter.write(str.charAt(i));}// // 直接往外寫// char[] chars = str.toCharArray();// fileWriter.write(chars);// 關閉流fileWriter.close();} }

使用FileReader 和 FileWriter完成文件的復制。

public class TestFileReaderWriter {public static void main(String[] args) throws IOException {// 源文件File infile = new File("e:\\test\\test.txt");// 目標文件File outFile = new File("e:\\test\\test1.txt");// 輸入的管子FileReader fileReader = new FileReader(infile);// 輸出的管子FileWriter fileWriter = new FileWriter(outFile);// 一遍讀入源文件 一遍將讀到的文件寫出去// 方式1// int n = fileReader.read();// while (n != -1) {// fileWriter.write(n);// n = fileReader.read();// }// 方式2char[] chars = new char[5];int length = fileReader.read(chars);while (length != -1) {fileWriter.write(chars);length = fileReader.read(chars);}// 關閉流 后用的先關閉fileWriter.close();fileReader.close();} }

5、不能用字符流去操作非文本文件,否則得到的文件會不可用。

文本文件:.txt? .java .c .cpp 等,建議使用字符流去操作

非文件文件:.jpg .mp3等,建議使用字節流去操作。

6、FileInputStream 和 FileOutputStream 的使用

  • 假設文件是UTF-8存儲的,那么英文占一個字節,中文占三個字節 --->因此文本文件就不建議用字節流讀取
  • 如果一個字節一個字節的讀,那么 read方法底層做了處理,讓返回的數都是“正數”,為了避免返回-1的話,不知道是讀入的字節,還是文件的結尾。
  • 如果用緩沖數組byte[]去讀,那么read的時候,字節就可以為負值,-128~127,因為判斷文件末尾用的是 “read的返回值是byte數組的有效長度=-1”,和字節本身不會沖突
  • 如果用緩沖數組取寫,wirte的時候要注意長度,否則復制得到的文件會比源文件大(最后一個數組里面有些是無效內容)?fileOutputStream.write(byte,0,length); 寫入數組的第0位到底length位
public class TestFileInputOutputStream {public static void main(String[] args) throws IOException {//程序從文件中讀取內容,一個字符一個字符的// 有一個文件-----》創建File對象File file = new File("e:\\test\\圖片.gif");File file2 = new File("e:\\test\\圖片2.gif");// 利用 FileInputStream FileOutputStream 這個流,將“管子” 把程序和源文件連接FileInputStream fileInputStream = new FileInputStream(file);FileOutputStream fileOutputStream = new FileOutputStream(file2);// 利用管子,進行讀取和寫出的動作// 假設文件是UTF-8存儲的,那么英文占一個字節,中文占三個字節 --->因此文本文件就不建議用字節流讀取int read = fileInputStream.read(); //每次只能讀一個字符,如果到了文件的末尾,返回的值是-1;while (read != -1) { // read方法底層做了處理,讓返回的數都是“正數”,為了避免返回-1的話,不知道是讀入的字節,還是文件的結尾。fileOutputStream.write(read); // 邊讀邊寫read = fileInputStream.read();}System.out.println();//管子不用了,就把管子關閉; ----->手動關閉流fileOutputStream.close();fileInputStream.close();} }

7、緩沖字節流(處理流) BufferedInputStream/BufferedOutputStream 的使用

  • 利用緩沖字節數組可以減少訪問硬盤的次數,提升效率,但是訪問次數還是較多,能不能進一步減少訪問硬盤次數呢?我們可以引入一個新的流 “緩沖字節流(處理流)”
  • 其實BufferedInputStream/BufferedOutputStream底層也是通過新建緩沖數組進行數據操作的,size值為8192
  • 如果數據流存在著嵌套,那么其實只要關閉高級流,那么里面的字節流也會隨之關閉。

例如BufferedOutputStream 的源碼:(BufferedInputStream類似)

public BufferedOutputStream(OutputStream out) {this(out, 8192);}public BufferedOutputStream(OutputStream out, int size) {super(out);if (size <= 0) {throw new IllegalArgumentException("Buffer size <= 0");}buf = new byte[size];} public class TestBuffer {public static void main(String[] args) throws IOException {//程序從文件中讀取內容,一個字符一個字符的// 有一個文件-----》創建File對象File file = new File("e:\\test\\圖片.gif");File file2 = new File("e:\\test\\圖片2.gif");// 利用 FileInputStream FileOutputStream 這個流,將“管子” 把程序和源文件連接FileInputStream fileInputStream = new FileInputStream(file);FileOutputStream fileOutputStream = new FileOutputStream(file2);// 功能加強,引入新的流BufferedInputStream bufferedInputStream = new BufferedInputStream(fileInputStream);BufferedOutputStream bufferedOutputStream = new BufferedOutputStream(fileOutputStream);// 開始動作 其實BufferedInputStream/BufferedOutputStream底層也是通過新建緩沖區數據操作的,size值為8192byte[] bytes = new byte[1026 * 8];int len = bufferedInputStream.read(bytes);while (len != -1) {bufferedOutputStream.write(bytes, 0, len);// bufferedOutputStream.flush();底層已經幫忙做了刷新緩沖區的操作,不需要手動完成刷新len = bufferedInputStream.read(bytes);}// 關閉流 ,倒著關閉// 如果數據流存在著嵌套,那么其實只要關閉高級流,那么里面的字節流也會隨之關閉。bufferedOutputStream.close();bufferedInputStream.close();// fileOutputStream.close(); 可以不寫// fileInputStream.close(); 可以不寫} }

8、緩沖字符流(處理流) BufferedReader/BufferedWriter 的使用

public class TestBuffer02 {public static void main(String[] args) throws IOException {//程序從文件中讀取內容,一個字符一個字符的// 有一個文件-----》創建File對象File file = new File("e:\\test\\test.txt");File file2 = new File("e:\\test\\test1.txt");// 利用 FileInputStream FileOutputStream 這個流,將“管子” 把程序和源文件連接FileReader fileReader = new FileReader(file);FileWriter fileWriter = new FileWriter(file2);// 功能加強,引入新的流BufferedReader bufferedReader = new BufferedReader(fileReader);BufferedWriter bufferedWriter = new BufferedWriter(fileWriter);// 開始動作 其實BufferedInputStream/BufferedOutputStream底層也是通過新建緩沖區數據操作的,size值為8192// char[] chars = new char[1024];// int len = bufferedReader.read(chars);// while (len != -1) {// bufferedWriter.write(chars, 0, len);// len = bufferedReader.read(chars);// }// 新的方式String str = bufferedReader.readLine(); // 每次讀取文本文件中的一行while (str != null) {bufferedWriter.write(str);bufferedWriter.newLine(); // 注意寫入時,每行之間要新加一行,否則復制的文件中沒有換行。str = bufferedReader.readLine();}// 關閉流 ,倒著關閉// 如果數據流存在著嵌套,那么其實只要關閉高級流,那么里面的字節流也會隨之關閉。bufferedWriter.close();bufferedReader.close();// FileWriter.close(); 可以不寫// FileReader.close(); 可以不寫} }

9、轉換流(將字節流和字符流進行轉換)InputStreamReader / OutputStreamWriter的使用。

看后綴,這兩個轉換流屬于字符流。

  • InputStreamReader:字節輸入流轉換為字符輸入流,完成文件到程序
  • OutputStreamWriter:字符輸出流轉換為字節輸出流,完成程序到文件
public class Test_InputStreamReader_OutputStreamWriter {public static void main(String[] args) throws IOException {// 源文件 和目標文件File file = new File("e:\\test\\test.txt");File file1 = new File("e:\\test\\test1.txt");// 輸入方向,創建一個字節流接觸文件,創建轉換流,負責將字節流轉換為字符流(相當于一個處理流)// 創建轉換流,負責將字節流轉換為字符流(相當于一個處理流)// 編碼格式要保持統一,否則會出現亂碼; 如果不手動寫編碼格式,會自動獲取編譯器的編碼格式FileInputStream fileInputStream = new FileInputStream(file);InputStreamReader inputStreamReader = new InputStreamReader(fileInputStream, "utf-8");// 輸出方向FileOutputStream fileOutputStream = new FileOutputStream(file1);OutputStreamWriter outputStreamWriter = new OutputStreamWriter(fileOutputStream, "utf-8");// 開始動作char[] chars = new char[20];int len = inputStreamReader.read(chars);while (len != -1) {outputStreamWriter.write(chars);len = inputStreamReader.read(chars);}// 關閉流outputStreamWriter.close();inputStreamReader.close();} }

10、System類對IO屬性的支持

  • System.in:從鍵盤輸入
  • System.out:輸出到控制臺

11、數據流DataInputStream / DataOutputStream

將文件中存儲的基本數據類型和字符串寫入到內存的變量中,但是讀的過程中,要注意變量的類型要和寫入變量的類型要一一對應,否則會讀出錯。

12、對象流 ObjectInputStream 和 ObjectOutputStream

用于存儲和讀取基本數據類型或者對象的處理流,他的強大之處就是可以把Java中的對象寫入到數據源中,也能把對象從數據源中還原回來。

ObjectOutputStream : 將一個對象轉化為字節寫到一個文件中去,以此來實現對象的持久化保存,這個過程被稱為序列化

ObjectInputStream :?從文件中讀取被序列化的對象, 稱作反序列化。

序列化的可以參考以下鏈接

Java 反射reflect 序列化_材料小菜鳥的博客-CSDN博客

13、什么是同步,什么是異步?

同步:如果有多個任務或者事件要發生,這些任務或者事件必須逐個進行,一個事件任務的執行會導致整個流程的暫時等待,其他事件沒有辦法并發的執行下去;

異步:如果有多個任務或者事件要發生,那么這些事件可以并發的執行

例子:一個任務包括兩個子任務A和B,同步時,A執行過程中B只能等待,直到A執行完畢后,B才能繼續執行;異步時,AB可以并發的執行,B不用等待A執行結束。

14、什么是阻塞,什么是非阻塞?

阻塞:某個事件或者任務執行過程中,發出一個請求,但是由于該請求操作需要的條件不滿足而無法繼續執行時,他就一直在那等待,直到條件滿足后繼續執行;

非阻塞:某個事件或者任務執行過程中,發出一個請求,如果該請求操作需要的條件不滿足,會立即返回一個標志信息告知條件不滿足,不會一直等待。

舉個簡單的例子:

假如我要讀取一個文件中的內容,如果此時文件中沒有內容可讀,對于同步來說就是會一直在那等待,直至文件中有內容可讀;而對于非阻塞來說,就會直接返回一個標志信息告知文件中暫時無內容可讀。

阻塞和非阻塞著重點在于發出一個請求操作時,如果進行操作的條件不滿足是否會返會一個標志信息告知條件不滿足。理解阻塞和非阻塞可以同線程阻塞類比地理解,當一個線程進行一個請求操作時,如果條件不滿足,則會被阻塞,即在那等待條件滿足。

有關BIO/NIO/AIO的知識,后續學習完網絡相關的在來補充。

15、BIO(Bolcking IO)

同步阻塞IO,jdk1.4之前只有這一種IO模型,指的是調用發起后,會阻塞線程,直到獲得結果,服務端一個線程只能同時處理一個客戶端的請求。

問題:服務端在等待接收客戶端請求時阻塞,等待客戶端的連接,有多個客戶端連接時,由于client1先和服務端進行了連接,此時服務端只能處理client1 的請求,什么時候client1處理完,什么時候才可以處理其他的請求,此時client2發送請求,服務端是沒辦法處理的

TCP/IP底層使用的是BIO,同步阻塞IO,發起請求后,必須等待接收到響應后,代碼才能繼續向下執行,服務端一個線程只能處理一個客戶端的請求

解決方案:服務端為每個客戶端創建一個線程,但是如果客戶端特別多,服務器就需要創建對應數量的子線程,由于每個子線程都有自己的獨立線程區,子線程創建多了就會產生內存不足等問題,而且子線程也需要調度,切換和銷毀也都是非常消耗性能的。使用線程池可以一定程度上提升線程創建和銷毀的性能,但是調度和切換帶來的性能下降還是無法解決。

16、NIO?

new IO 或者 Non-Blocking IO,NIO的特性就是同步非阻塞IO;

調用發起后,等待獲得結果,但是不會阻塞線程,NIO中服務端的一個線程可以處理多個客戶端。

NIO解決了使用BIO服務端創建過多的子線程產生內存消耗、子線程調度切換銷毀等帶來的性能消耗問題。

NIO支持面向緩沖的,基于通道的I/O操作方法。 NIO提供了與傳統BIO模型中的?Socket?和?ServerSocket?相對應的?SocketChannel?和?ServerSocketChannel?兩種不同的套接字通道實現,兩種通道都支持阻塞和非阻塞兩種模式。阻塞模式使用就像傳統中的支持一樣,比較簡單,但是性能和可靠性都不好;非阻塞模式正好與之相反。對于低負載、低并發的應用程序,可以使用同步阻塞I/O來提升開發速率和更好的維護性;對于高負載、高并發的(網絡)應用,應使用 NIO 的非阻塞模式來開發。

17、Buffer緩沖區

Buffer緩沖區,緩沖區中緩存的是流數據,BIO直接操作流數據,NIO模型變為操作緩存區數據通過channel管道進行傳輸。

Buffer緩沖區是一個對象,他包含一些要寫入或者剛讀出的數據,緩沖區實質上是一個數組 ,NIO所有的數據都是用緩沖區處理,寫入數據時,首先寫到緩沖區中,讀數據也是從緩沖區中去讀。

Buffer的主要實現類

ByteBuffer
CharBuffer
ShortBuffer
IntBuffer
LongBuffer
FloatBuffer
DoubleBuffer

在NIO中,Buffer類是抽象類,是所有緩存的父類,提供了除boolean外基本數據類型的緩存類,但是我們一般只使用ByteBuffer,因為TCP協議是基于字節的,所以緩存區也使用的是Byte類型的緩存區

18、channel 通道

通道是對原IO包中流的一個模擬,源與目標的連接是借助一個Channel對象(通道)實現的,channel 不能直接訪問數據,需要和緩沖區進行交互 。

舉個栗子:

A和B兩個地區之間可以進行鐵路運輸,他們分別在火車站旁邊有個倉庫AB;這里的鐵路就是管道channel,而AB兩個倉庫就是緩沖區Buffer,倉庫用于臨時存儲運來的貨物,即緩沖區用于臨時存儲傳輸來的數據。

Channel的主要實現類

1 、FileChannel:用于讀取、寫入、映射和操作文件的通道。

2、 DatagramChannel:通過UDP讀寫網絡中的數據通道。

3 、SocketChannel:通過tcp讀寫網絡中的數據。

4 、ServerSocketChannel:可以監聽新進來的tcp連接,對每一個連接都創建一個SocketChannel。
其中FileChannel沒有繼承SelectableChannel, 因此不支持非阻塞操作;其他的類都支持非阻塞操作。

獲取通道的方式

1、通過getChannel()方法獲取

前提是該類支持該方法。支持該類的方法有:

FileInputStream/FileOutputStream,RandomAccessFile,Socket,ServerSocket ,DatagramSocket

2、通過靜態方法open()

3、通過jdk1.7中Files的newByteChannel()方法

NIO的底層工作原理

首先Buffer的工作機制

1、buffer數組的幾個屬性設置

public abstract class Buffer {private int mark = -1; // 用于記錄當前 position 的前一個位置或者默認是 -1private int position = 0; // 下一個要操作的數據元素的位置private int limit; // 緩沖區數組中不可操作的下一個元素的位置 limit <=capacityprivate int capacity; // 緩沖區數組的長度 }

2、初始化時,默認狀態為:

3、開始往數組中寫入字節的時候,變為下圖,position會移動到數據結束的下一個位置

?4、調用buffer.flip() 方法,byte數組中的內容不變,position賦值給limit,position重置為0; 適合讀之前的操作

public final Buffer flip() {limit = position;position = 0;mark = -1;return this;}

?5、調用buffer.clear() 方法,byte數組中的內容不變,position重置為0,capacity賦值給limit,適合寫之前的操作

public final Buffer clear() {position = 0;limit = capacity;mark = -1;return this;}

6、mark()方法回將position的值賦給mark,reset() 方法是講mark的值附回給position,這里是jdk1.8中的源碼和網上的博客大多不一樣。

public final Buffer mark() {mark = position;return this;}public final Buffer reset() {int m = mark;if (m < 0)throw new InvalidMarkException();position = m;return this;}

代碼樣例:

public class TestByteBuffer {public static void main(String[] args) {// 方式一:創建byteBuffer對象,ByteBuffer是抽象類,使用allocate(capacity)方法給buffer分配緩存空間// 底層使用byte[]數組存儲緩存數據,數組的長度為傳入的參數capacityByteBuffer byteBuffer = ByteBuffer.allocate(1024);// 方式二:根據傳遞的內容自動創建緩存區大小,大小為內容的長度// ByteBuffer byteBuffer1 = ByteBuffer.wrap("hello,world".getBytes());// 向緩存區中放內容byteBuffer.put("hello".getBytes());// position 代表下一個存放位置的開始,初始為0System.out.println(byteBuffer.position()); // 5// 最大限制,就是capacitySystem.out.println(byteBuffer.limit()); //1024// 獲取到緩存區中存值的數組 byteBuffer.array();byte[] array = byteBuffer.array();System.out.println(new String(array)); //hello000000000000... 0代表空格// 這種方法要保證不能對position進行重置操作System.out.println(new String(array, 0, byteBuffer.position())); // hello// 重置buffer// byte數組中的內容不變,position重置為0,capacity賦值給limit,適合寫之前的操作byteBuffer.clear();// byte數組中的內容不變,position賦值給limit,position重置為0 適合讀之前的操作byteBuffer.flip();} }

Selector簡介

selector一般被稱為選擇器,也稱為多路復用器。是Java NIO核心組件中的一個,用于檢查一個躲著多個NIO channel 通道的狀態是否處于可讀或者可寫。如此可以實現單線程管理多個channels,也就是單個線程管理多個網絡連接。

?

可選擇通道SelectableChannel?

  • 判斷一個channel是否可以被selector復用,是判斷是否繼承了抽象類SelectableChannel,如果繼承了就可以被復用,否則就不能。?
  • SelectableChannel 類提供了實現通道的可選擇性所需要的公共方法,FileChannel類沒有繼承SelectableChannel類,因此不是可選通道。
  • 一個通道可以被注冊到多個選擇器上,但是對每個選擇器而言,只能注冊一次。通道和選擇器之間的關系,是使用注冊的方式完成。SelectableChannel可以被注冊到Selector對象上,注冊的時候,需要制定通道的那些操作是Selector感興趣的,如可讀,可寫等。

Channel注冊到Selector

  • 使用Channel.register(Selector sel, int ops)方法,將一個通道注冊到一個選擇器。第一個參數:指定通道要注冊的選擇器,第二個參數指定選擇器需要查詢的通道操作。
  • 可以供選擇器查詢的通道操作,類型上分為以下四種。
  • SelectionKey.OP_READ? 可讀
  • SelectionKey.OP_WRITE 可寫
  • SelectionKey.OP_CONNECT 連接
  • SelectionKey.OP_ACCEPT 接收
  • 通過“位或”操作實現對多通道感興趣? int key=SelectionKey.OP_READ |?SelectionKey.OP_WRITE
  • 選擇器查詢的不是通道的操作,而是通道某個操作的一種就緒狀態。就是說,一旦通道具備完成某個操作的條件,就標識該通道的這個操作依據就緒,就可以被selector查詢到,程序就可以對通道進行對應的操作。如:某個SocketChannel可以連接到一個服務器,則處于連接就緒
  • 選擇鍵?SelectionKey

  • channel注冊到selector后,并且一旦處于某種就緒狀態,就可以被選擇器查詢到,這個功能使用Selector的select()方法完成。
  • selector可以不斷查詢channel中發生的操作的就緒狀態,并且挑選感興趣的操作就緒狀態,一旦通道有操作的就緒狀態達成,并且是selector感興趣的操作,就會被selector選擇,放入選擇鍵集合中。
  • 一個選擇鍵,首先包含了注冊在selector的通道操作類型,比如可讀狀態,也包含了特定的通道與特定選擇器之間的注冊關系。
  • 選擇鍵的概念,和事件的概念比較相似,差別是事件是觸發模式,選擇鍵是主動查詢模式。
  • Selector的使用

  • 創建選擇器 Selector selector = Selector.open();
  • 注冊channel 到選擇器
  • 獲取通道?ServerSocketChannel ssc = ServerSocketChannel.open();
  • 設置為非阻塞模式??ssc.configureBlocking(false);
  • 綁定連接??ssc.bind(new InetSocketAddress("127.0.0.1", 9999));
  • 將通道注冊到選擇器上,并制定監聽事件?ssc.register(selector, SelectionKey.OP_ACCEPT);
  • 輪詢查詢就緒操作
  • ?selector.select(); 可以查詢已經就緒的通道操作,這些就緒的狀態集合,存在一個元素是SelectionKey的Set集合中。 循環調用這個方法,監測通道的就緒狀態
  • 幾個重載的select()方法:
  • select():阻塞方法,有至少一個通道在注冊的事件上就緒了;返回值為int類型,表示有多少個通道就緒了。(更準確的說是,前一次select()方法到這一次select()方法之間的時間段內,有多少通道變成就緒狀態。)一旦調用select()方法返回值不為0時,在Selector中有一個selectedKeys()方法,用來訪問選擇鍵集合
  • select(long timeout):長阻塞時間為timeouthaomia
  • selectNow():非阻塞,只要有通道就緒就立刻返回。
  • 遍歷selectedKeys()方法返回的set集合,獲取就緒的channel集合
  • 遍歷channel集合,判斷就緒事件類型,實現具體業務操作
  • 根據業務,是否需要再次注冊監聽事件,重復執行上述操作。
  • 停止選擇的方法
  • 選擇器執行選擇的過程,系統底層會一次詢問每個 通道是否就緒,這個過程可能會造成調用線程進入阻塞狀態,有以下幾種方式可以喚醒在select()方法中阻塞的線程。
  • wakeup():調用Selector對象的wakeup()方法讓在阻塞狀態下的select()方法立刻返回
  • close()方法:通過該方法關閉Selector,這個方法使任何一個在選擇操作中阻塞的線程都被喚醒,同時使得注冊到這個Selector上的所有channel被注銷,所有的鍵被取消,但是channel本身不會被關閉。
  • 注意:與selector 一起使用時,channel必須處于非阻塞模式,否則將拋出異常IllegalBlockingModeExcption;因此FileChannel不能和selector一起使用,因為FileChannel不能切換到非阻塞模式,而套接字相關的通道都可以

    一個通道并不是要支持所有四種操作,如服務器通道ServerSocketChannel支持ACCEPT操作,而SocketChannel不支持??梢酝ㄟ^通道上的validOps()方法,獲取特定通道下支持的操作集合。

    NIO實現服務端和客戶端的連接

    服務端

    /** Copyright (c) Huawei Technologies Co., Ltd. 2022-2022. All rights reserved.*/package IO;import java.io.IOException; import java.net.InetSocketAddress; import java.nio.ByteBuffer; import java.nio.channels.SelectableChannel; import java.nio.channels.SelectionKey; import java.nio.channels.Selector; import java.nio.channels.ServerSocketChannel; import java.nio.channels.SocketChannel; import java.util.Iterator; import java.util.Set;public class TestSeverSocketChannel {public static void main(String[] args) throws IOException, InterruptedException {// 創建TCP服務端的管道ServerSocketChannel ssc = ServerSocketChannel.open();// 默認管道是阻塞的,因此要手動設置為非阻塞模式ssc.configureBlocking(false);// 綁定對應的ip 端口號ssc.bind(new InetSocketAddress("127.0.0.1", 9999));// 創建選擇器(多路復用器)Selector selector = Selector.open();//將管道注冊到多路復用器上 --->參數1,多路復用器,參數2.多路復用器的監聽服務端接收客戶端的狀態(此時沒有狀態)// 如果接收到了客戶端,此時管道會變為該狀態ssc.register(selector, SelectionKey.OP_ACCEPT);while (true) {// 選擇管道的狀態 沒有狀態會阻塞,有狀態會繼續執行selector.select();System.out.println("------------------");// 獲取所有被監聽到的狀態Set<SelectionKey> selectionKeys = selector.selectedKeys();// 獲取迭代器,方便后續操作,當然也可以用foreach遍歷Iterator<SelectionKey> iterator = selectionKeys.iterator();while (iterator.hasNext()) {SelectionKey next = iterator.next();// 服務端接收到了客戶端,Accept狀態被監聽到if (next.isAcceptable()) {System.out.println(next.isAcceptable());SocketChannel accept = ssc.accept();// 這個管道是客戶端管道,可以理解是在服務端的這頭accept.configureBlocking(false);// 設置客戶端的管道在服務端這頭為非阻塞//System.out.println(accept);// 將客戶端管道注冊到多路復用器,監聽管道中內容的狀態accept.register(selector, SelectionKey.OP_READ);} else if (next.isReadable()) { // 管道中有數據// 可讀狀態時,獲取被選中的管道SelectableChannel sc = next.channel();// 通過客戶端管道接收數據,放入緩存中ByteBuffer allocate = ByteBuffer.allocate(1024);((SocketChannel) sc).read(allocate);byte[] array = allocate.array();String s = new String(array, 0, allocate.position());System.out.println(s);sc.register(selector, SelectionKey.OP_WRITE);// 讀完之后監聽寫的狀態} else if (next.isWritable()) {Thread.sleep(1000);SelectableChannel sc = next.channel();// 服務端向客戶端發送數據((SocketChannel) sc).write(ByteBuffer.wrap("你好".getBytes()));sc.register(selector, SelectionKey.OP_READ); // 寫完之后監聽讀}// 去除已經被監聽到的狀態iterator.remove();}}} }

    客戶端

    /** Copyright (c) Huawei Technologies Co., Ltd. 2022-2022. All rights reserved.*/package IO;import java.io.IOException; import java.net.InetSocketAddress; import java.nio.ByteBuffer; import java.nio.channels.SelectionKey; import java.nio.channels.Selector; import java.nio.channels.SocketChannel; import java.util.Iterator; import java.util.Set;public class TestSocketChannel {public static void main(String[] args) throws IOException, InterruptedException {// 創建客戶端管道SocketChannel sc = SocketChannel.open();// 設置為非阻塞sc.configureBlocking(false);// 創建多路復用器Selector selector = Selector.open();// 將客戶端管道注冊到多路復用器中sc.register(selector, SelectionKey.OP_CONNECT);// 連接服務端sc.connect(new InetSocketAddress("127.0.0.1", 9999));while (true) {// 選擇客戶端管道的狀態selector.select();// 獲取所有被監聽到的狀態Set<SelectionKey> selectionKeys = selector.selectedKeys();// 通過迭代器獲取所有被監聽到的狀態,方便后續操作Iterator<SelectionKey> iterator = selectionKeys.iterator();while (iterator.hasNext()) {SelectionKey next = iterator.next();//判斷客戶端是否連接了服務端,if (next.isConnectable()) {// 此時是掛起狀態,并沒有真正連接System.out.println(sc); // java.nio.channels.SocketChannel[connection-pending remote=/127.0.0.1:9999]// 讓客戶端管道掛起的狀態變成真正的鏈接狀態if (sc.isConnectionPending()) {sc.finishConnect();System.out.println(sc);// java.nio.channels.SocketChannel[connected local=/127.0.0.1:54278 remote=/127.0.0.1:9999]}// 向服務端輸出一句話ByteBuffer wrap = ByteBuffer.wrap("success".getBytes());sc.write(wrap);// 監聽客戶端管道中有數據的狀態sc.register(selector, SelectionKey.OP_READ);} else if (next.isReadable()) {// 通過客戶端管道接收數據,放入緩存中ByteBuffer allocate = ByteBuffer.allocate(1024);((SocketChannel) sc).read(allocate);byte[] array = allocate.array();String s = new String(array, 0, allocate.position());System.out.println(s);sc.register(selector, SelectionKey.OP_WRITE); // 讀完監聽寫// 想服務端寫數據} else if (next.isWritable()) {Thread.sleep(1000);sc.write(ByteBuffer.wrap("nihao".getBytes()));sc.register(selector, SelectionKey.OP_READ);// 寫完監聽讀}}}} }

    Pipe管道

    Java NIO管道是兩個線程之間的單向數據連接,Pipe中有一個source通道和一個sink通道,數據會被寫到sink通道中,然后從source通道中讀取。

    創建管道 Pipe pipe = Pipe.open();

    ?

    FileLock 文件鎖

  • 多個程序同時訪問、修改一個文件,很容易出現文件數據不同步的問題。給文件加一個鎖,同一時間,只能有同一個程序修改某個文件,或者程序都只能只讀此文件,就解決了同步問題。
  • 文件鎖是進程級別的,不是線程級別的。無法解決多線程并發訪問、修改一個文件的問題。
  • 文件鎖是當前程序所屬的JVM實例持有的,一旦獲取到文件鎖(對文件加鎖),要調用release()方法,或者關閉對應的FileChannel對象,或者當JVM退出,才會釋放這個鎖。
  • 一旦某個進程對某個文件加鎖,在釋放這個鎖之前,此進程不能在對此文件加鎖,就是說JVM實例在同一個文件上的文件鎖是不重疊的。
  • 文件鎖分類

    • 排他鎖:又叫獨占鎖,對文件加排他鎖后,該進程可以對此文件進行讀寫操作,其他進程不能讀寫此文件,直到該進程釋放文件鎖。
    • 共享鎖:某個進程對文件加共享鎖,其他進程也可以訪問該文件,但是都是只讀操作。

    獲取文件鎖的方法

    • lock() 對整個文件加鎖,默認排他鎖
    • lock(long position, long size , boolean shared)? 自定義加鎖方式,前兩個參數指定加鎖的部分(可以只對此文件部分內容加鎖),第三個參數指定是否為共享鎖
    • tryLock() 對整個文件加鎖,默認為排他鎖
    • tryLock(long position, long size , boolean shared)? 自定義加鎖方式

    lock和?tryLock 的區別:

    • lock是阻塞式的,如果未獲取到文件鎖,會一直阻塞當前線程,直到獲取文件鎖
    • tryLock是非阻塞式的,嘗試獲取文件鎖,獲取成功就返回鎖對象,失敗返回null,不會阻塞當前線程。

    AIO?

    Asynchronous IO:異步非阻塞IO,在執行時,當前線程不會阻塞,調用發起后,不需要等待返回結果(結果是以事件驅動的形式返回),而且也不需要多線程就可以實現多客戶端訪問。

    AIO實現服務端和客戶端的連接

    服務端

    /** Copyright (c) Huawei Technologies Co., Ltd. 2022-2022. All rights reserved.*/package IO;import java.io.IOException; import java.net.InetSocketAddress; import java.nio.ByteBuffer; import java.nio.channels.AsynchronousServerSocketChannel; import java.nio.channels.AsynchronousSocketChannel; import java.nio.channels.CompletionHandler; import java.util.concurrent.CountDownLatch;public class TestAsynchronousSeverSocketChannel {public static void main(String[] args) throws IOException, InterruptedException {// 計數器// CountDownLatch await() : CountDownLatch數組不等于0 的時候,阻塞// countDown(),調用一次,計數器的值-1CountDownLatch latch = new CountDownLatch(1);// 1 創建服務端AsynchronousServerSocketChannelAsynchronousServerSocketChannel assc = AsynchronousServerSocketChannel.open();// 2 綁定ip 和 端口號assc.bind(new InetSocketAddress("127.0.0.1", 9999));// 3 接收客戶端assc.accept(null, new CompletionHandler<AsynchronousSocketChannel, Object>() {// 接收成功執行該回調方法// 參數1: 客戶端的管道@Overridepublic void completed(AsynchronousSocketChannel result, Object attachment) {ByteBuffer allocate = ByteBuffer.allocate(1024);result.read(allocate, null, new CompletionHandler<Integer, Object>() {@Override // 成功接收到客戶端數據執行public void completed(Integer result, Object attachment) {System.out.println("連接成功");// 先獲取ByteBuffer中的數組byte[] array = allocate.array();// 數組轉為字符串String s = new String(array, 0, allocate.position());System.out.println(s);// 拿到數據,計數器減一latch.countDown();}@Override // 接收客戶端數據失敗執行public void failed(Throwable exc, Object attachment) {System.out.println("接收數據失敗");}});}// 接收失敗,執行該方法@Overridepublic void failed(Throwable exc, Object attachment) {System.out.println("接收失敗了");}});latch.await(); // 主線程等待} }

    客戶端

    /** Copyright (c) Huawei Technologies Co., Ltd. 2022-2022. All rights reserved.*/package IO;import java.io.IOException; import java.net.InetSocketAddress; import java.nio.ByteBuffer; import java.nio.channels.AsynchronousSocketChannel; import java.nio.channels.CompletionHandler; import java.util.concurrent.CountDownLatch;public class TestAsynchronousSocketChannel {public static void main(String[] args) throws IOException, InterruptedException {CountDownLatch latch = new CountDownLatch(1);// 1 創建客戶端AsynchronousSocketChannel asc = AsynchronousSocketChannel.open();// 2 連接服務端asc.connect(new InetSocketAddress("127.0.0.1", 9999), null, new CompletionHandler<Void, Object>() {// 連接服務端成功,執行該方法@Overridepublic void completed(Void result, Object attachment) {System.out.println("連接成功");asc.write(ByteBuffer.wrap("你好".getBytes()));latch.countDown();}// 連接服務端失敗,執行該方法@Overridepublic void failed(Throwable exc, Object attachment) {System.out.println("連接失敗");}});// 3 阻塞主線程,直到向服務端發送了消息latch.await();} }

    總結

    以上是生活随笔為你收集整理的Java - IO流学习笔记的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    黄色大片入口 | 免费av片在线 | 亚洲爽爽网| 国产精品国产三级国产 | 国产色在线视频 | 亚洲欧洲国产精品 | 国产一级二级av | 亚洲区二区 | 成人国产网站 | 99在线精品视频观看 | 久久视频免费在线观看 | 日本三级在线观看中文字 | 香蕉久久国产 | 日韩在线 一区二区 | 中文字幕日本在线 | 日韩精品视频在线免费观看 | 伊人婷婷| 亚洲激情在线 | 中文字幕在线看人 | 福利视频一二区 | 日韩av中文字幕在线 | 成年人国产在线观看 | 亚洲全部视频 | 日本字幕网 | 91精品免费在线观看 | av片子在线观看 | 91黄色在线观看 | 五月婷av| 亚洲伊人第一页 | www.伊人网 | 99爱在线观看 | 丁香综合激情 | 久久综合偷偷噜噜噜色 | 亚洲午夜小视频 | 一区二区精品 | 99超碰在线播放 | 99久久久成人国产精品 | 中文字幕在线看视频国产中文版 | 亚洲日本va午夜在线电影 | 91禁在线看 | 亚洲午夜久久久久久久久久久 | 日韩精品一区二区在线视频 | 久草干 | 国产生活一级片 | 欧美少妇bbwhd | 日本深夜福利视频 | 综合国产在线 | 最新亚洲视频 | 手机成人av | 在线欧美小视频 | 免费精品国产 | 欧美少妇18p | 久久tv视频 | 国产小视频在线观看免费 | 日日草夜夜操 | 九九热在线精品 | 国产999视频 | 草久在线观看 | 一区二区三区免费网站 | 午夜久久网站 | 午夜精品久久一牛影视 | 久久天天躁狠狠躁夜夜不卡公司 | 91传媒免费观看 | 西西4444www大胆无视频 | 天天干国产 | 国产成人精品av在线 | 日本久久综合网 | 国产亚洲一级高清 | 国产精品毛片久久蜜 | 国产视频69| 久久婷婷一区二区三区 | 国产超碰在线 | 久久草在线视频国产 | 欧美午夜精品久久久久 | 天海翼一区二区三区免费 | 麻豆视频在线播放 | 亚洲国产中文字幕 | 久久久久区 | 日韩精品一区二区三区不卡 | 亚洲理论在线观看电影 | 精品高清美女精品国产区 | 免费开视频 | 国产精品系列在线观看 | 国产黄色免费观看 | 五月天婷亚洲天综合网精品偷 | 黄色毛片大全 | 成人免费看电影 | 黄色精品一区二区 | 亚洲天天做 | 午夜三级福利 | 国产精品久久久久久久久久久久午 | 超碰在线观看99 | 国产日韩在线视频 | 久久电影中文字幕视频 | 国产精品一区二区三区在线免费观看 | 欧美色图一区 | 99精品欧美一区二区蜜桃免费 | 亚洲激情综合网 | 奇米影视777影音先锋 | 成年人毛片在线观看 | 亚洲2019精品 | 国产精品成人av电影 | 三级视频国产 | 91大神视频网站 | 一区二区三区久久 | 国产麻豆精品免费视频 | 蜜桃视频日本 | 国产成人一区二区三区电影 | 超碰在线观看av.com | 日日夜夜精品视频 | 九色视频网 | 亚洲理论在线观看 | 99爱在线| 国产福利91精品一区二区三区 | 日韩久久一区二区 | 日韩av成人在线观看 | 久久久亚洲精华液 | 色综合小说 | 右手影院亚洲欧美 | 97超级碰碰碰碰久久久久 | 国产精品视频最多的网站 | 亚洲成人二区 | 国产精品h在线观看 | 狠狠综合久久 | 成人欧美一区二区三区在线观看 | 黄色a一级片 | 69精品在线观看 | 99精品免费 | 黄色毛片视频 | 特级西西人体444是什么意思 | 亚洲成a人片77777kkkk1在线观看 | 天天草天天操 | 亚洲国产精品999 | 国产精选在线观看 | 久久精品艹 | av在线专区| 欧美成人在线免费观看 | 国产精品午夜久久久久久99热 | 狠狠狠狠狠狠狠干 | 国产精品嫩草在线 | 日韩欧美在线一区二区 | 国产精品美女久久久久久久久久久 | 国产福利一区二区三区在线观看 | 91成人在线网站 | 欧美综合色在线图区 | 日韩色在线观看 | 婷婷久久网站 | 国产精品久久久区三区天天噜 | 91免费版在线观看 | 免费看一及片 | 91豆花在线观看 | 精品免费观看 | 在线日本看片免费人成视久网 | 在线中文字幕视频 | 国产精品高清av | 青青草华人在线视频 | 天天久久夜夜 | 在线观看久久久久久 | 91在线视频一区 | 99产精品成人啪免费网站 | 综合久久2023| 伊人中文在线 | 日韩av中文在线观看 | 色网站在线看 | 成片免费| 一区二区不卡 | 最近的中文字幕大全免费版 | 亚洲精品短视频 | 九九综合久久 | 亚洲色图 校园春色 | 中文字幕无吗 | 亚洲精品欧美精品 | 五月天婷亚洲天综合网精品偷 | 人人爽人人爽人人爽人人爽 | 久久精品久久精品 | 久久久久久久久久久网 | 91精品国产91p65 | 亚洲精品一区二区精华 | 欧洲一区二区在线观看 | 五月天免费网站 | 亚洲免费视频在线观看 | 久久国产精品电影 | 97电影在线看视频 | 久久久久欧美精品 | 91在线观看黄 | 成年人黄色免费看 | 久久黄色片 | 综合久久久久久久久 | 久久久久电影网站 | 国产不卡在线视频 | 国产一区二区三区视频在线 | 亚洲精品国产精品国自产 | 99精品福利 | 日韩成人黄色av | 91手机视频 | av高清网站在线观看 | 国产精品久久网 | 日韩艹 | 亚洲精品视频在线播放 | 日日日视频 | 天天干天天操 | 在线观看亚洲 | 国产成人精品av在线 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 国产午夜精品av一区二区 | www免费视频com━ | 一二区电影 | 国产麻豆精品免费视频 | 国产婷婷在线观看 | 亚洲成人家庭影院 | 精品欧美一区二区在线观看 | 91尤物国产尤物福利在线播放 | 成人免费大片黄在线播放 | 色综合婷婷 | 成人h电影在线观看 | 欧美日韩高清不卡 | 成人精品国产 | 久久丁香| 国产视频2 | 久久久国产精品人人片99精片欧美一 | 99久久精品无码一区二区毛片 | 久久精品99久久久久久2456 | 在线视频 影院 | 伊人天天狠天天添日日拍 | 中文国产字幕 | 中文字幕有码在线播放 | 天天操 夜夜操 | 特级西西444www高清大视频 | 在线你懂的视频 | 国产高清在线 | 国产91精品一区二区麻豆亚洲 | 国产精品成人久久久久久久 | 精品一区二区综合 | 中文字幕日本特黄aa毛片 | 亚洲永久精品视频 | 国产在线综合视频 | 久久久精品免费观看 | 超碰午夜| 天天摸天天弄 | 91女子私密保健养生少妇 | 欧美a免费| 久久精品79国产精品 | 国产视频在线观看一区 | 亚洲精品视频免费在线 | 亚洲美女视频在线 | 在线午夜 | 久久久伦理| 国产二级视频 | 91色在线观看视频 | 国际精品久久久久 | 999视频在线播放 | 五月色丁香 | 国产三级精品三级在线观看 | 黄污在线观看 | 91精品影视 | 激情开心站 | 日本特黄特色aaa大片免费 | 日韩高清不卡一区二区三区 | 国产精品视频永久免费播放 | 黄色亚洲 | 精品一区在线看 | 欧美精品视 | 一区二区精品在线视频 | 中文字幕乱码亚洲精品一区 | 91亚洲精| 99精品视频观看 | 免费国产视频 | 人人爽夜夜爽 | 国产精品一区二区免费看 | 91在线精品播放 | 日韩精品视频免费在线观看 | 精品九九九 | 亚洲精品视频在线观看免费视频 | 日韩午夜三级 | 国产老太婆免费交性大片 | 中文字幕999 | 精品中文字幕视频 | 在线观看视频免费大全 | 国产精久久久久久妇女av | 99精品视频播放 | 成年人电影免费看 | 亚洲精品乱码久久久久久蜜桃不爽 | 日韩一区二区三区高清在线观看 | 日韩av成人在线观看 | 最新国产在线视频 | 久久久男人的天堂 | 一本色道久久精品 | 欧美一区二区三区激情视频 | 91av手机在线 | 97人人射 | 国产丝袜一区二区三区 | 国产一区在线免费观看视频 | www色网站 | 91在线视频播放 | 久久99婷婷 | 五月婷婷毛片 | 国产乱老熟视频网88av | 精壮的侍卫呻吟h | 激情网五月婷婷 | 免费视频91| 天天天色综合 | 亚洲一区二区麻豆 | 午夜久久影视 | 免费看污的网站 | 亚洲精品视频中文字幕 | 色综合天天天天做夜夜夜夜做 | 欧美大片在线看免费观看 | 一本一道久久a久久精品蜜桃 | 在线观看免费黄色 | 国产精品视频你懂的 | 在线观看精品视频 | 99久久精品免费看 | 久久美女免费视频 | 午夜精品久久 | 欧美性生活免费 | 在线观看国产亚洲 | 一区二区三区高清在线观看 | 日韩大片免费在线观看 | 狂野欧美激情性xxxx欧美 | 国产高清在线一区 | 菠萝菠萝蜜在线播放 | 激情五月五月婷婷 | 国产精品麻豆果冻传媒在线播放 | 九九免费在线观看视频 | 久久久精品欧美一区二区免费 | 亚洲专区在线视频 | 日韩二区三区在线 | 91久久精品日日躁夜夜躁国产 | 亚洲一区二区三区精品在线观看 | 人人插人人做 | 国产麻豆成人传媒免费观看 | 欧美污网站| 欧美一级免费 | 国产男女无遮挡猛进猛出在线观看 | 永久免费毛片在线观看 | 色无五月 | 亚洲二区精品 | av 一区二区三区 | 91黄在线看 | 国精产品999国精产 久久久久 | 欧美与欧洲交xxxx免费观看 | 天天舔夜夜操 | 天天操天天干天天操天天干 | 日韩在线免费视频 | 欧美国产日韩在线视频 | 亚洲最新在线 | 麻豆传媒在线视频 | 日韩欧美视频在线播放 | 超碰97国产精品人人cao | av免费在线观看1 | 日韩 精品 一区 国产 麻豆 | 亚洲欧美日韩精品久久久 | 亚洲精品电影在线 | 97在线看 | 久久午夜视频 | 国产午夜一级毛片 | 免费观看一级视频 | 99视频| 深爱五月激情网 | 久热av | 久久精品影片 | 四虎影视成人永久免费观看亚洲欧美 | 99精品欧美一区二区蜜桃免费 | 色狠狠一区二区 | 欧美福利精品 | 亚洲理论片| 欧美日韩国产免费视频 | 精品国产电影一区二区 | 亚洲综合色播 | 美女免费视频一区 | 日韩一区二区三免费高清在线观看 | 日日操网| 国产精品久久久久久久久久白浆 | 久久精品3 | 久久综合婷婷国产二区高清 | 色婷婷久久 | 久一久久 | 久久亚洲在线 | 手机看片午夜 | 亚洲资源在线 | 美女黄视频免费 | 国产一区二区视频在线 | 亚洲精品视频免费在线观看 | 国产一级片播放 | 亚洲欧美视屏 | 国产精品久久久久久麻豆一区 | 91网页版免费观看 | 婷婷久操| 97国产一区 | 日韩在线大片 | 日韩免 | 欧美极度另类性三渗透 | 国产女人40精品一区毛片视频 | 美女福利视频在线 | 欧美一级欧美一级 | 欧美激情视频一二区 | 免费视频三区 | 精品久久久久久久久久 | 免费在线观看中文字幕 | 亚洲国产中文在线观看 | 亚洲国产网站 | 丁香电影小说免费视频观看 | av在线电影免费观看 | 免费看黄在线看 | 中文字幕在线观看亚洲 | 天天色棕合合合合合合 | 国产91粉嫩白浆在线观看 | 福利视频午夜 | 999久久久久久久久 69av视频在线观看 | 欧美国产精品久久久久久免费 | 午夜精品久久久久久久99水蜜桃 | 99久久精品无码一区二区毛片 | 国产精品一区二区62 | 成人黄色在线视频 | 国产专区在线视频 | 国产91学生粉嫩喷水 | 五月婷婷综合久久 | 久草网在线观看 | 精品成人国产 | 久福利| 久久综合网色—综合色88 | 日韩性色 | 99精品视频免费全部在线 | 色婷婷久久一区二区 | 国产一级片久久 | 国产精品嫩草影视久久久 | av先锋影音少妇 | 日韩.com| 中文字幕一区二区三区久久蜜桃 | 国产999精品久久久久久 | 国产免费中文字幕 | a久久久久久 | 婷婷去俺也去六月色 | 96亚洲精品久久久蜜桃 | 69国产盗摄一区二区三区五区 | 最近中文字幕免费大全 | 麻豆视频免费在线观看 | 91色蜜桃| 免费看十八岁美女 | 伊人婷婷网 | 97超碰国产在线 | 久久免费视频一区 | 狠狠躁夜夜a产精品视频 | 中文视频一区二区 | 99精品国产一区二区三区不卡 | 九九免费在线看完整版 | 欧美精品久久久久久久久久 | 日韩视频专区 | 开心激情五月婷婷 | 亚洲成aⅴ人片久久青草影院 | 免费观看性生交大片3 | 在线看国产视频 | 美女视频免费一区二区 | 国模精品一区二区三区 | 成人一区二区三区在线观看 | 国产一区二区三精品久久久无广告 | 国产精品入口a级 | 国产精品免费一区二区三区在线观看 | 激情网在线观看 | 久久久久一区二区三区四区 | 亚欧洲精品视频在线观看 | 国产黄色片网站 | 91精品视频免费 | 国产又粗又硬又爽的视频 | 久久影院精品 | 日韩欧美精品在线观看 | 精品黄色在线观看 | 天天看天天干天天操 | 国产成人在线免费观看 | 激情久久网 | 国产中文字幕三区 | 在线播放91| 69av国产| www国产在线| 欧美va天堂在线电影 | 久久国产高清 | 毛片永久新网址首页 | 福利视频网站 | 97福利社 | 久久久综合九色合综国产精品 | 久草网站在线观看 | 亚洲国产精品一区二区久久,亚洲午夜 | 黄色三级免费网址 | 在线国产视频 | 免费在线国产视频 | 国产中文在线字幕 | 天天操天天曰 | 91精品在线免费观看视频 | 亚洲精品视频中文字幕 | av资源在线观看 | 亚洲男人天堂2018 | 在线免费av观看 | 色噜噜在线观看 | 手机av网站 | 欧美日韩视频免费 | www.伊人色.com | 国产视频2 | 亚洲激情在线播放 | 99久热在线精品 | 国产一级免费观看 | 国产天天综合 | 九九视频免费观看视频精品 | 人人草人人草 | 韩国精品一区二区三区六区色诱 | 日韩理论在线 | 国产福利av| 久久好看免费视频 | 欧美精品999 | 欧美日韩国产一二三区 | 成人禁用看黄a在线 | 中文字幕有码在线观看 | 久久中国精品 | 精品一区二区在线观看 | 国产精品久久久一区二区 | 欧美一级专区免费大片 | 精品国产区 | 在线免费中文字幕 | 日韩专区中文字幕 | 肉色欧美久久久久久久免费看 | 免费观看一区二区三区视频 | 亚洲特级片 | 亚洲理论片 | 日韩欧美在线第一页 | 美女国产精品 | 男女免费av | 在线观看mv的中文字幕网站 | 久久精品小视频 | 不卡的一区二区三区 | 午夜av电影院 | 色偷偷88888欧美精品久久 | 西西4444www大胆艺术 | 久久香蕉影视 | 在线之家免费在线观看电影 | 国产一级片免费视频 | 国产精品久久久久久久久久三级 | 日本动漫做毛片一区二区 | 午夜久久影院 | 丁香激情综合久久伊人久久 | 午夜体验区 | 亚洲综合成人婷婷小说 | 三级在线视频观看 | 国产手机视频在线 | 一区二区三区视频 | 手机看片 | 欧美日韩视频免费看 | 成 人 黄 色视频免费播放 | 国产福利91精品一区二区三区 | 黄色片视频免费 | 久久九九国产精品 | 午夜 久久 tv | 日本在线观看一区二区 | 在线视频欧美日韩 | 视频99爱 | av中文字幕网站 | 久草影视在线观看 | 国产精品99久久久精品免费观看 | 天天干天天操天天拍 | 久久免费的视频 | 免费成人黄色 | 免费高清男女打扑克视频 | a在线观看国产 | 国产精品久久久久影视 | 开心激情久久 | 精品久久久久久久久久久久 | 天天干天天操天天干 | 国产亚洲精品美女久久 | 久久综合狠狠综合久久狠狠色综合 | 欧美aaaxxxx做受视频 | 国产成人精品999 | 日本在线h | 久草免费在线视频观看 | 国产成人精品久 | 国产日韩欧美在线一区 | 97夜夜澡人人爽人人免费 | 免费看三片 | 在线免费中文字幕 | 免费午夜在线视频 | 又粗又长又大又爽又黄少妇毛片 | 欧美成年黄网站色视频 | 99久久精品免费一区 | 中文字幕在线视频一区二区 | 欧美国产一区二区 | 精品一区精品二区高清 | 国产精品亚洲a | 1024久久| 片网站| 97av免费视频 | 91精品国产三级a在线观看 | 成人小视频免费在线观看 | 99久久99视频 | 成人网在线免费视频 | 婷婷伊人五月天 | 亚洲蜜桃在线 | www.久久色 | 亚洲无线视频 | 99久久久国产精品免费观看 | 中文字幕免费一区二区 | 97在线精品视频 | 免费观看成年人视频 | 91中文字幕在线 | 天天射天天干天天插 | 日韩在线看片 | 五月天天色 | 在线观看国产区 | 色福利网站 | 超碰人人在 | 亚洲一区美女视频在线观看免费 | 又湿又紧又大又爽a视频国产 | 亚洲精品字幕在线观看 | 狠狠色丁香久久婷婷综合_中 | 国产无遮挡猛进猛出免费软件 | 久久五月情影视 | 亚洲女同ⅹxx女同tv | 亚洲男男gaygay无套同网址 | 日韩欧美视频在线观看免费 | 久久视精品 | 国产黄在线观看 | 欧美精品久久 | 久草视频免费在线观看 | 国产精品久久嫩一区二区免费 | 亚洲精品乱码久久久久久久久久 | 亚洲国产成人精品在线 | 91热视频 | 精品国产一区二区久久 | 少妇av网 | 婷婷在线五月 | 免费黄色a网站 | 亚洲九九精品 | 中文字幕在线观看第三页 | 胖bbbb搡bbbb擦bbbb | av在线播放亚洲 | 激情婷婷综合 | 偷拍福利视频一区二区三区 | 中文字幕 婷婷 | 天天干天天干天天 | 夜夜澡人模人人添人人看 | 91视频91蝌蚪 | 国产激情小视频在线观看 | 91av欧美 | 亚洲精品乱码久久久久久蜜桃动漫 | 久久精品草 | 色资源二区在线视频 | 国产生活一级片 | 久久97久久 | 久久精品网站视频 | 中文字幕免费在线 | 精品国产一区二区三区久久久蜜臀 | 激情视频一区二区三区 | 久操视频在线观看 | 久久人人爽人人爽人人片av免费 | 国产精品观看在线亚洲人成网 | 永久免费视频国产 | 亚洲黄色在线免费观看 | 亚洲欧洲精品一区二区精品久久久 | 色99色| 91精选在线观看 | 91精品啪在线观看国产81旧版 | 91精品啪在线观看国产 | 日韩欧美视频一区二区三区 | 97视频免费观看2区 亚洲视屏 | 日韩在线视频不卡 | 久久在线一区 | 久久久精品网 | 蜜臀av性久久久久av蜜臀三区 | 一区三区视频在线观看 | 日韩午夜电影 | 六月丁香久久 | 99久久久国产精品免费99 | 久草视频在线免费播放 | 色婷婷av一区二 | 日p在线观看 | 在线观看色网站 | 国产精品成人在线观看 | 手机av在线免费观看 | 激情狠狠干 | 99视频99| 久久天堂亚洲 | 日韩在线观看视频在线 | 丝袜美女视频网站 | 天天射天天爽 | 99热这里只有精品8 久久综合毛片 | 免费日韩三级 | 久久免费黄色网址 | 国产成人精品区 | 国产视频美女 | 成人在线观看日韩 | 99热这里精品| 在线观看免费成人 | 黄色日批网站 | 色婷五月 | 欧美久久久一区二区三区 | 在线观看岛国片 | 成人性生交视频 | 国产成人性色生活片 | 国产精品国产三级国产专区53 | 日韩小视频 | 成人免费视频网址 | 色噜噜日韩精品一区二区三区视频 | 欧美精品九九99久久 | 亚洲国产小视频在线观看 | 色在线视频 | 久久综合久久综合久久综合 | 国产精品高潮久久av | 日韩av电影手机在线观看 | 精品999在线观看 | 午夜美女网站 | av在线8 | 在线之家免费在线观看电影 | 日韩精品一区二区三区在线视频 | 亚洲视频在线观看免费 | 奇米7777狠狠狠琪琪视频 | 亚洲高清视频在线播放 | 国产精品爽爽久久久久久蜜臀 | 国产手机免费视频 | 青青河边草观看完整版高清 | 成人久久久久久久久久 | 精品久久久久久综合日本 | 人人干人人模 | 亚洲欧洲国产精品 | 伊人看片| 色综合久久久久久中文网 | 2019免费中文字幕 | 99视频国产精品 | 少妇bbw搡bbbb搡bbbb | 国产精品毛片一区二区在线 | 在线激情影院一区 | 色美女在线| 超碰人人在线 | 五月天高清欧美mv | 亚洲激情 | 亚洲激情网站免费观看 | 久草在线91 | 99综合电影在线视频 | 国产高清不卡av | 伊人五月在线 | 欧美成人亚洲 | 国内综合精品午夜久久资源 | 欧美日韩啪啪 | 精品国精品自拍自在线 | 日韩视频精品在线 | 91久久精品日日躁夜夜躁国产 | 96精品视频| av丁香花 | 国产成人精品亚洲精品 | 日韩激情视频在线观看 | 99久久久国产精品美女 | 欧美日韩精品区 | 日本超碰在线 | 国产一区二区在线看 | 深爱婷婷网 | 国产理论在线 | 亚洲精品综合欧美二区变态 | 一区二区中文字幕在线播放 | 麻豆传媒电影在线观看 | 国产一区二区三区午夜 | 色婷婷激情 | 91麻豆精品国产91久久久无需广告 | 日本在线观看黄色 | 久久久高清一区二区三区 | 久久精品亚洲综合专区 | 午夜91在线| 精品一区二区在线看 | 免费成视频 | 综合久久综合久久 | 日韩久久久久久久 | 91精品欧美 | 国产精品久久久久久久妇 | www.xxx.性狂虐 | 人人网人人爽 | 九九久久久久久久久激情 | 99久久精品电影 | 免费高清男女打扑克视频 | 西西4444www大胆视频 | 日韩精品一区二区三区丰满 | 国产成人99久久亚洲综合精品 | 亚洲精品乱码久久久久久写真 | 欧美一级在线 | 国产麻豆电影 | 在线观看视频国产 | 亚洲码国产日韩欧美高潮在线播放 | 国产xvideos免费视频播放 | 欧美在线一级片 | 国产精品福利在线 | 日韩一区二区免费播放 | 国产成人精品一二三区 | 国内精品视频在线 | 中文字幕免费国产精品 | 女人高潮特级毛片 | 久久综合免费视频影院 | 香蕉视频久久 | 狠狠ri| 91精品伦理 | 一级片黄色片网站 | 在线日韩亚洲 | 青青河边草手机免费 | av激情五月 | 91亚洲精品在线观看 | 亚洲另类xxxx | 色婷婷激情电影 | 国产在线视频在线观看 | 中文字幕不卡在线88 | 黄色av观看 | 国产精品白丝jk白祙 | 欧美日本不卡视频 | 久久久久久久18 | www.夜夜爽 | 国产成人精品综合久久久 | 国产破处在线视频 | 91在线日本 | 久久精品视频中文字幕 | 2021国产视频 | 狠狠的日 | 欧美va天堂va视频va在线 | 国产精品久久久久久久妇 | 久久久久久看片 | 久久久在线 | 国产精品美女久久久久久久 | 国产视频一区在线播放 | 99精品视频在线观看免费 | 成人网色 | 国产精品女人久久久久久 | 亚洲男女精品 | 国产一区 在线播放 | 人人看人人艹 | 99热在线国产精品 | 蜜臀av麻豆 | 成人免费色 | av黄色免费网站 | 亚洲伊人天堂 | 激情综合国产 | 亚洲精品国产精品国 | 97视频人人免费看 | 国产人成一区二区三区影院 | 亚洲激情久久 | a久久免费视频 | 亚洲精品国产精品国自 | 国产精品一区二区久久精品 | 久久视频精品在线 | 久久成人18免费网站 | 久久午夜精品 | 亚洲91视频 | 黄色精品免费 | 久久精品久久综合 | 国产精品门事件 | 91精品推荐 | 免费在线观看不卡av | 中文在线字幕免费观看 | 国产在线黄色 | 久草在线观看视频免费 | 三三级黄色片之日韩 | 成人av电影免费在线观看 | 国产裸体bbb视频 | 亚洲国产美女精品久久久久∴ | 五月婷婷开心中文字幕 | 国产亚洲成人网 | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 人人搞人人干 | 99久久精品一区二区成人 | 成人午夜网 | 在线观看日韩中文字幕 | 欧美一区中文字幕 | 欧美激情精品一区 | 日本大尺码专区mv | 深爱激情开心 | 国产一区二区不卡视频 | 久久精品www人人爽人人 | 啪啪激情网 | 免费在线观看一区 | 99国产情侣在线播放 | 97爱爱爱| 日韩最新av在线 | 91精品国产高清自在线观看 | 国产精品久久久久一区二区 | 国产精品专区一 | 最新婷婷色 | 欧美日韩中文字幕视频 | 91人人网 | 亚州国产精品久久久 | av品善网 | 欧美天天射| 亚洲国产视频在线 | 国产精品美女久久久久久久网站 | 久久网站最新地址 | 久久久久久久国产精品影院 | 国产视频丨精品|在线观看 国产精品久久久久久久久久久久午夜 | 亚洲午夜久久久久久久久 | 欧美在线视频第一页 | 亚洲精品xxxx | 91色视频 | 欧美一级看片 | 日韩黄色一级电影 | 热久久视久久精品18亚洲精品 | 国产精品网站一区二区三区 | 日日夜夜狠狠 | 免费看日韩 | 色偷偷网站视频 | 亚洲精品影院在线观看 | 欧美视屏一区二区 | 成人小电影在线看 | 久久久久久久久久久电影 | 欧美一区二区三区免费观看 | 午夜少妇一区二区三区 | 免费在线国产视频 | 最新av免费在线 | 91在线porny国产在线看 | 日韩三级成人 | 精品免费一区二区三区 | 久久理伦片| 亚洲精品999 | 日韩超碰在线 | 欧美精品v国产精品 | 人人看人人做人人澡 | 国产不卡在线观看 | 美女网站在线观看 | 国产大尺度视频 | 国产麻豆果冻传媒在线观看 | 五月天色中色 | 欧美精品做受xxx性少妇 | 国产伦精品一区二区三区高清 | 成片免费观看视频 | 亚洲精选在线观看 | 久久国产精品久久精品国产演员表 | 在线精品国产 | 久久久黄色 | 在线观看成人一级片 | 久久日韩精品 | 在线观看网站av | 日本高清中文字幕有码在线 | 欧美视频99 | 久久成视频 | 成人黄色资源 | 96精品高清视频在线观看软件特色 | 日韩在线视频网站 | 精品久久久久久久久久久久久久久久久久 | 激情综合网在线观看 | 欧美精品乱码99久久影院 | 亚洲精品白浆高清久久久久久 | 美女av免费 | 97视频在线免费观看 | 中文字幕第一页av | 国产免费黄视频在线观看 | 婷婷5月色 | 日本视频久久久 | 2022国产精品视频 | 国产日韩视频在线播放 | 色在线高清| 国产理论免费 | 国产香蕉97碰碰久久人人 | 又黄又刺激 | 国产96av| 天天天天色射综合 | 999久久久久久久久 69av视频在线观看 | 一区二区三区在线免费观看 | 国产亚洲91| 亚洲精品高清视频 | 亚洲精品中文字幕在线 | 久色 网 | 国产精品18久久久久久久久久久久 | 精精国产xxxx视频在线播放 | 免费视频91蜜桃 | 国内精品久久久 | 成人永久免费 | 麻豆视频国产精品 | www.天天干.com| 国产网红在线观看 | 成人国产精品一区二区 | 奇米影视777影音先锋 | 中文字幕免费观看视频 | 国产精品久久久一区二区 | 日本黄色一级电影 | 激情视频国产 | 色婷婷六月 | 久草电影网| 天天爱天天干天天爽 | 久久999久久| 最近2019好看的中文字幕免费 | 日韩在线免费播放 | 国产高清专区 | 青青久草在线视频 | 国产精品久久久一区二区 | 97操碰| av不卡中文| 国产精品中文字幕av | 91精品国产自产在线观看永久 | 色婷婷激情五月 | 在线 视频 一区二区 | 国产一区二区视频在线播放 | 久久亚洲电影 | 国产精品观看在线亚洲人成网 | 久久99亚洲精品久久久久 | 久久综合免费视频 | 国产精品白丝jk白祙 | 欧美亚洲精品一区 | 国产精品美女久久久 | 国产精品99视频 | 97香蕉久久国产在线观看 | 日韩午夜剧场 | 在线黄色观看 |