久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

PL/0语言编译程序分析

發布時間:2025/3/15 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 PL/0语言编译程序分析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

PL/0語言是Pascal語言的一個子集,我們這里分析的PL/0的編譯程序包括了對PL/0語言源程序進行分析處理、編譯生成類PCODE代碼,并在虛擬機上解釋運行生成的類PCODE代碼的功能。
  PL/0語言編譯程序采用以語法分析為核心、一遍掃描的編譯方法。詞法分析和代碼生成作為獨立的子程序供語法分析程序調用。語法分析的同時,提供了出錯報告和出錯恢復的功能。在源程序沒有錯誤編譯通過的情況下,調用類PCODE解釋程序解釋執行生成的類PCODE代碼。

  詞法分析子程序分析:
  詞法分析子程序名為getsym,功能是從源程序中讀出一個單詞符號(token),把它的信息放入全局變量sym、id和num中,語法分析器需要單詞時,直接從這三個變量中獲得。(注意!語法分析器每次用完這三個變量的值就立即調用getsym子程序獲取新的單詞供下一次使用。而不是在需要新單詞時才調用getsym過程。)getsym過程通過反復調用getch子過程從源程序過獲取字符,并把它們拼成單詞。getch過程中使用了行緩沖區技術以提高程序運行效率。
  詞法分析器的分析過程:調用getsym時,它通過getch過程從源程序中獲得一個字符。如果這個字符是字母,則繼續獲取字符或數字,最終可以拼成一個單詞,查保留字表,如果查到為保留字,則把sym變量賦成相應的保留字類型值;如果沒有查到,則這個單詞應是一個用戶自定義的標識符(可能是變量名、常量名或是過程的名字),把sym置為ident,把這個單詞存入id變量。查保留字表時使用了二分法查找以提高效率。如果getch獲得的字符是數字,則繼續用getch獲取數字,并把它們拼成一個整數,然后把sym置為number,并把拼成的數值放入num變量。如果識別出其它合法的符號(比如:賦值號、大于號、小于等于號等),則把sym則成相應的類型。如果遇到不合法的字符,把sym置成nul。

  語法分析子程序分析:
  語法分析子程序采用了自頂向下的遞歸子程序法,語法分析同時也根據程序的語意生成相應的代碼,并提供了出錯處理的機制。語法分析主要由分程序分析過程(block)、常量定義分析過程(constdeclaration)、變量定義分析過程(vardeclaration)、語句分析過程(statement)、表達式處理過程(expression)、項處理過程(term)、因子處理過程(factor)和條件處理過程(condition)構成。這些過程在結構上構成一個嵌套的層次結構。除此之外,還有出錯報告過程(error)、代碼生成過程(gen)、測試單詞合法性及出錯恢復過程(test)、登錄名字表過程(enter)、查詢名字表函數(position)以及列出類PCODE代碼過程(listcode)作過語法分析的輔助過程。
  由PL/0的語法圖可知:一個完整的PL/0程序是由分程序和句號構成的。因此,本編譯程序在運行的時候,通過主程序中調用分程序處理過程block來分析分程序部分(分程序分析過程中還可能會遞歸調用block過程),然后,判斷最后讀入的符號是否為句號。如果是句號且分程序分析中未出錯,則是一個合法的PL/0程序,可以運行生成的代碼,否則就說明源PL/0程序是不合法的,輸出出錯提示即可。
  下面按各語法單元分析PL/0編譯程序的運行機制。

  分程序處理過程:
  語法分析開始后,首先調用分程序處理過程(block)處理分程序。過程入口參數置為:0層、符號表位置0、出錯恢復單詞集合為句號、聲明符或語句開始符。進入block過程后,首先把局部數據段分配指針設為3,準備分配3個單元供運行期存放靜態鏈SL、動態鏈DL和返回地址RA。然后用tx0記錄下當前符號表位置并產生一條jmp指令,準備跳轉到主程序的開始位置,由于當前還沒有知到主程序究竟在何處開始,所以jmp的目標暫時填為0,稍后再改。同時在符號表的當前位置記錄下這個jmp指令在代碼段中的位置。在判斷了嵌套層數沒有超過規定的層數后,開始分析源程序。首先判斷是否遇到了常量聲明,如果遇到則開始常量定義,把常量存入符號表。接下去用同樣的方法分析變量聲明,變量定義過程中會用dx變量記錄下局部數據段分配的空間個數。然后如果遇到procedure保留字則進行過程聲明和定義,聲明的方法是把過程的名字和所在的層次記入符號表,過程定義的方法就是通過遞歸調用block過程,因為每個過程都是一個分程序。由于這是分程序中的分程序,因此調用block時需把當前的層次號lev加一傳遞給block過程。分程序聲明部分完成后,即將進入語句的處理,這時的代碼分配指針cx的值正好指向語句的開始位置,這個位置正是前面的jmp指令需要跳轉到的位置。于是通過前面記錄下來的地址值,把這個jmp指令的跳轉位置改成當前cx的位置。并在符號表中記錄下當前的代碼段分配地址和局部數據段要分配的大小(dx的值)。生成一條int指令,分配dx個空間,作為這個分程序段的第一條指令。下面就調用語句處理過程statement分析語句。分析完成后,生成操作數為0的opr指令,用于從分程序返回(對于0層的主程序來說,就是程序運行完成,退出)。

  常量定義過程:
  通過循環,反復獲得標識符和對應的值,存入符號表。符號表中記錄下標識符的名字和它對應的值。

  變量定義過程:
  與常量定義類似,通過循環,反復獲得標識符,存入符號表。符號表中記錄下標識符的名字、它所在的層及它在所在層中的偏移地址。

  語句處理過程:
  語句處理過程是一個嵌套子程序,通過調用表達式處理、項處理、因子處理等過程及遞歸調用自己來實現對語句的分析。語句處理過程可以識別的語句包括賦值語句、read語句、write語句、call語句、if語句、while語句。當遇到begin/end語句時,就遞歸調用自己來分析。分析的同時生成相應的類PCODE指令。

  賦值語句的處理:
  首先獲取賦值號左邊的標識符,從符號表中找到它的信息,并確認這個標識符確為變量名。然后通過調用表達式處理過程算得賦值號右部的表達式的值并生成相應的指令保證這個值放在運行期的數據棧頂。最后通過前面查到的左部變量的位置信息,生成相應的sto指令,把棧頂值存入指定的變量的空間,實現了賦值操作。

  read語句的處理:
  確定read語句語法合理的前提下(否則報錯),生成相應的指令:第一條是16號操作的opr指令,實現從標準輸入設備上讀一個整數值,放在數據棧頂。第二條是sto指令,把棧頂的值存入read語句括號中的變量所在的單元。

  write語句的處理:
  與read語句相似。在語法正確的前提下,生成指令:通過循環調用表達式處理過程分析write語句括號中的每一個表達式,生成相應指令保證把表達式的值算出并放到數據棧頂并生成14號操作的opr指令,輸出表達式的值。最后生成15號操作的opr指令輸出一個換行。

  call語句的處理:
  從符號表中找到call語句右部的標識符,獲得其所在層次和偏移地址。然后生成相應的cal指令。至于調用子過程所需的保護現場等工作是由類PCODE解釋程序在解釋執行cal指令時自動完成的。

  if語句的處理:
  按if語句的語法,首先調用邏輯表達式處理過程處理if語句的條件,把相應的真假值放到數據棧頂。接下去記錄下代碼段分配位置(即下面生成的jpc指令的位置),然后生成條件轉移jpc指令(遇0或遇假轉移),轉移地址未知暫時填0。然后調用語句處理過程處理then語句后面的語句或語句塊。then后的語句處理完后,當前代碼段分配指針的位置就應該是上面的jpc指令的轉移位置。通過前面記錄下的jpc指令的位置,把它的跳轉位置改成當前的代碼段指針位置。

  begin/end語句的處理:
  通過循環遍歷begin/end語句塊中的每一個語句,通過遞歸調用語句分析過程分析并生成相應代碼。

  while語句的處理:
  首先用cx1變量記下當前代碼段分配位置,作為循環的開始位置。然后處理while語句中的條件表達式生成相應代碼把結果放在數據棧頂,再用cx2變量記下當前位置,生成條件轉移指令,轉移位置未知,填0。通過遞歸調用語句分析過程分析do語句后的語句或語句塊并生成相應代碼。最后生成一條無條件跳轉指令jmp,跳轉到cx1所指位置,并把cx2所指的條件跳轉指令的跳轉位置改成當前代碼段分配位置。

  表達式、項、因子處理:
  根據PL/0語法可知,表達式應該是由正負號或無符號開頭、由若干個項以加減號連接而成。而項是由若干個因子以乘除號連接而成,因子則可能是一個標識符或一個數字,或是一個以括號括起來的子表達式。根據這樣的結構,構造出相應的過程,遞歸調用就完成了表達式的處理。把項和因子獨立開處理解決了加減號與乘除號的優先級問題。在這幾個過程的反復調用中,始終傳遞fsys變量的值,保證可以在出錯的情況下跳過出錯的符號,使分析過程得以進行下去。

  邏輯表達式的處理:
  首先判斷是否為一元邏輯表達式:判奇偶。如果是,則通過調用表達式處理過程分析計算表達式的值,然后生成判奇指令。如果不是,則肯定是二元邏輯運算符,通過調用表達式處理過程依次分析運算符左右兩部分的值,放在棧頂的兩個空間中,然后依不同的邏輯運算符,生成相應的邏輯判斷指令,放入代碼段。

  判斷單詞合法性與出錯恢復過程分析:
  本過程有三個參數,s1、s2為兩個符號集合,n為出錯代碼。本過程的功能是:測試當前符號(即sym變量中的值)是否在s1集合中,如果不在,就通過調用出錯報告過程輸出出錯代碼n,并放棄當前符號,通過詞法分析過程獲取一下單詞,直到這個單詞出現在s1或s2集合中為止。
  這個過程在實際使用中很靈活,主要有兩個用法:
  在進入某個語法單位時,調用本過程,檢查當前符號是否屬于該語法單位的開始符號集合。若不屬于,則濾去開始符號和后繼符號集合外的所有符號。
  在語法單位分析結束時,調用本過程,檢查當前符號是否屬于調用該語法單位時應有的后繼符號集合。若不屬于,則濾去后繼符號和開始符號集合外的所有符號。
  通過這樣的機制,可以在源程序出現錯誤時,及時跳過出錯的部分,保證語法分析可以繼續下去。

  語法分析過程中調用的其它子過程相對比較簡單,請參考源程序的注釋。

  類PCODE代碼解釋執行過程分析
  這個過程模擬了一臺可以運行類PCODE指令的棧式計算機。它擁有一個棧式數據段用于存放運行期數據、擁有一個代碼段用于存放類PCODE程序代碼。同時還擁用數據段分配指針、指令指針、指令寄存器、局部段基址指針等寄存器。
  解釋執行類PCODE代碼時,數據段存儲分配方式如下:
  對于源程序的每一個過程(包括主程序),在被調用時,首先在數據段中開辟三個空間,存放靜態鏈SL、動態鏈DL和返回地址RA。靜態鏈記錄了定義該過程的直接外過程(或主程序)運行時最新數據段的基地址。動態鏈記錄調用該過程前正在運行的過程的數據段基址。返回地址記錄了調用該過程時程序運行的斷點位置。對于主程序來說,SL、DL和RA的值均置為0。靜態鏈的功能是在一個子過程要引用它的直接或間接父過程(這里的父過程是按定義過程時的嵌套情況來定的,而不是按執行時的調用順序定的)的變量時,可以通過靜態鏈,跳過個數為層差的數據段,找到包含要引用的變量所在的數據段基址,然后通過偏移地址訪問它。
  在過程返回時,解釋程序通過返回地址恢復指令指針的值到調用前的地址,通過當前段基址恢復數據段分配指針,通過動態鏈恢復局部段基址指針。實現子過程的返回。對于主程序來說,解釋程序會遇到返回地址為0的情況,這時就認為程序運行結束。
  解釋程序過程中的base函數的功能,就是用于沿著靜態鏈,向前查找相差指定層數的局部數據段基址。  這在使用sto、lod等訪問局部變量的指令中會經常用到。
  類PCODE代碼解釋執行的部分通過循環和簡單的case判斷不同的指令,做出相應的動作。當遇到主程序中的返回指令時,指令指針會指到0位置,把這樣一個條件作為終至循環的條件,保證程序運行可以正常的結束。

以下源程序是以清華大學出版社《編譯原理》中的源代碼為基礎作了少量改動而成。

程序在Turbo Pascal 7.0上編譯運行通過。

************************************************************************************

program pl0(fa,fa1,fa2); (* PL/0編譯程序與代碼生成解釋運行程序 *)
(* PL/0 compiler with code generation *)
label 99; (* 聲明出錯跳轉標記 *)
(* 在Turbo Pascal 7.0中已不允許跨過程的GOTO轉移,因此后面的GOTO語句均被我去除了,因此這里的label也沒有意義了 *)
const (* 常量定義 *)
? norw = 13;???? (* of reserved words *) (* 保留字的個數 *)
? txmax = 100;?? (* length of identifier table *) (* 標識符表的長度(容量) *)
? nmax = 14;???? (* max number of digits in numbers *) (* 數字允許的最長位數 *)
? al = 10;?????? (* length of identifiers *) (* 標識符最長長度 *)
? amax = 2047;?? (* maximum address *) (* 尋址空間 *)
? levmax = 3;??? (* max depth of block nesting *) (* 最大允許的塊嵌套層數 *)
? cxmax = 200;?? (* size of code array *) (* 類PCODE目標代碼數組長度(可容納代碼行數) *)
type (* 類型定義 *)
? symbol = (nul, ident, number, plus, minus, times, slash, oddsym,
??????????? eql, neq, lss, leq, gtr, geq, lparen, rparen, comma,
??????????? semicolon, period, becomes, beginsym, endsym, ifsym,
??????????? thensym, whilesym, writesym, readsym, dosym, callsym,
??????????? constsym, varsym, procsym); (* symobl類型標識了不同類型的詞匯 *)
? alfa = packed array[1..al] of char; (* alfa類型用于標識符 *)
? object1 = (constant, variable, procedur); (* object1為三種標識符的類型 *)
? (* 原程序在此使用object作為類型名稱,在支持面向對象的Turbo Pascal 7.0中編譯不能通過 *)
? (* wirth used the word "procedure" there, whick won't work! *)
? (* 上面一行是課本上的程序清單中的注釋,說本程序的原作者Wirth在這里用了procedure這個詞作為標識符類型,是不可以的。
???? 事實上Wirth原本在這里用的詞是prozedure,是可以的。 *)
? symset = set of symbol; (* symset是symbol類型的一個集合類型,可用于存放一組symbol *)
? fct = (lit, opr, lod, sto, cal, int, jmp, jpc); (* fct類型分別標識類PCODE的各條指令 *)
? instruction = packed record
??? f: fct;?????? (* function code *)
??? l: 0..levmax; (* level *)
??? a: 0..amax;?? (* displacement addr *)
? end; (* 類PCODE指令類型,包含三個字段:指令f、層差l和另一個操作數a *)
? (*
???? lit 0, a? load constant a
???? opr 0, a? execute opr a
???? lod l, a? load variable l, a
???? sto l, a? store variable l, a
???? cal l, a? call procedure a at level l
???? int 0, a? increment t-register by a
???? jmp 0, a? jump to a
???? jpc 0, a? jump conditional to a
? *)
var (* 全局變量定義 *)
? fa: text; (* 文本文件fa用于列出源程序 *)
? fa1, fa2: text; (* 文本文件fa1用于列出類PCODE代碼、fa2用于記錄解釋執行類PCODE代碼的過程 *)
? listswitch: boolean; (* true set list object code *) (* 如果本變量置true,程序編譯后將為列出類PCODE代碼,
????????????????????????????????????????????????????????? 否則不列出類PCODE代碼 *)
? ch: char; (* last char read *) (* 主要用于詞法分析器,存放最近一次從文件中讀出的字符 *)
? sym: symbol; (* last symbol read *) (* 詞法分析器輸出結果之用,存放最近一次識別出來的token的類型 *)
? id: alfa;? (* last identifier read *) (* 詞法分析器輸出結果之用,存放最近一次識別出來的標識符的名字 *)
? num: integer; (* last number read *) (* 詞法分析器輸出結果之用,存放最近一次識別出來的數字的值 *)
? cc: integer;? (* character count *) (* 行緩沖區指針 *)
? ll: integer;? (* line length *) (* 行緩沖區長度 *)
? kk: integer;? (* 引入此變量是出于程序性能考慮,見getsym過程注釋 *)
? cx: integer;? (* code allocation index *) (* 代碼分配指針,代碼生成模塊總在cx所指位置生成新的代碼 *)
? line: array[1..81] of char; (* 行緩沖區,用于從文件讀出一行,供詞法分析獲取單詞時之用 *)
? a: alfa; (* 詞法分析器中用于臨時存放正在分析的詞 *)
? code: array[0..cxmax] of instruction; (* 生成的類PCODE代碼表,存放編譯得到的類PCODE代碼 *)
? word: array[1..norw] of alfa; (* 保留字表 *)
? wsym: array[1..norw] of symbol; (* 保留字表中每一個保留字對應的symbol類型 *)
? ssym: array[' '..'^'] of symbol; (* 一些符號對應的symbol類型表 *)
??? (* wirth uses "array[char]" here *)
? mnemonic: array[fct] of packed array[1..5] of char;(* 類PCODE指令助記符表 *)
? declbegsys, statbegsys, facbegsys: symset; (* 聲明開始、表達式開始和項開始符號集合 *)
? table: array[0..txmax] of record (* 符號表 *)
??? name: alfa; (* 符號的名字 *)
??? case kind: object1 of (* 符號的類型 *)
????? constant: (* 如果是常量名 *)
??????? (val: integer); (* val中放常量的值 *)
????? variable, procedur:? (* 如果是變量名或過程名 *)
??????? (level, adr, size: integer) (* 存放層差、偏移地址和大小 *)
??????? (* "size" lacking in orginal. I think it belons here *)
? end;
? fin, fout: text; (* fin文本文件用于指向輸入的源程序文件,fout程序中沒有用到 *)
? fname: string; (* 存放PL/0源程序文件的文件名 *)
? (* 我修改的代碼:原程序在此處使用alfa類型,無法在Turbo Pascal 7.0中通過,readln函數的參數不能為alfa型 *)
? err: integer; (* 出錯總次數 *)
(* 出錯處理過程error *)
(* 參數:n:出錯代碼 *)
procedure error(n: integer);
begin
? writeln('****', ' ': cc-1, '!', n:2); (* 在屏幕cc-1位置顯示!與出錯代碼提示,由于cc
?????????????????????????????????????????? 是行緩沖區指針,所以!所指位置即為出錯位置 *)
? writeln(fa1, '****', ' ': cc-1, '!', n:2); (* 在文件cc-1位置輸出!與出錯代碼提示 *)
? err := err + 1 (* 出錯總次數加一 *)
end (* error *);
(* 詞法分析過程getsym *)
procedure getsym;
var
? i, j, k: integer;
? (* 讀取原程序中下一個字符過程getch *)
? procedure getch;
? begin
??? if cc = ll then (* 如果行緩沖區指針指向行緩沖區最后一個字符就從文件讀一行到行緩沖區 *)
??? begin
????? if eof(fin) then (* 如果到達文件末尾 *)
????? begin
??????? write('Program incomplete'); (* 出錯,退出程序 *)
??????? close(fa);
??????? close(fa1);
??????? close(fin);
??????? halt(0);???????
??????? {goto 99}
??????? (* 我修改的代碼,由于Turbo Pascal 7.0中不允許跨過程的goto,就只能用上面的方法退出程序了。 *)
????? end;
????? ll := 0; (* 行緩沖區長度置0 *)
????? cc := 0; (* 行緩沖區指針置行首 *)
????? write(cx: 4, ' '); (* 輸出cx值,寬度為4 *)
????? write(fa1, cx: 4, ' '); (* 輸出cx值,寬度為4到文件 *)
????? while not eoln(fin) do (* 當未到行末時 *)
????? begin
??????? ll := ll + 1; (* 行緩沖區長度加一 *)
??????? read(fin, ch); (* 從文件讀入一個字符到 ch *)
??????? write(ch); (* 在屏幕輸出ch *)
??????? write(fa1, ch); (* 把ch輸出到文件 *)
??????? line[ll] := ch; (* 把讀到的字符存入行緩沖區相應的位置 *)
????? end;
????? (* 可見,PL/0源程序要求每行的長度都小于81個字符 *)
????? writeln;
????? ll := ll + 1; (* 行緩沖區長度加一,用于容納即將讀入的回車符CR *)
????? read(fin, line[ll]);(* 把#13(CR)讀入行緩沖區尾部 *)
????? read(fin, ch); (* 我添加的代碼。由于PC上文本文件換行是以#13#10(CR+LF)表示的,
??????????????????????? 所以要把多余的LF從文件讀出,這里放在ch變量中是由于ch變量的
??????????????????????? 值在下面即將被改變,把這個多余值放在ch中沒有問題 *)
????? writeln(fa1);
??? end;
??? cc := cc + 1; (* 行緩沖區指針加一,指向即將讀到的字符 *)
??? ch := line[cc] (* 讀出字符,放入全局變量ch *)
? end (* getch *);
begin (* getsym *)
? while (ch = ' ') or (ch = #13) do (* 我修改的代碼:這句原來是用于讀一個有效的字符
?????????????????????????????????????? (跳過讀出的字符中多余的空格),但實際上還要跳
?????????????????????????????????????? 過多余的回車 *)
??? getch;
? if ch in ['a'..'z'] then (* 如果讀出的字符是一個字母,說明是保留字或標識符 *)
? begin
??? k := 0; (* 標識符緩沖區指針置0 *)
??? repeat (* 這個循環用于依次讀出源文件中的字符構成標識符 *)
????? if k < al then (* 如果標識符長度沒有超過最大標識符長度(如果超過,就取前面一部分,把多余的拋棄) *)
????? begin
??????? k := k + 1;
??????? a[k] := ch;
????? end;
????? getch (* 讀下一個字符 *)
??? until not (ch in ['a'..'z','0'..'9']); (* 直到讀出的不是字母或數字,由此可知PL/0的標識符構成規則是:
????????????????????????????????????????????? 以字母開頭,后面跟若干個字母或數字 *)
??? if k >= kk then (* 如果當前獲得的標識符長度大于等于kk *)
????? kk := k (* 令kk為當前標識符長度 *)
??? else
????? repeat (* 這個循環用于把標識符緩沖后部沒有填入相應字母或空格的空間用空格補足 *)
??????? a[kk] := ' ';
??????? kk := kk - 1
????? until kk = k;
??? (* 在第一次運行這個過程時,kk的值為al,即最大標識符長度,如果讀到的標識符長度小于kk,
?????? 就把a數組的后部沒有字母的空間用空格補足。
?????? 這時,kk的值就成為a數組前部非空格字符的個數。以后再運行getsym時,如果讀到的標識符長度大于等于kk,
?????? 就把kk的值變成當前標識符的長度。
?????? 這時就不必在后面填空格了,因為它的后面肯定全是空格。反之如果最近讀到的標識符長度小于kk,那就需要從kk位置向前,
?????? 把超過當前標識長度的空間填滿空格。
?????? 以上的這樣一個邏輯,完全是出于程序性能的上考慮。其實完全可以簡單的把a數組中a[k]元素以后的空間不管三七二十一全填空格。
??? *)
??? (* 下面開始二分法查找看讀出的標識符是不是保留字之一 *)
??? id := a; (* 最后讀出標識符等于a *)
??? i := 1; (* i指向第一個保留字 *)
??? j := norw; (* j指向最后一個保留字 *)
??? repeat
????? k := (i + j) div 2; (* k指向中間一個保留字 *)
????? if id <= word[k] then (* 如果當前的標識符小于k所指的保留字 *)
??????? j := k - 1; (* 移動j指針 *)
????? if id >= word[k] then (* 如果當前的標識符大于k所指的保留字 *)
??????? i := k + 1 (* 移動i指針 *)
??? until i > j; (* 循環直到找完保留字表 *)
??? if i - 1 > j then (* 如果i - 1 > j表明在保留字表中找到相應的項,id中存的是保留字 *)
????? sym := wsym[k] (* 找到保留字,把sym置為相應的保留字值 *)
??? else
????? sym := ident (* 未找到保留字,把sym置為ident類型,表示是標識符 *)
? end(* 至此讀出字符為字母即對保留字或標識符的處理結束 *)
? else (* 如果讀出字符不是字母 *)
??? if ch in ['0'..'9'] then (* 如果讀出字符是數字 *)
??? begin (* number *) (* 開始對數字進行處理 *)
????? k := 0; (* 數字位數 *)
????? num := 0; (* 數字置為0 *)
????? sym := number; (* 置sym為number,表示這一次讀到的是數字 *)
????? repeat (* 這個循環依次從源文件中讀出字符,組成數字 *)
??????? num := 10 * num + (ord(ch) - ord('0')); (* num * 10加上最近讀出的字符ASCII減'0'的ASCII得到相應的數值 *)
??????? k := k + 1; (* 數字位數加一 *)
??????? getch
????? until not (ch in ['0'..'9']); (* 直到讀出的字符不是數字為止 *)
????? if k > nmax then (* 如果組成的數字位數大于最大允許的數字位數 *)
??????? error(30) (* 發出30號錯 *)
??? end(* 至此對數字的識別處理結束 *)
??? else
????? if ch = ':' then (* 如果讀出的不字母也不是數字而是冒號 *)
????? begin
??????? getch; (* 再讀一個字符 *)
??????? if ch = '=' then (* 如果讀到的是等號,正好可以與冒號構成賦值號 *)
??????? begin
????????? sym := becomes; (* sym的類型設為賦值號becomes *)
????????? getch (* 再讀出下一個字 *)
??????? end
??????? else
????????? sym := nul; (* 如果不是讀到等號,那單獨的一個冒號就什么也不是 *)
????? end(* 以上完成對賦值號的處理 *)
??? else (* 如果讀到不是字母也不是數字也不是冒號 *)
????? if ch = '<' then (* 如果讀到小于號 *)
????? begin
??????? getch; (* 再讀一個字符 *)
??????? if ch = '=' then (* 如果讀到等號 *)
??????? begin
????????? sym := leq; (* 購成一個小于等于號 *)
????????? getch (* 讀一個字符 *)
??????? end
??????? else (* 如果小于號后不是跟的等號 *)
????????? sym := lss (* 那就是一個單獨的小于號 *)
????? end
????? else (* 如果讀到不是字母也不是數字也不是冒號也不是小于號 *)
??????? if ch = '>' then (* 如果讀到大于號,處理過程類似于處理小于號 *)
??????? begin
????????? getch; (* 再讀一個字符 *)
????????? if ch = '=' then (* 如果讀到等號 *)
????????? begin
??????????? sym := geq; (* 購成一個大于等于號 *)
??????????? getch (* 讀一個字符 *)
????????? end
????????? else (* 如果大于號后不是跟的等號 *)
??????????? sym := gtr (* 那就是一個單獨的大于號 *)
??????? end
??????? else(* 如果讀到不是字母也不是數字也不是冒號也不是小于號也不是大于號 *)
??????? begin (* 那就說明它不是標識符/保留字,也不是復雜的雙字節操作符,應該是一個普通的符號 *)
????????? sym := ssym[ch]; (* 直接成符號表中查到它的類型,賦給sym *)
????????? getch (* 讀下一個字符 *)
??????? end
? (* 整個if語句判斷結束 *)
end (* getsym *);
(* 詞法分析過程getsym總結:從源文件中讀出若干有效字符,組成一個token串,識別它的類型
?? 為保留字/標識符/數字或是其它符號。如果是保留字,把sym置成相應的保留字類型,如果是
?? 標識符,把sym置成ident表示是標識符,于此同時,id變量中存放的即為保留字字符串或標識
?? 符名字。如果是數字,把sym置為number,同時num變量中存放該數字的值。如果是其它的操作符,
?? 則直接把sym置成相應類型。經過本過程后ch變量中存放的是下一個即將被識別的字符 *)
(* 目標代碼生成過程gen *)
(* 參數:x:要生成的一行代碼的助記符 *)
(*?????? y, z:代碼的兩個操作數 *)
(* 本過程用于把生成的目標代碼寫入目標代碼數組,供后面的解釋器解釋執行 *)
procedure gen(x: fct; y, z: integer);
begin
? if cx > cxmax then (* 如果cx>cxmax表示當前生成的代碼行號大于允許的最大代碼行數 *)
? begin
??? write('program too long'); (* 輸出"程序太長",退出 *)
??? close(fa);
??? close(fa1);
??? close(fin);
??? halt(0)??????
??? {goto 99}
??? (* 我修改的代碼,由于Turbo Pascal 7.0中不允許跨過程的goto,就只能用上面的方法退出程序了。 *)
? end;
? with code[cx] do (* 把代碼寫入目標代碼數組的當前cx所指位置 *)
? begin
??? f := x;
??? l := y;
??? a := z;
? end;
? cx := cx + 1 (* 移動cx指針指向下一個空位 *)
end (* gen *);
(* 測試當前單詞是否合法過程test *)
(* 參數:s1:當語法分析進入或退出某一語法單元時當前單詞符合應屬于的集合 *)
(*?????? s2:在某一出錯狀態下,可恢復語法分析正常工作的補充單詞集合 *)
(*?????? n:出錯信息編號,當當前符號不屬于合法的s1集合時發出的出錯信息 *)
procedure test(s1, s2: symset; n: integer);
begin
? if not (sym in s1) then (* 如果當前符號不在s1中 *)
? begin
??? error(n); (* 發出n號錯誤 *)
??? s1 := s1 + s2; (* 把s2集合補充進s1集合 *)
??? while not (sym in s1) do (* 通過循環找到下一個合法的符號,以恢復語法分析工作 *)
????? getsym
? end
end (* test *);
(* 語法分析過程block *)
(* 參數:lev:這一次語法分析所在的層次 *)
(*?????? tx:符號表指針 *)
(*?????? fsys:用于出錯恢復的單詞集合 *)
procedure block(lev, tx: integer; fsys: symset);
var
? dx: integer; (* data allocation index *) (* 數據段內存分配指針,指向下一個被分配空間在數據段中的偏移位置 *)
? tx0: integer;? (* initial table index *) (* 記錄本層開始時符號表位置 *)
? cx0: integer;? (* initial code index *) (* 記錄本層開始時代碼段分配位置 *)
? (* 登陸符號表過程enter *)
? (* 參數:k:欲登陸到符號表的符號類型 *)
? procedure enter(k: object1);
? begin (* enter object into table *)
??? tx := tx + 1; (* 符號表指針指向一個新的空位 *)
??? with table[tx] do (* 開始登錄 *)
??? begin
????? name := id; (* name是符號的名字,對于標識符,這里就是標識符的名字 *)
????? kind := k; (* 符號類型,可能是常量、變量或過程名 *)
????? case k of (* 根據不同的類型進行不同的操作 *)
??????? constant: (* 如果是常量名 *)
??????? begin
????????? if num > amax then (* 在常量的數值大于允許的最大值的情況下 *)
????????? begin
??????????? error(31); (* 拋出31號錯誤 *)
??????????? num := 0; (* 實際登陸的數字以0代替 *)
????????? end;
????????? val := num (* 如是合法的數值,就登陸到符號表 *)
??????? end;
??????? variable: (* 如果是變量名 *)
??????? begin
????????? level := lev; (* 記下它所屬的層次號 *)
????????? adr := dx; (* 記下它在當前層中的偏移量 *)
????????? dx := dx+1; (* 偏移量自增一,為下一次做好準備 *)
??????? end;
??????? procedur: (* 如果要登陸的是過程名 *)
????????? level := lev (* 記錄下這個過程所在層次 *)
????? end
??? end
? end (* enter *);
? (* 登錄符號過程沒有考慮到重復的定義的問題。如果出現重復定義,則以最后一次的定義為準。 *)
?
? (* 在符號表中查找指定符號所在位置的函數position *)
? (* 參數:id:要找的符號 *)
? (* 返回值:要找的符號在符號表中的位置,如果找不到就返回0 *)
? function position (id: alfa): integer;
? var
??? i: integer;
? begin (* find identifier in table *)
??? table[0].name := id; (* 先把id放入符號表0號位置 *)
??? i := tx; (* 從符號表中當前位置也即最后一個符號開始找 *)
??? while table[i].name <> id do (* 如果當前的符號與要找的不一致 *)
????? i := i - 1; (* 找前面一個 *)
??? position := i (* 返回找到的位置號,如果沒找到則一定正好為0 *)
? end(* position *);
? (* 常量聲明處理過程constdeclaration *)
? procedure constdeclaration;
? begin
??? if sym = ident then (* 常量聲明過程開始遇到的第一個符號必然應為標識符 *)
??? begin
????? getsym; (* 獲取下一個token *)
????? if sym in [eql, becomes] then (* 如果是等號或賦值號 *)
????? begin
??????? if sym = becomes then (* 如果是賦值號(常量生明中應該是等號) *)
????????? error(1); (* 拋出1號錯誤 *)
??????? (* 這里其實自動進行了錯誤糾正使編譯繼續進行,把賦值號當作等號處理 *)
??????? getsym; (* 獲取下一個token,等號或賦值號后應接上數字 *)
??????? if sym = number then (* 如果的確是數字 *)
??????? begin
????????? enter(constant); (* 把這個常量登陸到符號表 *)
????????? getsym (* 獲取下一個token,為后面作準備 *)
??????? end
??????? else
????????? error(2) (* 如果等號后接的不是數字,拋出2號錯誤 *)
????? end
????? else
??????? error(3) (* 如果常量標識符后接的不是等號或賦值號,拋出3號錯誤 *)
??? end
??? else
????? error(4) (* 如果常量聲明過程遇到的第一個符號不為標識符,拋出4號錯誤 *)
? end(* constdeclaration *);
? (* 變量聲明過程vardeclaration *)?
? procedure vardeclaration;
? begin
??? if sym = ident then (* 變量聲明過程開始遇到的第一個符號必然應為標識符 *)
??? begin
????? enter(variable); (* 將標識符登陸到符號表中 *)
????? getsym (* 獲取下一個token,為后面作準備 *)
??? end
??? else
????? error(4) (* 如果變量聲明過程遇到的第一個符號不是標識符,拋出4號錯誤 *)
? end(* vardeclaration *);
? (* 列出當前一層類PCODE目標代碼過程listcode *)
? procedure listcode;
? var
??? i: integer;
? begin (* list code generated for this block *)
??? if listswitch then (* 如果用戶選擇是要列出代碼的情況下才列出代碼 *)
??? begin
????? for i := cx0 to cx - 1 do (* 從當前層代碼開始位置到當前代碼位置-1處,即為本分程序塊 *)
??????? with code[i] do
??????? begin
????????? writeln(i: 4, mnemonic[f]: 5, l: 3, a: 5); (* 顯示出第i行代碼的助記符和L與A操作數 *)
????????? (* 我修改的代碼:原程序此處在輸出i時,沒有指定占4個字符寬度,不美觀也與下面一句不配套。 *)
????????? writeln(fa, i: 4, mnemonic[f]: 5, l: 3, a: 5) (* 同時把屏顯打印到文件 *)
??????? end;
??? end
? end(* listcode *);
? (* 語句處理過程statement *)
? (* 參數說明:fsys: 如果出錯可用來恢復語法分析的符號集合 *)
? procedure statement(fsys: symset);
? var
??? i, cx1, cx2: integer;
??? (* 表達式處理過程expression *)
??? (* 參數說明:fsys: 如果出錯可用來恢復語法分析的符號集合 *)
??? procedure expression(fsys: symset);
??? var
????? addop: symbol;
????? (* 項處理過程term *)
????? (* 參數說明:fsys: 如果出錯可用來恢復語法分析的符號集合 *)
????? procedure term(fsys: symset);
????? var
??????? mulop: symbol;
??????? (* 因子處理過程factor *)
??????? (* 參數說明:fsys: 如果出錯可用來恢復語法分析的符號集合 *)
??????? procedure factor(fsys: symset);
??????? var
????????? i: integer;
??????? begin
????????? test(facbegsys, fsys, 24); (* 開始因子處理前,先檢查當前token是否在facbegsys集合中。 *)
???????????????????????????????????? (* 如果不是合法的token,拋24號錯誤,并通過fsys集恢復使語法處理可以繼續進行 *)????????
????????? while sym in facbegsys do (* 循環處理因子 *)
????????? begin
??????????? if sym = ident then (* 如果遇到的是標識符 *)
??????????? begin
????????????? i := position(id); (* 查符號表,找到當前標識符在符號表中的位置 *)
????????????? if i = 0 then (* 如果查符號表返回為0,表示沒有找到標識符 *)
??????????????? error(11) (* 拋出11號錯誤 *)
????????????? else
??????????????? with table[i] do (* 如果在符號表中找到了當前標識符的位置,開始生成相應代碼 *)
????????????????? case kind of
??????????????????? constant: gen(lit, 0, val); (* 如果這個標識符對應的是常量,值為val,生成lit指令,把val放到棧頂 *)
??????????????????? variable: gen(lod, lev - level, adr); (* 如果標識符是變量名,生成lod指令, *)
????????????????????????????????????????????????????????? (* 把位于距離當前層level的層的偏移地址為adr的變量放到棧頂 *)
??????????????????? procedur: error(21) (* 如果在因子處理中遇到的標識符是過程名,出錯了,拋21號錯 *)
????????????????? end;
????????????? getsym (* 獲取下一token,繼續循環處理 *)
??????????? end
??????????? else
????????????? if sym = number then (* 如果因子處理時遇到數字 *)
????????????? begin
??????????????? if num > amax then (* 如果數字的大小超過允許最大值amax *)
??????????????? begin
????????????????? error(31); (* 拋出31號錯 *)
????????????????? num := 0 (* 把數字按0值處理 *)
??????????????? end;
??????????????? gen(lit, 0, num); (* 生成lit指令,把這個數值字面常量放到棧頂 *)
??????????????? getsym (* 獲取下一token *)
????????????? end
????????????? else
??????????????? if sym = lparen then (* 如果遇到的是左括號 *)
??????????????? begin
????????????????? getsym; (* 獲取一個token *)
????????????????? expression( [rparen] + fsys ); (* 遞歸調用expression子程序分析一個子表達式 *)
????????????????? if sym = rparen then (* 子表達式分析完后,應遇到右括號 *)
??????????????????? getsym (* 如果的確遇到右括號,讀取下一個token *)
????????????????? else
??????????????????? error(22) (* 否則拋出22號錯誤 *)
??????????????? end;
??????????? test(fsys, facbegsys, 23) (* 一個因子處理完畢,遇到的token應在fsys集合中 *)
????????????????????????????????????? (* 如果不是,拋23號錯,并找到下一個因子的開始,使語法分析可以繼續運行下去 *)
????????? end
??????? end(* factor *);
????? begin (* term *)
??????? factor([times, slash] + fsys); (* 每一個項都應該由因子開始,因此調用factor子程序分析因子 *)
??????? while sym in [times, slash] do (* 一個因子后應當遇到乘號或除號 *)
??????? begin
????????? mulop := sym; (* 保存當前運算符 *)
????????? getsym; (* 獲取下一個token *)
????????? factor(fsys + [times, slash]); (* 運算符后應是一個因子,故調factor子程序分析因子 *)
????????? if mulop = times then (* 如果剛才遇到乘號 *)
??????????? gen(opr, 0, 4) (* 生成乘法指令 *)
????????? else
??????????? gen(opr, 0, 5) (* 不是乘號一定是除號,生成除法指令 *)
??????? end
????? end (* term *);
??? begin (* expression *)
????? if sym in [plus, minus] then (* 一個表達式可能會由加號或減號開始,表示正負號 *)
????? begin
??????? addop := sym; (* 把當前的正號或負號保存起來,以便下面生成相應代碼 *)
??????? getsym; (* 獲取一個token *)
??????? term(fsys + [plus, minus]); (* 正負號后面應該是一個項,調term子程序分析 *)
??????? if addop = minus then (* 如果保存下來的符號是負號 *)
????????? gen(opr, 0, 1) (* 生成一條1號操作指令:取反運算 *)
??????? (* 如果不是負號就是正號,不需生成相應的指令 *)
????? end
????? else (* 如果不是由正負號開頭,就應是一個項開頭 *)
??????? term(fsys + [plus, minus]); (* 調用term子程序分析項 *)
????? while sym in [plus, minus] do (* 項后應是加運算或減運算 *)
????? begin
??????? addop := sym; (* 把運算符保存下來 *)
??????? getsym; (* 獲取下一個token,加減運算符后應跟的是一個項 *)
??????? term(fsys + [plus, minus]); (* 調term子程序分析項 *)
??????? if addop = plus then (* 如果項與項之間的運算符是加號 *)
????????? gen(opr, 0, 2) (* 生成2號操作指令:加法 *)
??????? else (* 否則是減法 *)
????????? gen(opr, 0, 3) (* 生成3號操作指令:減法 *)
????? end
??? end (* expression *);
??? (* 條件處理過程condition *)
??? (* 參數說明:fsys: 如果出錯可用來恢復語法分析的符號集合 *)
??? procedure condition(fsys: symset);
??? var
????? relop: symbol; (* 用于臨時記錄token(這里一定是一個二元邏輯運算符)的內容 *)
??? begin
????? if sym = oddsym then (* 如果是odd運算符(一元) *)
????? begin
??????? getsym; (* 獲取下一個token *)
??????? expression(fsys); (* 對odd的表達式進行處理計算 *)
??????? gen(opr, 0, 6); (* 生成6號操作指令:奇偶判斷運算 *)
????? end
????? else (* 如果不是odd運算符(那就一定是二元邏輯運算符) *)
????? begin
??????? expression([eql, neq, lss, leq, gtr, geq] + fsys); (* 對表達式左部進行處理計算 *)
??????? if not (sym in [eql, neq, lss, leq, gtr, geq]) then (* 如果token不是邏輯運算符中的一個 *)
????????? error(20) (* 拋出20號錯誤 *)
??????? else
??????? begin
????????? relop := sym; (* 記錄下當前的邏輯運算符 *)
????????? getsym; (* 獲取下一個token *)
????????? expression(fsys); (* 對表達式右部進行處理計算 *)
????????? case relop of (* 如果剛才的運算符是下面的一種 *)
??????????? eql: gen(opr, 0, 8); (* 等號:產生8號判等指令 *)
??????????? neq: gen(opr, 0, 9); (* 不等號:產生9號判不等指令 *)
??????????? lss: gen(opr, 0, 10); (* 小于號:產生10號判小指令 *)
??????????? geq: gen(opr, 0, 11); (* 大于等號號:產生11號判不小于指令 *)
??????????? gtr: gen(opr, 0, 12); (* 大于號:產生12號判大于指令 *)
??????????? leq: gen(opr, 0, 13); (* 小于等于號:產生13號判不大于指令 *)
????????? end
??????? end
????? end
??? end (* condition *);
? begin (* statement *)
??? if sym = ident then (* 所謂"語句"可能是賦值語句,以標識符開頭 *)
??? begin
????? i := position(id); (* 在符號表中查到該標識符所在位置 *)
????? if i = 0 then (* 如果沒找到 *)
??????? error(11) (* 拋出11號錯誤 *)
????? else
??????? if table[i].kind <> variable then (* 如果在符號表中找到該標識符,但該標識符不是變量名 *)
??????? begin
????????? error(12); (* 拋出12號錯誤 *)
????????? i := 0 (* i置0作為錯誤標志 *)
??????? end;
????? getsym; (* 獲得下一個token,正常應為賦值號 *)
????? if sym = becomes then (* 如果的確為賦值號 *)
??????? getsym (* 獲取下一個token,正常應為一個表達式 *)
????? else
??????? error(13); (* 如果賦值語句的左部標識符號后所接不是賦值號,拋出13號錯誤 *)
????? expression(fsys); (* 處理表達式 *)
????? if i <> 0 then (* 如果不曾出錯,i將不為0,i所指為當前語名左部標識符在符號表中的位置 *)
??????? with table[i] do
????????? gen(sto, lev - level, adr) (* 產生一行把表達式值寫往指定內存的sto目標代碼 *)
??? end
??? else
????? if sym = readsym then (* 如果不是賦值語句,而是遇到了read語句 *)
????? begin
??????? getsym; (* 獲得下一token,正常情況下應為左括號 *)
??????? if sym <> lparen then (* 如果read語句后跟的不是左括號 *)
????????? error(34) (* 拋出34號錯誤 *)
??????? else
????????? repeat (* 循環得到read語句括號中的參數表,依次產生相應的“從鍵盤讀入”目標代碼 *)
??????????? getsym; (* 獲得一個token,正常應是一個變量名 *)
??????????? if sym = ident then (* 如果確為一個標識符 *)
??????????? (* 這里略有問題,還應判斷一下這個標識符是不是變量名,如果是常量名或過程名應出錯 *)
????????????? i := position(id) (* 查符號表,找到它所在位置給i,找不到時i會為0 *)
??????????? else
????????????? i := 0; (* 不是標識符則有問題,i置0作為出錯標志 *)
??????????? if i = 0 then (* 如果有錯誤 *)
????????????? error(35) (* 拋出35號錯誤 *)
??????????? else (* 否則生成相應的目標代碼 *)
????????????? with table[i] do
????????????? begin
??????????????? gen(opr, 0, 16); (* 生成16號操作指令:從鍵盤讀入數字 *)
??????????????? gen(sto, lev - level, adr) (* 生成sto指令,把讀入的值存入指定變量所在的空間 *)
????????????? end;
??????????? getsym (* 獲取下一個token,如果是逗號,則read語還沒完,否則應當是右括號 *)
????????? until sym <> comma; (* 不斷生成代碼直到read語句的參數表中的變量遍歷完為止,這里遇到不是逗號,應為右括號 *)
??????? if sym <> rparen then (* 如果不是我們預想中的右括號 *)
??????? begin
????????? error(33); (* 拋出33號錯誤 *)
????????? while not (sym in fsys) do (* 依靠fsys集,找到下一個合法的token,恢復語法分析 *)
??????????? getsym
??????? end
??????? else
????????? getsym (* 如果read語句正常結束,得到下一個token,一般為分號或end *)
????? end
????? else
??????? if sym = writesym then (* 如果遇到了write語句 *)
??????? begin
????????? getsym; (* 獲取下一token,應為左括號 *)
????????? if sym = lparen then (* 如確為左括號 *)
????????? begin
??????????? repeat (* 依次獲取括號中的每一個值,進行輸出 *)
????????????? getsym; (* 獲得一個token,這里應是一個標識符 *)
????????????? expression([rparen, comma] + fsys); (* 調用expression過程分析表達式,用于出錯恢復的集合中加上右括號和逗號 *)
????????????? gen(opr, 0, 14) (* 生成14號指令:向屏幕輸出 *)
??????????? until sym <> comma; (* 循環直到遇到的不再是逗號,這時應是右括號 *)
??????????? if sym <> rparen then (* 如果不是右括號 *)
????????????? error(33) (* 拋出33號錯誤 *)
??????????? else
????????????? getsym (* 正常情況下要獲取下一個token,為后面準備好 *)
????????? end;
????????? gen(opr, 0, 15) (* 生成一個15號操作的目標代碼,功能是輸出一個換行 *)
????????? (* 由此可知PL/0中的write語句與Pascal中的writeln語句類似,是帶有輸出換行的 *)
??????? end
??????? else
????????? if sym = callsym then (* 如果是call語句 *)
????????? begin
??????????? getsym; (* 獲取token,應是過程名型標識符 *)
??????????? if sym <> ident then (* 如果call后跟的不是標識符 *)
????????????? error(14) (* 拋出14號錯誤 *)
??????????? else
??????????? begin
????????????? i := position(id); (* 從符號表中找出相應的標識符 *)
????????????? if i = 0 then (* 如果沒找到 *)
??????????????? error(11) (* 拋出11號錯誤 *)
????????????? else
??????????????? with table[i] do (* 如果找到標識符位于符號表第i位置 *)
????????????????? if kind = procedur then (* 如果這個標識符為一個過程名 *)
??????????????????? gen(cal,lev-level,adr) (* 生成cal目標代碼,呼叫這個過程 *)
????????????????? else
??????????????????? error(15); (* 如果call后跟的不是過程名,拋出15號錯誤 *)
????????????? getsym (* 獲取下一token,為后面作準備 *)
??????????? end
????????? end
??????? else
????????? if sym = ifsym then (* 如果是if語句 *)
????????? begin
??????????? getsym; (* 獲取一token應是一個邏輯表達式 *)
??????????? condition([thensym, dosym] + fsys); (* 對邏輯表達式進行分析計算,出錯恢復集中加入then和do語句 *)
??????????? if sym = thensym then (* 表達式后應遇到then語句 *)
????????????? getsym (* 獲取then后的token,應是一語句 *)
??????????? else
????????????? error(16); (* 如果if后沒有then,拋出16號錯誤 *)
??????????? cx1 := cx; (* 記下當前代碼分配指針位置 *)
??????????? gen(jpc, 0, 0); (* 生成條件跳轉指令,跳轉位置暫時填0,分析完語句后再填寫 *)
??????????? statement(fsys); (* 分析then后的語句 *)
??????????? code[cx1].a:=cx (* 上一行指令(cx1所指的)的跳轉位置應為當前cx所指位置 *)
????????? end
????????? else
??????????? if sym = beginsym then (* 如果遇到begin *)
??????????? begin
????????????? getsym; (* 獲取下一個token *)
????????????? statement([semicolon, endsym] + fsys);(* 對begin與end之間的語句進行分析處理 *)
????????????? while sym in [semicolon] + statbegsys do (* 如果分析完一句后遇到分號或語句開始符循環分析下一句語句 *)
????????????? begin
??????????????? if sym = semicolon then (* 如果語句是分號(可能是空語句) *)
????????????????? getsym (* 獲取下一token繼續分析 *)
??????????????? else
????????????????? error(10); (* 如果語句與語句間沒有分號,出10號錯 *)
??????????????? statement([semicolon, endsym] + fsys) (* 分析一個語句 *)
????????????? end;
????????????? if sym = endsym then (* 如果語句全分析完了,應該遇到end *)
??????????????? getsym (* 的確是end,讀下一token *)
????????????? else
??????????????? error(17) (* 如果不是end,拋出17號錯 *)
??????????? end
??????????? else
????????????? if sym = whilesym then (* 如果遇到while語句 *)
????????????? begin
??????????????? cx1 := cx; (* 記下當前代碼分配位置,這是while循環的開始位置 *)
??????????????? getsym; (* 獲取下一token,應為一邏輯表達式 *)
??????????????? condition([dosym] + fsys); (* 對這個邏輯表達式進行分析計算 *)
??????????????? cx2 := cx; (* 記下當前代碼分配位置,這是while的do中的語句的開始位置 *)
??????????????? gen(jpc, 0, 0); (* 生成條件跳轉指令,跳轉位置暫時填0 *)
??????????????? if sym = dosym then (* 邏輯表達式后應為do語句 *)
????????????????? getsym (* 獲取下一token *)
??????????????? else
????????????????? error(18); (* if后缺少then,拋出18號錯誤 *)
??????????????? statement(fsys); (* 分析do后的語句塊 *)
??????????????? gen(jmp, 0, cx1); (* 循環跳轉到cx1位置,即再次進行邏輯判斷 *)
??????????????? code[cx2].a := cx (* 把剛才填0的跳轉位置改成當前位置,完成while語句的處理 *)
????????????? end;
??? test(fsys, [], 19) (* 至此一個語句處理完成,一定會遇到fsys集中的符號,如果沒有遇到,就拋19號錯 *)
? end(* statement *);
begin (* block *)
? dx := 3; (* 地址指示器給出每層局部量當前已分配到的相對位置。
????????????? 置初始值為3的原因是:每一層最開始的位置有三個空間用于存放靜態鏈SL、動態鏈DL和返回地址RA *)
? tx0 := tx; (* 初始符號表指針指向當前層的符號在符號表中的開始位置 *)
? table[tx].adr := cx; (* 符號表當前位置記下當前層代碼的開始位置 *)
? gen(jmp, 0, 0); (* 產生一行跳轉指令,跳轉位置暫時未知填0 *)
? if lev > levmax then (* 如果當前過程嵌套層數大于最大允許的套層數 *)
??? error(32); (* 發出32號錯誤 *)
? repeat (* 開始循環處理源程序中所有的聲明部分 *)
??? if sym = constsym then (* 如果當前token是const保留字,開始進行常量聲明 *)
??? begin
????? getsym; (* 獲取下一個token,正常應為用作常量名的標識符 *)
????? repeat (* 反復進行常量聲明 *)
??????? constdeclaration; (* 聲明以當前token為標識符的常量 *)
??????? while sym = comma do (* 如果遇到了逗號則反復聲明下一個常量 *)
??????? begin
????????? getsym; (* 獲取下一個token,這里正好應該是標識符 *)
????????? constdeclaration (* 聲明以當前token為標識符的常量 *)
??????? end;
??????? if sym = semicolon then (* 如果常量聲明結束,應遇到分號 *)
????????? getsym (* 獲取下一個token,為下一輪循環做好準備 *)
??????? else
????????? error(5) (* 如果常量聲明語句結束后沒有遇到分號則發出5號錯誤 *)
????? until sym <> ident (* 如果遇到非標識符,則常量聲明結束 *)
??? end;
??? (* 此處的常量聲明的語法與課本上的EBNF范式有不同之處:
?????? 它可以接受像下面的聲明方法,而根據課本上的EBNF范式不可得出下面的語法:
?????? const a = 3, b = 3; c = 6; d = 7, e = 8;
?????? 即它可以接受分號或逗號隔開的常量聲明,而根據EBNF范式只可接受用逗號隔開的聲明 *)
??? if sym = varsym then (* 如果當前token是var保留字,開始進行變量聲明,與常量聲明類似 *)
??? begin
????? getsym; (* 獲取下一個token,此處正常應為用作變量名的一個標識符 *)
????? repeat (* 反復進行變量聲明 *)
??????? vardeclaration; (* 以當前token為標識符聲明一個變量 *)
??????? while sym = comma do (* 如果遇到了逗號則反復聲明下一個變量 *)
??????? begin
????????? getsym; (* 獲取下一個token,這里正好應該是標識符 *)
????????? vardeclaration; (* 聲明以當前token為標識符的變量 *)
??????? end;
??????? if sym = semicolon then (* 如果變量聲明結束,應遇到分號 *)
????????? getsym (* 獲取下一個token,為下一輪循環做好準備 *)
??????? else
????????? error(5) (* 如果變量聲明語句結束后沒有遇到分號則發出5號錯誤 *)
????? until sym <> ident; (* 如果遇到非標識符,則變量聲明結束 *)
????? (* 這里也存在與上面的常量聲明一樣的毛病:與PL/0的語法規范有沖突。 *)
??? end;
??? while sym = procsym do (* 循環聲明各子過程 *)
??? begin
????? getsym; (* 獲取下一個token,此處正常應為作為過程名的標識符 *)
????? if sym = ident then (* 如果token確為標識符 *)
????? begin
??????? enter(procedur); (* 把這個過程登錄到名字表中 *)
??????? getsym (* 獲取下一個token,正常情況應為分號 *)
????? end
????? else
??????? error(4); (* 否則拋出4號錯誤 *)
????? if sym = semicolon then (* 如果當前token為分號 *)
??????? getsym (* 獲取下一個token,準備進行語法分析的遞歸調用 *)
????? else
??????? error(5); (* 否則拋出5號錯誤 *)
????? block(lev + 1, tx, [semicolon] + fsys); (* 遞歸調用語法分析過程,當前層次加一,同時傳遞表頭索引、合法單詞符 *)
????? if sym = semicolon then (* 遞歸返回后當前token應為遞歸調用時的最后一個end后的分號 *)
????? begin
??????? getsym; (* 獲取下一個token *)
??????? test(statbegsys + [ident, procsym], fsys, 6); (* 檢查當前token是否合法,不合法則用fsys恢復語法分析同時拋6號錯 *)
????? end
????? else
??????? error(5) (* 如果過程聲明后的符號不是分號,拋出5號錯誤 *)
??? end;
??? test(statbegsys + [ident], declbegsys, 7) (* 檢查當前狀態是否合法,不合法則用聲明開始符號作出錯恢復、拋7號錯 *)
? until not (sym in declbegsys); (* 直到聲明性的源程序分析完畢,繼續向下執行,分析主程序 *)
? code[table[tx0].adr].a := cx; (* 把前面生成的跳轉語句的跳轉位置改成當前位置 *)
? with table[tx0] do (* 在符號表中記錄 *)
? begin
??? adr := cx; (* 地址為當前代碼分配地址 *)
??? size := dx; (* 長度為當前數據代分配位置 *)
? end;
? cx0 := cx; (* 記下當前代碼分配位置 *)
? gen(int, 0, dx); (* 生成分配空間指令,分配dx個空間 *)
? statement([semicolon, endsym] + fsys); (* 處理當前遇到的語句或語句塊 *)
? gen(opr, 0, 0); (* 生成從子程序返回操作指令 *)
? test(fsys, [], 8); (* 用fsys檢查當前狀態是否合法,不合法則拋8號錯 *)
? listcode (* 列出本層的類PCODE代碼 *)
end(* block *);
(* PL/0編譯器產生的類PCODE目標代碼解釋運行過程interpret *)
procedure interpret;
const
? stacksize = 500; (* 常量定義,假想的棧式計算機有500個棧單元 *)
var
? p, b, t: integer; (* program base topstack registers *)
? (* p為程序指令指針,指向下一條要運行的代碼 *)
? (* b為基址指針,指向每個過程被調用時數據區中分配給它的局部變量數據段基址 *)
? (* t為棧頂寄存器,類PCODE是在一種假想的棧式計算上運行的,這個變量記錄這個計算機的當前棧頂位置 *)
? i: instruction; (* i變量中存放當前在運行的指令 *)
? s: array[1..stacksize] of integer; (* datastore *) (* s為棧式計算機的數據內存區 *)
? (* 通過靜態鏈求出數據區基地址的函數base *)
? (* 參數說明:l:要求的數據區所在層與當前層的層差 *)
? (* 返回值:要求的數據區基址 *)
? function base(l: integer): integer;
? var
??? b1: integer;
? begin
??? b1 := b; (* find base 1 level down *) (* 首先從當前層開始 *)
??? while l > 0 do (* 如果l大于0,循環通過靜態鏈往前找需要的數據區基址 *)
??? begin
????? b1 := s[b1]; (* 用當前層數據區基址中的內容(正好是靜態鏈SL數據,為上一層的基址)的作為新的當前層,即向上找了一層 *)
????? l := l - 1 (* 向上了一層,l減一 *)
??? end;
??? base := b1 (* 把找到的要求的數據區基址返回 *)
? end(* base *);
begin
? writeln('start pl0'); (* PL/0程序開始運行 *)
? t := 0; (* 程序開始運行時棧頂寄存器置0 *)
? b := 1; (* 數據段基址為1 *)
? p := 0; (* 從0號代碼開始執行程序 *)
? s[1] := 0;
? s[2] := 0;
? s[3] := 0; (* 數據內存中為SL,DL,RA三個單元均為0,標識為主程序 *)
? repeat (* 開始依次運行程序目標代碼 *)
??? i := code[p]; (* 獲取一行目標代碼 *)
??? p := p + 1; (* 指令指針加一,指向下一條代碼 *)
??? with i do
????? case f of (* 如果i的f,即指令助記符是下面的某種情況,執行不同的功能 *)
??????? lit: (* 如果是lit指令 *)
??????? begin
????????? t := t + 1; (* 棧頂指針上移,在棧中分配了一個單元 *)
????????? s[t] := a (* 該單元的內容存放i指令的a操作數,即實現了把常量值放到運行棧棧頂 *)
??????? end;
??????? opr: (* 如果是opr指令 *)
????????? case a of (* operator *) (* 根據a操作數不同,執行不同的操作 *)
??????????? 0: (* 0號操作為從子過程返回操作 *)
??????????? begin (* return *)
????????????? t := b - 1; (* 釋放這段子過程占用的數據內存空間 *)
????????????? p := s[t + 3]; (* 把指令指針取到RA的值,指向的是返回地址 *)
????????????? b := s[t + 2] (* 把數據段基址取到DL的值,指向調用前子過程的數據段基址 *)
??????????? end;
??????????? 1: (* 1號操作為棧頂數據取反操作 *)
????????????? s[t] := -s[t]; (* 對棧頂數據進行取反 *)
??????????? 2: (* 2號操作為棧頂兩個數據加法操作 *)
??????????? begin
????????????? t := t - 1; (* 棧頂指針下移 *)
????????????? s[t] := s[t] + s[t + 1] (* 把兩單元數據相加存入棧頂 *)
??????????? end;
??????????? 3: (* 3號操作為棧頂兩個數據減法操作 *)
??????????? begin
????????????? t := t - 1; (* 棧頂指針下移 *)
????????????? s[t] := s[t] - s[t + 1] (* 把兩單元數據相減存入棧頂 *)
??????????? end;
??????????? 4: (* 4號操作為棧頂兩個數據乘法操作 *)
??????????? begin
????????????? t := t - 1; (* 棧頂指針下移 *)
????????????? s[t] := s[t] * s[t + 1] (* 把兩單元數據相乘存入棧頂 *)
??????????? end;
??????????? 5: (* 5號操作為棧頂兩個數據除法操作 *)
??????????? begin
????????????? t := t - 1; (* 棧頂指針下移 *)
????????????? s[t] := s[t] div s[t + 1] (* 把兩單元數據相整除存入棧頂 *)
??????????? end;
??????????? 6: (* 6號操作為判奇操作 *)
????????????? s[t] := ord(odd(s[t])); (* 數據棧頂的值是奇數則把棧頂值置1,否則置0 *)
??????????? 8: (* 8號操作為棧頂兩個數據判等操作 *)
??????????? begin
????????????? t := t - 1; (* 棧頂指針下移 *)
????????????? s[t] := ord(s[t] = s[t + 1]) (* 判等,相等棧頂置1,不等置0 *)
??????????? end;
??????????? 9: (* 9號操作為棧頂兩個數據判不等操作 *)
??????????? begin
????????????? t := t - 1; (* 棧頂指針下移 *)
????????????? s[t] := ord(s[t] <> s[t + 1]) (* 判不等,不等棧頂置1,相等置0 *)
??????????? end;
??????????? 10: (* 10號操作為棧頂兩個數據判小于操作 *)
??????????? begin
????????????? t := t - 1; (* 棧頂指針下移 *)
????????????? s[t] := ord(s[t] < s[t + 1]) (* 判小于,如果下面的值小于上面的值,棧頂置1,否則置0 *)
??????????? end;
??????????? 11: (* 11號操作為棧頂兩個數據判大于等于操作 *)
??????????? begin
????????????? t := t - 1; (* 棧頂指針下移 *)
????????????? s[t] := ord(s[t] >= s[t + 1]) (* 判大于等于,如果下面的值大于等于上面的值,棧頂置1,否則置0 *)
??????????? end;
??????????? 12: (* 12號操作為棧頂兩個數據判大于操作 *)
??????????? begin
????????????? t := t - 1; (* 棧頂指針下移 *)
????????????? s[t] := ord(s[t] > s[t + 1]) (* 判大于,如果下面的值大于上面的值,棧頂置1,否則置0 *)
??????????? end;
??????????? 13: (* 13號操作為棧頂兩個數據判小于等于操作 *)
??????????? begin
????????????? t := t - 1; (* 棧頂指針下移 *)
????????????? s[t] := ord(s[t] <= s[t + 1]) (* 判小于等于,如果下面的值小于等于上面的值,棧頂置1,否則置0 *)
??????????? end;
??????????? 14: (* 14號操作為輸出棧頂值操作 *)
??????????? begin
????????????? write(s[t]); (* 輸出棧頂值 *)
????????????? write(fa2, s[t]); (* 同時打印到文件 *)
????????????? t := t - 1 (* 棧頂下移 *)
??????????? end;
??????????? 15: (* 15號操作為輸出換行操作 *)
??????????? begin
????????????? writeln; (* 輸出換行 *)
????????????? writeln(fa2) (* 同時輸出到文件 *)
??????????? end;
??????????? 16: (* 16號操作是接受鍵盤值輸入到棧頂 *)
??????????? begin
????????????? t := t + 1; (* 棧頂上移,分配空間 *)
????????????? write('?'); (* 屏顯問號 *)
????????????? write(fa2, '?'); (* 同時輸出到文件 *)
????????????? readln(s[t]); (* 獲得輸入 *)
????????????? writeln(fa2, s[t]); (* 把用戶輸入值打印到文件 *)
??????????? end;
????????? end; (* opr指令分析運行結束 *)
??????? lod: (* 如果是lod指令:將變量放到棧頂 *)
??????? begin
????????? t := t + 1; (* 棧頂上移,開辟空間 *)
????????? s[t] := s[base(l) + a] (* 通過數據區層差l和偏移地址a找到變量的數據,存入上面開辟的新空間(即棧頂) *)
??????? end;
??????? sto: (* 如果是sto指令 *)
??????? begin
????????? s[base(l) + a] := s[t]; (* 把棧頂的值存入位置在數據區層差l偏移地址a的變量內存 *)
????????? t := t - 1 (* 棧項下移,釋放空間 *)
??????? end;
??????? cal: (* 如果是cal指令 *)
??????? begin (* generat new block mark *)
????????? s[t + 1] := base(l); (* 在棧頂壓入靜態鏈SL *)
????????? s[t + 2] := b; (* 然后壓入當前數據區基址,作為動態鏈DL *)
????????? s[t + 3] := p; (* 最后壓入當前的斷點,作為返回地址RA *)
????????? (* 以上的工作即為過程調用前的保護現場 *)
????????? b := t + 1; (* 把當前數據區基址指向SL所在位置 *)
????????? p := a; (* 從a所指位置開始繼續執行指令,即實現了程序執行的跳轉 *)
??????? end;
??????? int: (* 如果是int指令 *)
????????? t := t + a; (* 棧頂上移a個空間,即開辟a個新的內存單元 *)
??????? jmp: (* 如果是jmp指令 *)
????????? p := a; (* 把jmp指令操作數a的值作為下一次要執行的指令地址,實現無條件跳轉 *)
??????? jpc: (* 如果是jpc指令 *)
??????? begin
????????? if s[t] = 0 then (* 判斷棧頂值 *)
??????????? p := a; (* 如果是0就跳轉,否則不跳轉 *)
????????? t := t - 1 (* 釋放棧頂空間 *)
??????? end;
????? end(* with,case *)
? until p = 0; (* 如果p等于0,意味著在主程序運行時遇到了從子程序返回指令,也就是整個程序運行的結束 *)
? close(fa2) (* 關閉用于記錄屏幕輸入輸出的fa2文件 *)
? (* PCODE代碼的解釋執行過程結束 *)
end(* interpret *);
begin (* main *)
? for ch := ' ' to '!' do (* 這個循環把ssym數組全部填nul *)
??? ssym[ch] := nul;
? (* changed because of different character set
? note the typos below in the original where
? the alfas were not given the correct space *)
? (* 下面初始化保留字表,保留字長度不到10個字符的,多余位置用空格填充,便于詞法分析時以二分法來查找保留字 *)
? word[1] := 'begin???? ';
? word[2] := 'call????? ';
? word[3] := 'const???? ';
? word[4] := 'do??????? ';
? word[5] := 'end?????? ';
? word[6] := 'if??????? ';
? word[7] := 'odd?????? ';
? word[8] := 'procedure ';
? word[9] := 'read????? ';
? word[10] := 'then????? ';
? word[11] := 'var?????? ';
? word[12] := 'while???? ';
? word[13] := 'write???? ';
? (* 保留字符號列表,在上面的保留字表中找到保留字后可以本表中相應位置該保留字的類型 *)
? wsym[1] := beginsym;
? wsym[2] := callsym;
? wsym[3] := constsym;
? wsym[4] := dosym;
? wsym[5] := endsym;
? wsym[6] := ifsym;
? wsym[7] := oddsym;
? wsym[8] := procsym;
? wsym[9] := readsym;
? wsym[10] := thensym;
? wsym[11] := varsym;
? wsym[12] := whilesym;
? wsym[13] := writesym;
? (* 初始化符號表,把可能出現的符號賦上相應的類型,其余符號由于開始處的循環所賦的類型均為nul *)
? ssym['+'] := plus;
? ssym['-'] := minus;
? ssym['*'] := times;
? ssym['/'] := slash;
? ssym['('] := lparen;
? ssym[')'] := rparen;
? ssym['='] := eql;
? ssym[','] := comma;
? ssym['.'] := period;
? ssym['#'] := neq;
? ssym[';'] := semicolon;
? (* 初始化類PCODE助記符表,這個表主要供輸出類PCODE代碼之用 *)
? mnemonic[lit] := ' lit ';
? mnemonic[opr] := ' opr ';
? mnemonic[lod] := ' lod ';
? mnemonic[sto] := ' sto ';
? mnemonic[cal] := ' cal ';
? mnemonic[int] := ' int ';
? mnemonic[jmp] := ' jmp ';
? mnemonic[jpc] := ' jpc ';
? (* 我修改的代碼:書上此處均為'xxx? '形式,即助記符后兩個空格,通過上網查詢原版程序確認為助詞符前后各一空格。 *)
? (* 這樣改的目的是使后面的輸出結果比較美觀 *)
? declbegsys := [constsym, varsym, procsym];
? statbegsys := [beginsym, callsym, ifsym, whilesym];
? facbegsys := [ident, number, lparen];
? (* page(output) *)
? (* 由于Turbo Pascal 7.0的文本文件處理方法與源程序中使用的方法有很大不同,因此下面的有關文件處理的代碼進行了不少更改。 *)
? assign(fa1, 'fa1.txt'); (* 把文本文件fa1與fa1.txt文件關聯起來,用于輸出生成的類PCODE代碼 *)
? rewrite(fa1); (* 建立并打開fa1.txt文件 *)
? write('input file?? '); (* 提示輸入PL/0源程序名 *)
? write(fa1, 'input file? '); (* 同樣的提示輸出到fa1.txt文件 *)
? readln(fname); (* 獲得鍵盤輸入的文件名 *)
? writeln(fa1, fname); (* 把鍵盤輸入打印到fa1.txt文件 *)
? {openf(fin,fname,'r');}
? assign(fin, fname); (* 把PL/0的源程序文件與fin關聯 *)
? reset(fin); (* 打開fin所關聯的PL/0源程序文件 *)
? write('list object code ?'); (* 提示是否要列出類PCODE代碼 *)
? readln(fname); (* 獲得用戶輸入 *)
? write(fa1, 'list object code ?'); (* 同樣的提示寫到fa1.txt文件中 *)
? listswitch := (fname[1] = 'y'); (* 如果輸入'y'開頭的字符串,把listswitch標志置true,否則為false *)
? err := 0; (* 出錯次數置0 *)
? cc := 0; (* 詞法分析行緩沖區指針置0 *)
? cx := 0; (* 類PCODE代碼表指針置0 *)
? ll := 0; (* 詞法分析行緩沖區長度置0 *)
? ch := ' '; (* 詞法分析當前字符為空格 *)
? kk := al; (* 置kk的值為允許的標識符的最長長度,具體用意見getsym過程注釋 *)
? assign(fa, 'fa.txt'); (* 把fa.txt與fa關聯。fa用于輸出源程序 *)
? rewrite(fa); (* 建立并打開fa.txt *)
? getsym; (* 首次調用詞法分析子程序,獲取源程序的第一個詞(token) *)
? block(0, 0, [period] + declbegsys + statbegsys); (* 開始進行主程序(也就是第一個分程序)的語法分析 *)
? (* 主程序所在層為0層,符號表暫時為空,符號表指針指0號位置 *)
? close(fa); (* 關閉文件 *)
? close(fa1); (* 關閉文件 *)
? if sym <> period then (* 主程序分析結束,應遇到表明程序結束的句號 *)
??? error(9); (* 如果不是句號,出現9號錯誤 *)
? (* 以上可知,一個合法的PL/0源程序應由分程序和句號構成。 *)
? if err = 0 then (* 如果出錯次數為0,可以開始解釋執行編譯產生的代碼 *)
? begin
??? assign(fa2, 'fa2.txt'); (* 把文本文件fa2與fa2.txt文件關聯起來,用于輸出類PCODE代碼運行結果 *)
??? rewrite(fa2); (* 建立并打開fa2文件 *)
??? interpret (* 開始解釋執行類PCODE代碼 *)
? end
? else
??? write('errors in pl/0 program'); (* 如果有錯誤,提示程序有錯誤 *)
? 99: (* 這個標號原來是用于退出程序的,由于Turbo Pascal不支持跨過程的跳轉,因此這里這個標號也沒用了。 *)
? {closef(fin);}
? close(fin); (* 關閉源程序文件 *)
? writeln
end.
************************************************************************

本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/lifanxi/archive/2002/08/15/3833.aspx

總結

以上是生活随笔為你收集整理的PL/0语言编译程序分析的全部內容,希望文章能夠幫你解決所遇到的問題。

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

国产农村妇女高潮大叫 | 天下第一社区视频www日本 | 牲欲强的熟妇农村老妇女 | 麻豆国产97在线 | 欧洲 | 粗大的内捧猛烈进出视频 | 中文字幕乱码中文乱码51精品 | 成人性做爰aaa片免费看不忠 | 日韩精品a片一区二区三区妖精 | 日韩欧美成人免费观看 | 东京热无码av男人的天堂 | 国产sm调教视频在线观看 | 无码福利日韩神码福利片 | 在线播放无码字幕亚洲 | 鲁大师影院在线观看 | 亚欧洲精品在线视频免费观看 | 色狠狠av一区二区三区 | 国内精品久久久久久中文字幕 | 久9re热视频这里只有精品 | 成人亚洲精品久久久久 | 国产高清不卡无码视频 | 日本www一道久久久免费榴莲 | 亚洲 另类 在线 欧美 制服 | 国产成人午夜福利在线播放 | 亚洲精品成人福利网站 | 亚洲日韩乱码中文无码蜜桃臀网站 | 一本大道久久东京热无码av | 鲁一鲁av2019在线 | 无码精品人妻一区二区三区av | 亚洲精品一区二区三区在线观看 | 黄网在线观看免费网站 | 女人高潮内射99精品 | 国产亚洲精品久久久久久大师 | 国产成人精品优优av | 综合激情五月综合激情五月激情1 | 日韩人妻系列无码专区 | 中文字幕av无码一区二区三区电影 | 亚洲а∨天堂久久精品2021 | 亚洲日韩中文字幕在线播放 | 窝窝午夜理论片影院 | 日本熟妇浓毛 | 人人妻人人澡人人爽欧美一区九九 | 日韩精品乱码av一区二区 | 妺妺窝人体色www婷婷 | 少妇无套内谢久久久久 | 亚洲精品综合一区二区三区在线 | 红桃av一区二区三区在线无码av | 2020久久超碰国产精品最新 | 欧美怡红院免费全部视频 | 欧美zoozzooz性欧美 | a国产一区二区免费入口 | 精品国产一区av天美传媒 | 九月婷婷人人澡人人添人人爽 | 一个人看的www免费视频在线观看 | 国产精品亚洲一区二区三区喷水 | 嫩b人妻精品一区二区三区 | 日韩精品一区二区av在线 | 中文无码精品a∨在线观看不卡 | 色噜噜亚洲男人的天堂 | 国产熟妇高潮叫床视频播放 | √天堂中文官网8在线 | 性生交大片免费看女人按摩摩 | 伊在人天堂亚洲香蕉精品区 | 亚洲精品中文字幕 | 美女扒开屁股让男人桶 | 巨爆乳无码视频在线观看 | 国产97色在线 | 免 | 婷婷六月久久综合丁香 | 欧美人妻一区二区三区 | 亚洲色欲久久久综合网东京热 | 无码人妻精品一区二区三区下载 | 女高中生第一次破苞av | 乱人伦人妻中文字幕无码久久网 | 亚洲综合另类小说色区 | 丝袜 中出 制服 人妻 美腿 | 久久精品中文字幕一区 | 欧美人与动性行为视频 | 国内精品人妻无码久久久影院蜜桃 | 三上悠亚人妻中文字幕在线 | 帮老师解开蕾丝奶罩吸乳网站 | 欧美精品无码一区二区三区 | 中文字幕 亚洲精品 第1页 | 精品人人妻人人澡人人爽人人 | 国产电影无码午夜在线播放 | 亚洲成a人片在线观看日本 | 国产熟女一区二区三区四区五区 | 人妻天天爽夜夜爽一区二区 | 色婷婷香蕉在线一区二区 | 国产精品99久久精品爆乳 | 成人性做爰aaa片免费看不忠 | 亚洲精品一区二区三区四区五区 | 精品国产一区二区三区四区在线看 | 牲欲强的熟妇农村老妇女视频 | 国产97色在线 | 免 | 天天摸天天碰天天添 | 久久无码中文字幕免费影院蜜桃 | 日韩欧美群交p片內射中文 | 真人与拘做受免费视频 | 小sao货水好多真紧h无码视频 | 2020最新国产自产精品 | 久久国产自偷自偷免费一区调 | 亚洲色欲色欲天天天www | 18禁黄网站男男禁片免费观看 | 人人妻人人澡人人爽欧美一区九九 | 日韩视频 中文字幕 视频一区 | 国产成人午夜福利在线播放 | 国产精品久久久久久亚洲影视内衣 | 欧美成人午夜精品久久久 | 无码帝国www无码专区色综合 | 久久久久国色av免费观看性色 | 国产亚洲精品精品国产亚洲综合 | 欧美精品无码一区二区三区 | 午夜无码人妻av大片色欲 | 久久伊人色av天堂九九小黄鸭 | 特黄特色大片免费播放器图片 | 亚洲熟妇自偷自拍另类 | 国产热a欧美热a在线视频 | 无码国内精品人妻少妇 | 国产精品久久久久无码av色戒 | 丁香啪啪综合成人亚洲 | 沈阳熟女露脸对白视频 | 亚洲aⅴ无码成人网站国产app | yw尤物av无码国产在线观看 | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲精品午夜无码电影网 | 亚洲中文字幕无码一久久区 | 熟妇女人妻丰满少妇中文字幕 | 乱码av麻豆丝袜熟女系列 | 久久久婷婷五月亚洲97号色 | 亚洲精品无码人妻无码 | 亚洲日韩av一区二区三区四区 | 亚洲人成网站色7799 | 国产成人精品一区二区在线小狼 | 久久亚洲精品成人无码 | 国产成人无码av在线影院 | 亚洲欧美国产精品久久 | 久久国产36精品色熟妇 | 国内揄拍国内精品人妻 | 久久无码专区国产精品s | 亲嘴扒胸摸屁股激烈网站 | 久久午夜夜伦鲁鲁片无码免费 | 大地资源网第二页免费观看 | 日韩成人一区二区三区在线观看 | 久久久久av无码免费网 | 香港三级日本三级妇三级 | 综合人妻久久一区二区精品 | 天天摸天天透天天添 | 无码人妻久久一区二区三区不卡 | 亚洲区小说区激情区图片区 | 久久久无码中文字幕久... | 国产真实伦对白全集 | 一本色道久久综合亚洲精品不卡 | 亚洲精品美女久久久久久久 | 国产精品毛多多水多 | 亚洲国产欧美在线成人 | 人人爽人人爽人人片av亚洲 | 蜜臀aⅴ国产精品久久久国产老师 | 无码国模国产在线观看 | 两性色午夜视频免费播放 | 日韩人妻无码一区二区三区久久99 | 无码人妻丰满熟妇区五十路百度 | 久久无码中文字幕免费影院蜜桃 | 久久精品视频在线看15 | 亚洲综合精品香蕉久久网 | 欧美 亚洲 国产 另类 | 狂野欧美激情性xxxx | 牲交欧美兽交欧美 | 樱花草在线播放免费中文 | 天堂亚洲2017在线观看 | 欧美性生交xxxxx久久久 | 亚洲精品一区国产 | 最近免费中文字幕中文高清百度 | 国产尤物精品视频 | 少妇愉情理伦片bd | 精品人妻av区 | 国产精品美女久久久 | 国产精品沙发午睡系列 | 日本丰满熟妇videos | 欧美日韩一区二区三区自拍 | 草草网站影院白丝内射 | 亚洲色大成网站www | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产av无码专区亚洲a∨毛片 | 99久久精品无码一区二区毛片 | 免费国产成人高清在线观看网站 | 成人精品视频一区二区三区尤物 | 骚片av蜜桃精品一区 | 中文精品无码中文字幕无码专区 | 天天综合网天天综合色 | 狠狠色丁香久久婷婷综合五月 | www国产亚洲精品久久久日本 | 5858s亚洲色大成网站www | 亚洲精品午夜无码电影网 | 国产乱人偷精品人妻a片 | 日韩精品无码免费一区二区三区 | 久久久久久av无码免费看大片 | 欧美人与牲动交xxxx | а天堂中文在线官网 | 国产成人无码av一区二区 | 一区二区传媒有限公司 | 中文字幕人妻无码一区二区三区 | 六十路熟妇乱子伦 | 99久久精品无码一区二区毛片 | 亚洲精品久久久久久一区二区 | 99久久久无码国产aaa精品 | 99久久精品午夜一区二区 | 成人性做爰aaa片免费看 | 欧美放荡的少妇 | 人人超人人超碰超国产 | 国产日产欧产精品精品app | 欧美丰满熟妇xxxx性ppx人交 | 性开放的女人aaa片 | 97夜夜澡人人双人人人喊 | 兔费看少妇性l交大片免费 | 伊人久久大香线蕉亚洲 | 亚洲熟悉妇女xxx妇女av | 日本护士毛茸茸高潮 | 波多野42部无码喷潮在线 | 人妻人人添人妻人人爱 | 99久久99久久免费精品蜜桃 | 成人片黄网站色大片免费观看 | 影音先锋中文字幕无码 | 成人精品视频一区二区 | 色五月五月丁香亚洲综合网 | 性色欲网站人妻丰满中文久久不卡 | 国产成人精品一区二区在线小狼 | 欧美三级a做爰在线观看 | 亚洲中文字幕va福利 | 久久亚洲精品成人无码 | 亚洲爆乳精品无码一区二区三区 | 久久久久国色av免费观看性色 | 在线观看国产一区二区三区 | 大乳丰满人妻中文字幕日本 | 久久久久亚洲精品中文字幕 | 国产午夜福利亚洲第一 | 亚洲 a v无 码免 费 成 人 a v | 久久伊人色av天堂九九小黄鸭 | 国产无遮挡又黄又爽又色 | 国产精品无码久久av | 美女扒开屁股让男人桶 | 精品 日韩 国产 欧美 视频 | 又黄又爽又色的视频 | 性欧美牲交xxxxx视频 | 日韩成人一区二区三区在线观看 | 久久精品国产一区二区三区 | 无码国产乱人伦偷精品视频 | 无码国产乱人伦偷精品视频 | 久久国产自偷自偷免费一区调 | 日韩 欧美 动漫 国产 制服 | 麻豆国产97在线 | 欧洲 | 久久综合久久自在自线精品自 | 亚洲国产精华液网站w | 老司机亚洲精品影院无码 | 少女韩国电视剧在线观看完整 | 精品国产av色一区二区深夜久久 | 自拍偷自拍亚洲精品10p | 免费中文字幕日韩欧美 | 性史性农村dvd毛片 | 爆乳一区二区三区无码 | 成人无码视频在线观看网站 | 亚洲国产精品无码一区二区三区 | 欧美日本免费一区二区三区 | 色综合久久久久综合一本到桃花网 | 俺去俺来也在线www色官网 | 欧美一区二区三区 | 国产猛烈高潮尖叫视频免费 | 人妻互换免费中文字幕 | 亚洲一区av无码专区在线观看 | 亚洲熟妇色xxxxx欧美老妇y | 大色综合色综合网站 | 特级做a爰片毛片免费69 | 国产极品视觉盛宴 | 少妇太爽了在线观看 | 欧美高清在线精品一区 | www国产亚洲精品久久久日本 | 无码一区二区三区在线观看 | 国产内射爽爽大片视频社区在线 | 美女极度色诱视频国产 | 亚洲中文字幕在线观看 | 免费人成在线观看网站 | 97久久超碰中文字幕 | 久久综合香蕉国产蜜臀av | 亚洲春色在线视频 | 亚洲日韩精品欧美一区二区 | 亚洲精品一区二区三区四区五区 | 亚洲熟妇自偷自拍另类 | 国产精品毛片一区二区 | 中文字幕中文有码在线 | 内射巨臀欧美在线视频 | 老熟妇乱子伦牲交视频 | 99麻豆久久久国产精品免费 | 国产亚洲精品久久久久久久久动漫 | 精品亚洲成av人在线观看 | 国产三级精品三级男人的天堂 | 久久国产精品精品国产色婷婷 | 丰满少妇高潮惨叫视频 | 欧美性黑人极品hd | 久久久久亚洲精品中文字幕 | 精品偷自拍另类在线观看 | 亚洲自偷精品视频自拍 | 日韩av无码一区二区三区不卡 | 国产精品无码一区二区三区不卡 | 国产va免费精品观看 | 亚洲の无码国产の无码影院 | 97无码免费人妻超级碰碰夜夜 | 国产无av码在线观看 | 欧美成人免费全部网站 | 亚洲国产精品美女久久久久 | 中文字幕乱码亚洲无线三区 | 亚洲综合伊人久久大杳蕉 | 人妻无码久久精品人妻 | 亚洲男人av香蕉爽爽爽爽 | 久久综合给久久狠狠97色 | 少妇无套内谢久久久久 | 日韩人妻无码一区二区三区久久99 | 国产欧美熟妇另类久久久 | 国产激情精品一区二区三区 | 欧美 亚洲 国产 另类 | 夜夜高潮次次欢爽av女 | 国产成人精品三级麻豆 | 中文字幕人妻丝袜二区 | 红桃av一区二区三区在线无码av | 疯狂三人交性欧美 | 久久99精品久久久久久动态图 | 兔费看少妇性l交大片免费 | 亚洲经典千人经典日产 | 亚洲精品成人av在线 | 久久综合给合久久狠狠狠97色 | 亚洲欧美中文字幕5发布 | 水蜜桃色314在线观看 | 中文字幕乱码亚洲无线三区 | 欧美喷潮久久久xxxxx | 人人妻人人澡人人爽欧美一区九九 | 久久亚洲精品成人无码 | 国产成人av免费观看 | 色综合久久久无码中文字幕 | 日本一卡2卡3卡四卡精品网站 | 蜜臀aⅴ国产精品久久久国产老师 | 国产亚洲美女精品久久久2020 | 欧美黑人性暴力猛交喷水 | 麻豆国产97在线 | 欧洲 | 3d动漫精品啪啪一区二区中 | 成人一区二区免费视频 | 免费人成在线视频无码 | а天堂中文在线官网 | 扒开双腿疯狂进出爽爽爽视频 | 成人性做爰aaa片免费看 | 少妇性荡欲午夜性开放视频剧场 | 岛国片人妻三上悠亚 | 精品人妻av区 | 成熟人妻av无码专区 | 久精品国产欧美亚洲色aⅴ大片 | 日韩精品乱码av一区二区 | 波多野结衣av在线观看 | 久久综合色之久久综合 | 曰韩少妇内射免费播放 | 高清国产亚洲精品自在久久 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 亚洲娇小与黑人巨大交 | 高潮毛片无遮挡高清免费视频 | 奇米影视888欧美在线观看 | 亚洲春色在线视频 | 欧美成人午夜精品久久久 | 少妇久久久久久人妻无码 | 久精品国产欧美亚洲色aⅴ大片 | 亚洲一区二区三区国产精华液 | 娇妻被黑人粗大高潮白浆 | 久久久婷婷五月亚洲97号色 | 久久zyz资源站无码中文动漫 | 精品乱子伦一区二区三区 | 欧美一区二区三区视频在线观看 | 中文字幕av日韩精品一区二区 | 国产在线精品一区二区高清不卡 | 日本护士xxxxhd少妇 | 暴力强奷在线播放无码 | 久久久成人毛片无码 | 水蜜桃亚洲一二三四在线 | 色窝窝无码一区二区三区色欲 | 综合网日日天干夜夜久久 | 国产人妻人伦精品1国产丝袜 | 色婷婷综合中文久久一本 | 日韩欧美中文字幕公布 | 精品aⅴ一区二区三区 | 亚洲国产精品久久人人爱 | 在线天堂新版最新版在线8 | 国产偷抇久久精品a片69 | 无码一区二区三区在线观看 | 亚洲七七久久桃花影院 | 丰满少妇熟乱xxxxx视频 | 在线播放无码字幕亚洲 | 无码帝国www无码专区色综合 | 性生交大片免费看l | 影音先锋中文字幕无码 | 成人综合网亚洲伊人 | 综合激情五月综合激情五月激情1 | 成人女人看片免费视频放人 | 欧美熟妇另类久久久久久多毛 | 久久亚洲a片com人成 | 国产精品99爱免费视频 | 伦伦影院午夜理论片 | 领导边摸边吃奶边做爽在线观看 | 精品一区二区三区无码免费视频 | 亚洲中文字幕乱码av波多ji | 丰满少妇弄高潮了www | 亚洲人成人无码网www国产 | 中文字幕无码免费久久9一区9 | 国产无套内射久久久国产 | 日本丰满护士爆乳xxxx | 国产精品va在线观看无码 | 俄罗斯老熟妇色xxxx | 久久天天躁夜夜躁狠狠 | 日日干夜夜干 | 少妇性l交大片欧洲热妇乱xxx | 狠狠噜狠狠狠狠丁香五月 | 亚洲欧美日韩成人高清在线一区 | 亚洲国产av精品一区二区蜜芽 | 亚洲国产精品久久久天堂 | 香港三级日本三级妇三级 | 精品无码国产自产拍在线观看蜜 | 成人免费视频视频在线观看 免费 | 六月丁香婷婷色狠狠久久 | 国产成人无码a区在线观看视频app | 亚洲欧美国产精品专区久久 | 久9re热视频这里只有精品 | 日本大香伊一区二区三区 | 成人精品一区二区三区中文字幕 | 久久精品视频在线看15 | 999久久久国产精品消防器材 | 亚洲成色www久久网站 | 嫩b人妻精品一区二区三区 | 一本久道高清无码视频 | 国产成人综合在线女婷五月99播放 | 无码国内精品人妻少妇 | 麻豆精品国产精华精华液好用吗 | 欧美国产日产一区二区 | 蜜臀av无码人妻精品 | 成人欧美一区二区三区 | 久热国产vs视频在线观看 | 久久成人a毛片免费观看网站 | 欧美精品免费观看二区 | 未满小14洗澡无码视频网站 | 国产人妖乱国产精品人妖 | 成人三级无码视频在线观看 | 亚洲综合色区中文字幕 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 亚洲中文字幕成人无码 | 扒开双腿吃奶呻吟做受视频 | 日本熟妇乱子伦xxxx | 麻花豆传媒剧国产免费mv在线 | 全黄性性激高免费视频 | 熟女俱乐部五十路六十路av | 精品亚洲韩国一区二区三区 | 51国偷自产一区二区三区 | 又粗又大又硬毛片免费看 | 欧美老熟妇乱xxxxx | 色窝窝无码一区二区三区色欲 | 国产精品手机免费 | 中文字幕无码热在线视频 | 中文字幕人妻丝袜二区 | 无码一区二区三区在线 | 人人澡人人妻人人爽人人蜜桃 | 国内少妇偷人精品视频免费 | 色欲久久久天天天综合网精品 | 无套内谢老熟女 | 成人无码精品一区二区三区 | 香蕉久久久久久av成人 | 中文字幕无码av激情不卡 | 国产午夜福利亚洲第一 | 国产凸凹视频一区二区 | 内射爽无广熟女亚洲 | 国产成人精品必看 | 天天做天天爱天天爽综合网 | 久久人人爽人人人人片 | 国产黄在线观看免费观看不卡 | 久久久久成人精品免费播放动漫 | 亚洲综合在线一区二区三区 | 高清国产亚洲精品自在久久 | 无码任你躁久久久久久久 | 亚洲午夜福利在线观看 | 蜜臀av无码人妻精品 | 成人免费视频一区二区 | 亚洲国产精品毛片av不卡在线 | 精品无码一区二区三区爱欲 | 欧美自拍另类欧美综合图片区 | a在线亚洲男人的天堂 | 天海翼激烈高潮到腰振不止 | 伊人色综合久久天天小片 | 精品熟女少妇av免费观看 | 日韩 欧美 动漫 国产 制服 | 久久综合九色综合欧美狠狠 | 色综合久久久无码中文字幕 | 日韩亚洲欧美精品综合 | 亚洲男人av天堂午夜在 | 在线观看免费人成视频 | 精品成在人线av无码免费看 | 荫蒂添的好舒服视频囗交 | 欧美日韩久久久精品a片 | 国产精品无码成人午夜电影 | 久久国产劲爆∧v内射 | 中文字幕 人妻熟女 | 国产精品无码久久av | 国产成人无码av一区二区 | 国产精品国产三级国产专播 | 亚洲乱码日产精品bd | 亚洲の无码国产の无码影院 | 久久久久久a亚洲欧洲av冫 | 男人扒开女人内裤强吻桶进去 | 国产精品无码一区二区三区不卡 | 麻豆国产人妻欲求不满 | 国产农村乱对白刺激视频 | 国产午夜无码精品免费看 | 无码精品人妻一区二区三区av | 中文字幕无码日韩欧毛 | 76少妇精品导航 | 综合网日日天干夜夜久久 | 美女扒开屁股让男人桶 | 国产又爽又黄又刺激的视频 | 亚洲爆乳无码专区 | 国产精品久久久一区二区三区 | 婷婷五月综合激情中文字幕 | 激情内射日本一区二区三区 | 精品人妻人人做人人爽夜夜爽 | 国产性生大片免费观看性 | 国产一区二区不卡老阿姨 | 啦啦啦www在线观看免费视频 | 亚洲男人av香蕉爽爽爽爽 | 亚洲精品久久久久中文第一幕 | 亚洲成av人片在线观看无码不卡 | 国产精品久久久久影院嫩草 | 动漫av一区二区在线观看 | 老头边吃奶边弄进去呻吟 | 国产三级精品三级男人的天堂 | 十八禁真人啪啪免费网站 | 国产精品理论片在线观看 | 成在人线av无码免观看麻豆 | 欧美国产日产一区二区 | 精品人妻人人做人人爽夜夜爽 | 男人扒开女人内裤强吻桶进去 | 国产精品久久国产精品99 | 国产suv精品一区二区五 | 久久久中文字幕日本无吗 | 澳门永久av免费网站 | 九九综合va免费看 | 乱码av麻豆丝袜熟女系列 | 欧美三级不卡在线观看 | 搡女人真爽免费视频大全 | 欧美野外疯狂做受xxxx高潮 | 天堂无码人妻精品一区二区三区 | 99国产精品白浆在线观看免费 | 日韩欧美群交p片內射中文 | 久久久久99精品成人片 | 亚洲日本在线电影 | 免费中文字幕日韩欧美 | 伊在人天堂亚洲香蕉精品区 | 国产精品久久久午夜夜伦鲁鲁 | 国产又爽又猛又粗的视频a片 | 国产精品嫩草久久久久 | 久久久婷婷五月亚洲97号色 | 乱码av麻豆丝袜熟女系列 | 熟女体下毛毛黑森林 | 又湿又紧又大又爽a视频国产 | 少妇厨房愉情理9仑片视频 | 国产猛烈高潮尖叫视频免费 | 国产在线精品一区二区三区直播 | 人人妻人人澡人人爽欧美精品 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 日本大乳高潮视频在线观看 | 天堂а√在线地址中文在线 | 无码人妻精品一区二区三区下载 | 亚洲理论电影在线观看 | 一二三四社区在线中文视频 | 久久精品中文闷骚内射 | 精品国产乱码久久久久乱码 | 精品aⅴ一区二区三区 | 精品久久久无码中文字幕 | 久久综合给久久狠狠97色 | 欧美老妇与禽交 | 沈阳熟女露脸对白视频 | 亚洲国产欧美在线成人 | 欧美激情内射喷水高潮 | 国内精品久久毛片一区二区 | 成熟妇人a片免费看网站 | 亚洲国产精品毛片av不卡在线 | 乱人伦人妻中文字幕无码久久网 | 日本护士xxxxhd少妇 | 久久久久久a亚洲欧洲av冫 | 无码av免费一区二区三区试看 | 色五月五月丁香亚洲综合网 | 国产三级久久久精品麻豆三级 | 在线 国产 欧美 亚洲 天堂 | 亚洲s色大片在线观看 | 娇妻被黑人粗大高潮白浆 | 成人精品一区二区三区中文字幕 | 少妇厨房愉情理9仑片视频 | 99久久精品午夜一区二区 | 黑人大群体交免费视频 | 欧美精品在线观看 | 国产女主播喷水视频在线观看 | 国产色在线 | 国产 | 牲交欧美兽交欧美 | 人妻无码久久精品人妻 | 欧美喷潮久久久xxxxx | 图片区 小说区 区 亚洲五月 | 欧美丰满少妇xxxx性 | 欧美亚洲国产一区二区三区 | 精品午夜福利在线观看 | 精品少妇爆乳无码av无码专区 | 丰满少妇熟乱xxxxx视频 | 欧洲熟妇色 欧美 | 久久99久久99精品中文字幕 | 亚洲精品一区二区三区在线 | 亚洲中文字幕无码中字 | 一本无码人妻在中文字幕免费 | 久久久www成人免费毛片 | 少妇厨房愉情理9仑片视频 | 成年美女黄网站色大免费视频 | 中文字幕人妻无码一区二区三区 | 中文字幕 亚洲精品 第1页 | 无码国产色欲xxxxx视频 | 97se亚洲精品一区 | 青春草在线视频免费观看 | 久久97精品久久久久久久不卡 | 图片区 小说区 区 亚洲五月 | 色婷婷综合中文久久一本 | 日韩av无码中文无码电影 | 亚洲欧美综合区丁香五月小说 | 老太婆性杂交欧美肥老太 | 无码人妻黑人中文字幕 | 三上悠亚人妻中文字幕在线 | 中文字幕人成乱码熟女app | 免费无码一区二区三区蜜桃大 | 曰本女人与公拘交酡免费视频 | 四虎国产精品免费久久 | 少妇邻居内射在线 | 熟妇人妻无码xxx视频 | 国产在热线精品视频 | 欧美激情内射喷水高潮 | 亚洲一区二区三区播放 | 亚洲精品国产a久久久久久 | 熟女体下毛毛黑森林 | 18无码粉嫩小泬无套在线观看 | 亚洲一区二区三区在线观看网站 | 亚洲熟悉妇女xxx妇女av | 欧美大屁股xxxxhd黑色 | 色综合久久中文娱乐网 | 成人综合网亚洲伊人 | 无码毛片视频一区二区本码 | 亚洲国产精品无码久久久久高潮 | 国产精品久久久 | 88国产精品欧美一区二区三区 | 成 人 网 站国产免费观看 | 成人无码精品一区二区三区 | 国产精品18久久久久久麻辣 | 99国产欧美久久久精品 | 全球成人中文在线 | 99久久亚洲精品无码毛片 | 中国女人内谢69xxxxxa片 | 影音先锋中文字幕无码 | 国产精品无码久久av | 无码吃奶揉捏奶头高潮视频 | 日本成熟视频免费视频 | 国产女主播喷水视频在线观看 | 色 综合 欧美 亚洲 国产 | 久久久久av无码免费网 | 精品乱码久久久久久久 | 人妻少妇被猛烈进入中文字幕 | 黑人玩弄人妻中文在线 | 日韩av激情在线观看 | 国产无套粉嫩白浆在线 | 中文字幕无线码免费人妻 | 国产精品理论片在线观看 | 成人免费无码大片a毛片 | 国产香蕉97碰碰久久人人 | 欧美丰满熟妇xxxx | 亚洲春色在线视频 | 好男人www社区 | 国内精品人妻无码久久久影院 | 国产偷抇久久精品a片69 | 久久亚洲中文字幕无码 | 99久久精品无码一区二区毛片 | 国产免费久久久久久无码 | 久久久中文字幕日本无吗 | 午夜福利试看120秒体验区 | 天堂а√在线地址中文在线 | 精品熟女少妇av免费观看 | 国产性生交xxxxx无码 | 亚洲人成网站在线播放942 | 久久久中文字幕日本无吗 | 国产色xx群视频射精 | 伊人久久婷婷五月综合97色 | 欧美freesex黑人又粗又大 | 人妻少妇精品久久 | 久久亚洲国产成人精品性色 | 激情人妻另类人妻伦 | 精品熟女少妇av免费观看 | 中文字幕av无码一区二区三区电影 | 亚洲人成无码网www | 纯爱无遮挡h肉动漫在线播放 | 久久国产自偷自偷免费一区调 | 久久久中文字幕日本无吗 | 精品一区二区三区波多野结衣 | 亚洲精品美女久久久久久久 | 一二三四在线观看免费视频 | 亚洲 另类 在线 欧美 制服 | 无码人中文字幕 | 国产做国产爱免费视频 | 精品无码国产一区二区三区av | 午夜时刻免费入口 | 久久久久久九九精品久 | 无码精品国产va在线观看dvd | 日日噜噜噜噜夜夜爽亚洲精品 | 美女极度色诱视频国产 | 国产成人精品无码播放 | 日本免费一区二区三区最新 | 日本精品人妻无码77777 天堂一区人妻无码 | 国产人妻精品午夜福利免费 | 少妇高潮一区二区三区99 | 久久久久人妻一区精品色欧美 | 欧美激情一区二区三区成人 | 色欲av亚洲一区无码少妇 | 性生交片免费无码看人 | 丰满少妇人妻久久久久久 | 人妻少妇精品无码专区动漫 | 中文无码伦av中文字幕 | 国产女主播喷水视频在线观看 | 久久久中文字幕日本无吗 | 久久国语露脸国产精品电影 | 亚洲精品成人av在线 | 色窝窝无码一区二区三区色欲 | 久久国产精品二国产精品 | 日韩精品一区二区av在线 | 欧美精品一区二区精品久久 | 中国大陆精品视频xxxx | 狠狠亚洲超碰狼人久久 | 国产乱人伦偷精品视频 | 国产性生大片免费观看性 | 最新版天堂资源中文官网 | 亚洲精品午夜国产va久久成人 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 国产人妻精品午夜福利免费 | 中文字幕乱码人妻无码久久 | 色老头在线一区二区三区 | 中文字幕精品av一区二区五区 | 久久久久久av无码免费看大片 | 亚洲中文字幕在线观看 | 狠狠噜狠狠狠狠丁香五月 | 日本一区二区更新不卡 | 东北女人啪啪对白 | 丰满诱人的人妻3 | 丰腴饱满的极品熟妇 | 自拍偷自拍亚洲精品被多人伦好爽 | 欧洲精品码一区二区三区免费看 | 特黄特色大片免费播放器图片 | а√天堂www在线天堂小说 | 好爽又高潮了毛片免费下载 | 久久精品国产精品国产精品污 | 中文精品久久久久人妻不卡 | 内射后入在线观看一区 | 国产亚洲视频中文字幕97精品 | 国产人成高清在线视频99最全资源 | 精品人妻中文字幕有码在线 | 国产精品二区一区二区aⅴ污介绍 | 国产99久久精品一区二区 | 久久 国产 尿 小便 嘘嘘 | 国产无遮挡又黄又爽免费视频 | 国内精品九九久久久精品 | 丝袜人妻一区二区三区 | 久久久久久亚洲精品a片成人 | 成人免费视频一区二区 | 国产精品久久久久久久影院 | 国产av人人夜夜澡人人爽麻豆 | 东北女人啪啪对白 | 欧美老人巨大xxxx做受 | 国产又粗又硬又大爽黄老大爷视 | 18禁止看的免费污网站 | 国产精品久久久久久久9999 | 国精产品一品二品国精品69xx | 亚洲精品综合五月久久小说 | 欧美三级a做爰在线观看 | 国产真实乱对白精彩久久 | 久久熟妇人妻午夜寂寞影院 | 亚洲中文字幕无码中文字在线 | 波多野结衣aⅴ在线 | 小sao货水好多真紧h无码视频 | 少妇被粗大的猛进出69影院 | 亚洲成a人一区二区三区 | 任你躁国产自任一区二区三区 | 999久久久国产精品消防器材 | 久久精品国产一区二区三区 | aⅴ亚洲 日韩 色 图网站 播放 | 激情亚洲一区国产精品 | 亚洲а∨天堂久久精品2021 | 性欧美牲交xxxxx视频 | 麻豆精品国产精华精华液好用吗 | 国产在线aaa片一区二区99 | 大地资源中文第3页 | 一个人看的www免费视频在线观看 | 曰韩无码二三区中文字幕 | 波多野结衣一区二区三区av免费 | 中文字幕色婷婷在线视频 | 国产精品爱久久久久久久 | 岛国片人妻三上悠亚 | 免费人成在线视频无码 | 亚洲欧美中文字幕5发布 | 丝袜人妻一区二区三区 | 天堂а√在线中文在线 | 18无码粉嫩小泬无套在线观看 | 国精产品一品二品国精品69xx | 成年美女黄网站色大免费视频 | 亚洲伊人久久精品影院 | 97人妻精品一区二区三区 | 成人无码视频免费播放 | 精品久久久久久亚洲精品 | 欧美三级不卡在线观看 | 欧美黑人乱大交 | 久久综合香蕉国产蜜臀av | 精品久久久无码人妻字幂 | 学生妹亚洲一区二区 | 亚洲日韩一区二区 | 精品无人区无码乱码毛片国产 | 精品无码一区二区三区爱欲 | 少妇厨房愉情理9仑片视频 | 亚洲码国产精品高潮在线 | 亚洲最大成人网站 | а√天堂www在线天堂小说 | 无人区乱码一区二区三区 | 亚洲国产精品一区二区美利坚 | 天堂а√在线中文在线 | 久久亚洲中文字幕精品一区 | 午夜理论片yy44880影院 | 久久亚洲中文字幕精品一区 | 最近的中文字幕在线看视频 | 国产无套粉嫩白浆在线 | 又色又爽又黄的美女裸体网站 | 国产麻豆精品精东影业av网站 | 国产精品爱久久久久久久 | 中文字幕无码av激情不卡 | 亚洲色成人中文字幕网站 | 女人被爽到呻吟gif动态图视看 | 欧美丰满少妇xxxx性 | 中文字幕av无码一区二区三区电影 | 久久精品一区二区三区四区 | 久久99国产综合精品 | 国产一区二区三区影院 | 一本精品99久久精品77 | 永久免费观看国产裸体美女 | 亚洲一区二区三区含羞草 | 内射欧美老妇wbb | 国产成人综合色在线观看网站 | 亚洲日本在线电影 | 高潮毛片无遮挡高清免费视频 | 无码午夜成人1000部免费视频 | 性欧美大战久久久久久久 | 老熟妇乱子伦牲交视频 | 国产成人久久精品流白浆 | 曰本女人与公拘交酡免费视频 | 四虎4hu永久免费 | 波多野结衣 黑人 | 色妞www精品免费视频 | 一本久道高清无码视频 | 九九在线中文字幕无码 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 99久久久国产精品无码免费 | 免费视频欧美无人区码 | 精品偷自拍另类在线观看 | 波多野结衣高清一区二区三区 | 老熟妇仑乱视频一区二区 | 牲欲强的熟妇农村老妇女视频 | 国内精品久久久久久中文字幕 | 丰满少妇女裸体bbw | 中文字幕无码免费久久9一区9 | 日韩精品久久久肉伦网站 | 一二三四在线观看免费视频 | 国产成人久久精品流白浆 | 久久久精品欧美一区二区免费 | 亚洲中文字幕乱码av波多ji | 特黄特色大片免费播放器图片 | 青草视频在线播放 | 一本一道久久综合久久 | 亚洲中文字幕在线无码一区二区 | 亚洲 高清 成人 动漫 | 国产一精品一av一免费 | 桃花色综合影院 | 性色av无码免费一区二区三区 | 国产午夜手机精彩视频 | 午夜福利一区二区三区在线观看 | 大肉大捧一进一出视频出来呀 | 日本精品久久久久中文字幕 | 亚洲大尺度无码无码专区 | 宝宝好涨水快流出来免费视频 | 樱花草在线播放免费中文 | 亚洲码国产精品高潮在线 | 理论片87福利理论电影 | 强奷人妻日本中文字幕 | 久久久中文久久久无码 | 久久久中文字幕日本无吗 | 一本加勒比波多野结衣 | 亚洲成a人一区二区三区 | 欧美日韩一区二区免费视频 | 樱花草在线播放免费中文 | 18无码粉嫩小泬无套在线观看 | 国产一区二区三区精品视频 | 窝窝午夜理论片影院 | 爆乳一区二区三区无码 | 日本一卡2卡3卡四卡精品网站 | 精品人妻人人做人人爽 | 亚洲精品综合一区二区三区在线 | 国产精品久久久久久亚洲影视内衣 | 国产热a欧美热a在线视频 | 一区二区三区高清视频一 | 未满小14洗澡无码视频网站 | 国产内射爽爽大片视频社区在线 | 中文字幕无码视频专区 | 高清无码午夜福利视频 | 国产va免费精品观看 | 亚洲国产精品一区二区美利坚 | 丰满人妻一区二区三区免费视频 | 自拍偷自拍亚洲精品被多人伦好爽 | 草草网站影院白丝内射 | 丰满人妻精品国产99aⅴ | 中文字幕人妻无码一区二区三区 | 久久久久亚洲精品中文字幕 | 一本久道高清无码视频 | 中文字幕乱码亚洲无线三区 | 男女作爱免费网站 | 水蜜桃亚洲一二三四在线 | 日本高清一区免费中文视频 | av无码不卡在线观看免费 | 女人被男人躁得好爽免费视频 | 麻豆成人精品国产免费 | 任你躁国产自任一区二区三区 | 国产偷抇久久精品a片69 | 久久午夜无码鲁丝片 | ass日本丰满熟妇pics | 少妇无码av无码专区在线观看 | 草草网站影院白丝内射 | 久久久久久久久888 | 久久国产精品精品国产色婷婷 | 中文字幕乱码人妻无码久久 | 欧美日韩视频无码一区二区三 | 亚洲中文字幕乱码av波多ji | 成人精品一区二区三区中文字幕 | 女人被男人躁得好爽免费视频 | 秋霞成人午夜鲁丝一区二区三区 | 亚洲色无码一区二区三区 | 日本饥渴人妻欲求不满 | 麻花豆传媒剧国产免费mv在线 | 亚洲码国产精品高潮在线 | 天堂亚洲2017在线观看 | 欧美日韩人成综合在线播放 | 亚洲综合无码久久精品综合 | 大地资源中文第3页 | 国内少妇偷人精品视频 | 国产亚洲精品久久久久久久 | 无码av中文字幕免费放 | 免费看男女做好爽好硬视频 | 扒开双腿吃奶呻吟做受视频 | 成年美女黄网站色大免费全看 | 美女扒开屁股让男人桶 | 中文久久乱码一区二区 | 国产美女极度色诱视频www | 亚洲一区二区三区香蕉 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 精品成在人线av无码免费看 | 在线视频网站www色 | 久久人人爽人人爽人人片av高清 | 亚洲成色www久久网站 | 波多野结衣 黑人 | 天天躁日日躁狠狠躁免费麻豆 | 国产成人无码av在线影院 | 精品久久久久香蕉网 | 成在人线av无码免费 | 精品无人国产偷自产在线 | 亚洲第一无码av无码专区 | 国产精品第一区揄拍无码 | 色一情一乱一伦一区二区三欧美 | 六月丁香婷婷色狠狠久久 | 色一情一乱一伦一视频免费看 | 美女毛片一区二区三区四区 | 久久综合狠狠综合久久综合88 | 性欧美videos高清精品 | 国产在线精品一区二区三区直播 | 国产电影无码午夜在线播放 | 国产麻豆精品精东影业av网站 | 人妻插b视频一区二区三区 | 久久久精品456亚洲影院 | 亚洲七七久久桃花影院 | 午夜丰满少妇性开放视频 | 国产偷抇久久精品a片69 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 久久综合网欧美色妞网 | 日本在线高清不卡免费播放 | 无码一区二区三区在线观看 | 青青青手机频在线观看 | 精品亚洲成av人在线观看 | 风流少妇按摩来高潮 | 毛片内射-百度 | 亚洲国产精品一区二区美利坚 | 国产精品久久久久无码av色戒 | 亚洲国产精品毛片av不卡在线 | 国产一精品一av一免费 | 精品久久综合1区2区3区激情 | 国产精品二区一区二区aⅴ污介绍 | 亚洲中文字幕无码一久久区 | 国产精品久久久午夜夜伦鲁鲁 | 色一情一乱一伦一视频免费看 | 一本加勒比波多野结衣 | 久久 国产 尿 小便 嘘嘘 | 国产又爽又黄又刺激的视频 | 精品成在人线av无码免费看 | 免费无码的av片在线观看 | 久青草影院在线观看国产 | 夜精品a片一区二区三区无码白浆 | 无码人妻丰满熟妇区五十路百度 | 超碰97人人做人人爱少妇 | 乱人伦中文视频在线观看 | 日韩精品一区二区av在线 | 欧美激情内射喷水高潮 | 午夜理论片yy44880影院 | 国产农村妇女高潮大叫 | 又紧又大又爽精品一区二区 | 精品人人妻人人澡人人爽人人 | 国产一区二区三区日韩精品 | 少妇无码吹潮 | 成人亚洲精品久久久久软件 | 久久久久成人精品免费播放动漫 | 免费中文字幕日韩欧美 | 呦交小u女精品视频 | 国产肉丝袜在线观看 | 99riav国产精品视频 | 精品国产福利一区二区 | 男人的天堂av网站 | 久久国产精品_国产精品 | 丰满岳乱妇在线观看中字无码 | 女人和拘做爰正片视频 | 精品人妻人人做人人爽 | 亚洲日本va中文字幕 | 亚洲国产精品美女久久久久 | 蜜桃视频插满18在线观看 | 最近的中文字幕在线看视频 | 日本饥渴人妻欲求不满 | 熟妇女人妻丰满少妇中文字幕 | 亚洲精品中文字幕 | aa片在线观看视频在线播放 | 高潮毛片无遮挡高清免费 | 一个人看的www免费视频在线观看 | 久久久国产精品无码免费专区 | 日本欧美一区二区三区乱码 | 国产精品久久久久影院嫩草 | 无码国产乱人伦偷精品视频 | 无码播放一区二区三区 | 最新国产乱人伦偷精品免费网站 | 成在人线av无码免观看麻豆 | 亚洲日韩中文字幕在线播放 | 一本久道久久综合狠狠爱 | 天天做天天爱天天爽综合网 | 日本爽爽爽爽爽爽在线观看免 | 国产无套粉嫩白浆在线 | 免费乱码人妻系列无码专区 | 377p欧洲日本亚洲大胆 | 无套内射视频囯产 | 久久99精品国产麻豆蜜芽 | 国产超碰人人爽人人做人人添 | 国产免费观看黄av片 | aⅴ亚洲 日韩 色 图网站 播放 | 妺妺窝人体色www婷婷 | 麻花豆传媒剧国产免费mv在线 | 性欧美牲交xxxxx视频 | 宝宝好涨水快流出来免费视频 | 国产凸凹视频一区二区 | 日本一本二本三区免费 | 青青青手机频在线观看 | 老司机亚洲精品影院无码 | 波多野结衣aⅴ在线 | 中文字幕无码热在线视频 | 国产亚洲精品久久久久久国模美 | 日本饥渴人妻欲求不满 | 亚洲日韩一区二区 | 日韩人妻无码一区二区三区久久99 | 久久久久成人片免费观看蜜芽 | 亚洲乱码中文字幕在线 | 日本熟妇乱子伦xxxx | 国产精品人人爽人人做我的可爱 | 精品久久久无码中文字幕 | 黄网在线观看免费网站 | 免费乱码人妻系列无码专区 | 日日麻批免费40分钟无码 | www成人国产高清内射 | 婷婷六月久久综合丁香 | 激情内射亚州一区二区三区爱妻 | 国产办公室秘书无码精品99 | 天堂一区人妻无码 | 久久久久av无码免费网 | 波多野结衣 黑人 | 国产做国产爱免费视频 | 色综合久久久无码网中文 | 一本大道久久东京热无码av | 免费无码av一区二区 | 久久久久国色av免费观看性色 | 色婷婷综合中文久久一本 | 性色欲情网站iwww九文堂 | 波多野结衣高清一区二区三区 | 男女猛烈xx00免费视频试看 | 伊人久久大香线焦av综合影院 | 99久久无码一区人妻 | 国产成人无码区免费内射一片色欲 | 波多野结衣 黑人 | 学生妹亚洲一区二区 | 东京无码熟妇人妻av在线网址 | 国产农村妇女高潮大叫 | 粗大的内捧猛烈进出视频 | 国产色xx群视频射精 | 亚洲中文无码av永久不收费 | 99久久精品午夜一区二区 | 日本精品久久久久中文字幕 | 性欧美videos高清精品 | 欧美 亚洲 国产 另类 | 搡女人真爽免费视频大全 | 一本久道久久综合婷婷五月 | 成年美女黄网站色大免费全看 | 国产精品无码成人午夜电影 | 欧美精品免费观看二区 | 日韩亚洲欧美中文高清在线 | 久久综合狠狠综合久久综合88 | 亚洲精品国产第一综合99久久 | 久久久精品国产sm最大网站 | 九九综合va免费看 | 99久久久无码国产精品免费 | 欧美性猛交内射兽交老熟妇 | 国产无av码在线观看 | 丰满少妇高潮惨叫视频 | 精品久久久久久亚洲精品 | 亚洲国产一区二区三区在线观看 | 国产精品亚洲lv粉色 | 少妇愉情理伦片bd | 成 人 免费观看网站 | 久9re热视频这里只有精品 | www国产精品内射老师 | 99久久人妻精品免费一区 | 国产精品人人爽人人做我的可爱 | 午夜无码区在线观看 | 久久国产精品偷任你爽任你 | 日韩亚洲欧美中文高清在线 | 久久久精品国产sm最大网站 | 亚洲国产精品美女久久久久 | 国产激情无码一区二区app | 蜜桃视频插满18在线观看 | 午夜嘿嘿嘿影院 | 免费无码的av片在线观看 | 无码国内精品人妻少妇 | 无码帝国www无码专区色综合 | 久久99精品国产麻豆 | 国产精品视频免费播放 | 国产av人人夜夜澡人人爽麻豆 | 天堂亚洲免费视频 | 成人动漫在线观看 | 久久久久se色偷偷亚洲精品av | 亚洲精品国产a久久久久久 | www国产亚洲精品久久网站 | 亚洲乱码日产精品bd | 成人免费视频在线观看 | 成人av无码一区二区三区 | 男人扒开女人内裤强吻桶进去 | 亚洲人亚洲人成电影网站色 | 女人被男人躁得好爽免费视频 | 亚洲精品久久久久久一区二区 | 国产精品福利视频导航 | 久久久久亚洲精品男人的天堂 | 国产精品免费大片 | 好男人www社区 | 久久精品中文闷骚内射 | 国产美女精品一区二区三区 | 欧美日韩一区二区免费视频 | 婷婷丁香六月激情综合啪 | 亚洲欧美日韩成人高清在线一区 | 日本xxxx色视频在线观看免费 | 久久国产劲爆∧v内射 | 性生交片免费无码看人 | 日本精品人妻无码免费大全 | 国产亚洲精品久久久久久大师 | 高清无码午夜福利视频 | 2019nv天堂香蕉在线观看 | 一本无码人妻在中文字幕免费 | 久久五月精品中文字幕 | 亚洲国产成人av在线观看 | 国产午夜无码精品免费看 | 国内少妇偷人精品视频免费 | 精品久久久无码人妻字幂 | 人妻少妇精品久久 | 成熟女人特级毛片www免费 | 精品国产一区av天美传媒 | 日韩精品无码免费一区二区三区 | 动漫av一区二区在线观看 | 国产精品a成v人在线播放 | 成人精品视频一区二区三区尤物 | 国产艳妇av在线观看果冻传媒 | 成熟人妻av无码专区 | 亚洲精品无码国产 | 中文字幕无码日韩欧毛 | 久久精品国产一区二区三区 | 性欧美熟妇videofreesex | 国产亚洲美女精品久久久2020 | 成人免费无码大片a毛片 | 最近免费中文字幕中文高清百度 | ass日本丰满熟妇pics | 在线观看欧美一区二区三区 | 久久久久国色av免费观看性色 | 亚洲精品国产精品乱码不卡 | 亚洲国产精品一区二区第一页 | 少妇性l交大片欧洲热妇乱xxx | 黑人巨大精品欧美一区二区 | 免费无码av一区二区 | 国产精品人妻一区二区三区四 | 人妻互换免费中文字幕 | 性生交大片免费看l | 丝袜 中出 制服 人妻 美腿 | 成人无码精品1区2区3区免费看 | 麻豆蜜桃av蜜臀av色欲av | 性欧美牲交在线视频 | 无码人妻黑人中文字幕 | 国产在线精品一区二区三区直播 | 中文字幕乱码亚洲无线三区 | 精品欧美一区二区三区久久久 | 亚洲中文字幕乱码av波多ji | 激情国产av做激情国产爱 | 中文字幕无码日韩欧毛 | 国产精品多人p群无码 | 成人免费无码大片a毛片 | 亚洲a无码综合a国产av中文 | 给我免费的视频在线观看 | 大屁股大乳丰满人妻 | 欧美成人午夜精品久久久 | 国产欧美精品一区二区三区 | 久久99精品国产麻豆蜜芽 | 久久久久av无码免费网 | 免费中文字幕日韩欧美 | 国产精品多人p群无码 | 亚洲国产高清在线观看视频 | 国产美女极度色诱视频www | 无码人中文字幕 | 男人的天堂av网站 | 理论片87福利理论电影 | 欧美精品无码一区二区三区 | 亚洲阿v天堂在线 | 国产片av国语在线观看 | 欧美大屁股xxxxhd黑色 | 无码人妻精品一区二区三区不卡 | 亚洲国产精品毛片av不卡在线 | 亚洲日本va中文字幕 | 中文无码成人免费视频在线观看 | 4hu四虎永久在线观看 | 亚洲天堂2017无码中文 | 亚洲性无码av中文字幕 | 亚洲欧洲无卡二区视頻 | 免费无码的av片在线观看 | 中文无码伦av中文字幕 | 天天躁夜夜躁狠狠是什么心态 | 六十路熟妇乱子伦 | 欧美人与禽zoz0性伦交 | 牲欲强的熟妇农村老妇女 | 无码帝国www无码专区色综合 | 青青青手机频在线观看 | 天天躁夜夜躁狠狠是什么心态 | 亚洲区欧美区综合区自拍区 | 秋霞成人午夜鲁丝一区二区三区 | 在线精品亚洲一区二区 | 少妇的肉体aa片免费 | 色欲人妻aaaaaaa无码 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 99久久人妻精品免费二区 | 国产精华av午夜在线观看 | 麻豆蜜桃av蜜臀av色欲av | 亚洲午夜福利在线观看 | 免费人成网站视频在线观看 | 久久五月精品中文字幕 | 色窝窝无码一区二区三区色欲 | 一本大道久久东京热无码av | 在线欧美精品一区二区三区 | 国产农村乱对白刺激视频 | 少妇人妻大乳在线视频 | 欧美激情综合亚洲一二区 | 亚洲春色在线视频 | 999久久久国产精品消防器材 | 亚洲精品中文字幕久久久久 | 中文字幕+乱码+中文字幕一区 | av在线亚洲欧洲日产一区二区 | 国产真实伦对白全集 | 婷婷丁香五月天综合东京热 | 亚洲中文字幕无码中字 | 国产婷婷色一区二区三区在线 | 大胆欧美熟妇xx | 免费中文字幕日韩欧美 | 精品一二三区久久aaa片 | 久久人人爽人人人人片 | 老熟妇仑乱视频一区二区 | 色综合久久久久综合一本到桃花网 | 国产婷婷色一区二区三区在线 | 在线a亚洲视频播放在线观看 | 免费人成网站视频在线观看 | 日本饥渴人妻欲求不满 | 欧美国产日产一区二区 | 国产真实伦对白全集 | 动漫av一区二区在线观看 | 亚洲国产av精品一区二区蜜芽 | 自拍偷自拍亚洲精品10p | 午夜男女很黄的视频 | 日韩av无码一区二区三区不卡 | 露脸叫床粗话东北少妇 | 在线播放免费人成毛片乱码 | 国产无遮挡又黄又爽免费视频 | 亚洲国产精品久久人人爱 | 欧美阿v高清资源不卡在线播放 | 成人精品天堂一区二区三区 | 国产精品久久久久久久影院 | 日产精品99久久久久久 | 一本大道伊人av久久综合 | √天堂中文官网8在线 | 久久国产精品精品国产色婷婷 | 成人性做爰aaa片免费看 | 午夜成人1000部免费视频 | 国产三级精品三级男人的天堂 | 97夜夜澡人人爽人人喊中国片 | 熟妇激情内射com | 国产成人无码av在线影院 | 午夜精品久久久久久久 | 久久精品女人的天堂av | 少妇太爽了在线观看 | 国产一区二区三区影院 | 亚洲自偷自偷在线制服 | 国产精品久久久久久亚洲影视内衣 | 国产亚洲日韩欧美另类第八页 | 波多野结衣aⅴ在线 | 亚洲精品久久久久avwww潮水 | 欧美一区二区三区 | 国产精品二区一区二区aⅴ污介绍 | www国产精品内射老师 | 中文字幕 亚洲精品 第1页 | 无人区乱码一区二区三区 | 亚洲国产精品久久久久久 | 亚洲综合色区中文字幕 | 亚洲成av人影院在线观看 | 蜜臀aⅴ国产精品久久久国产老师 | 日韩精品乱码av一区二区 | 水蜜桃亚洲一二三四在线 | 帮老师解开蕾丝奶罩吸乳网站 | 精品无码成人片一区二区98 | 亚洲日韩精品欧美一区二区 | 人妻熟女一区 | 久久久久久国产精品无码下载 | 亚洲色成人中文字幕网站 | 日日天日日夜日日摸 | 久久久婷婷五月亚洲97号色 | 国产精品99爱免费视频 | 波多野42部无码喷潮在线 | 精品久久久无码中文字幕 | 18禁止看的免费污网站 | 久久久久成人精品免费播放动漫 | 在线天堂新版最新版在线8 | 久久97精品久久久久久久不卡 | 亚洲小说春色综合另类 | 亚洲最大成人网站 | 久久99精品久久久久久 | 国产免费久久久久久无码 | 狠狠亚洲超碰狼人久久 | 国产明星裸体无码xxxx视频 | 无遮无挡爽爽免费视频 | 露脸叫床粗话东北少妇 | 亚洲 a v无 码免 费 成 人 a v | 久久精品视频在线看15 | 成人一区二区免费视频 | 亚洲 a v无 码免 费 成 人 a v | 亚洲精品国产精品乱码不卡 | 亚洲精品成a人在线观看 | 熟女俱乐部五十路六十路av | 领导边摸边吃奶边做爽在线观看 | 久在线观看福利视频 | 无码吃奶揉捏奶头高潮视频 | 麻花豆传媒剧国产免费mv在线 | 无码成人精品区在线观看 | 中文字幕乱码亚洲无线三区 | 国产婷婷色一区二区三区在线 | 欧美日韩一区二区免费视频 | 国产精品无码一区二区三区不卡 | 少妇性荡欲午夜性开放视频剧场 | 久久国语露脸国产精品电影 | 老司机亚洲精品影院无码 | 男女猛烈xx00免费视频试看 | www国产亚洲精品久久久日本 | 欧美日韩一区二区三区自拍 | 性生交片免费无码看人 | 99国产精品白浆在线观看免费 | 成人亚洲精品久久久久 | 色欲人妻aaaaaaa无码 | 成人免费视频一区二区 | 亚洲色欲久久久综合网东京热 | 国产精品毛片一区二区 | 国产精品人妻一区二区三区四 | 黄网在线观看免费网站 | 精品偷自拍另类在线观看 | www成人国产高清内射 | 久久久精品456亚洲影院 | 国产偷抇久久精品a片69 | 久久久久免费精品国产 | 免费观看黄网站 | 国产精品国产自线拍免费软件 | 老熟妇乱子伦牲交视频 | 夫妻免费无码v看片 | 国产成人无码av一区二区 | 国产色xx群视频射精 | 国产成人一区二区三区别 | 一本久久伊人热热精品中文字幕 | 国产97色在线 | 免 | 少妇无码av无码专区在线观看 | 老子影院午夜伦不卡 | 亚洲 欧美 激情 小说 另类 | 欧美怡红院免费全部视频 | 亚洲高清偷拍一区二区三区 | 成 人 网 站国产免费观看 | 十八禁视频网站在线观看 | 精品一区二区三区波多野结衣 | 曰本女人与公拘交酡免费视频 | 亚洲精品一区二区三区在线观看 | 国产区女主播在线观看 | 伊人久久大香线焦av综合影院 | 久久久国产一区二区三区 | 日日摸日日碰夜夜爽av | 亚洲а∨天堂久久精品2021 | 无码人妻少妇伦在线电影 | 99久久人妻精品免费一区 | 亚洲欧美日韩成人高清在线一区 | 国产偷自视频区视频 | 亚洲中文无码av永久不收费 | 免费看少妇作爱视频 | www一区二区www免费 | 成人无码视频免费播放 | 久久久精品成人免费观看 | 国产又爽又猛又粗的视频a片 | 东京热无码av男人的天堂 | 国产舌乚八伦偷品w中 | 国产高潮视频在线观看 | 人妻少妇精品无码专区动漫 | 亚洲天堂2017无码 | 精品少妇爆乳无码av无码专区 | 亚洲精品综合一区二区三区在线 | 无码一区二区三区在线观看 | 国产精品久久久午夜夜伦鲁鲁 | 丰满少妇高潮惨叫视频 | 亚洲国产精品美女久久久久 | 波多野结衣一区二区三区av免费 | 精品久久久久久人妻无码中文字幕 | 国产69精品久久久久app下载 | 国产偷抇久久精品a片69 | 18无码粉嫩小泬无套在线观看 | 东京热无码av男人的天堂 | 日本大乳高潮视频在线观看 | 国产人妻精品午夜福利免费 | 日韩人妻无码一区二区三区久久99 | 国产精品va在线播放 | 久久精品女人天堂av免费观看 | 久久精品国产99久久6动漫 | 国产精品久久久久久久9999 | 国产精品久久久久7777 | 麻豆蜜桃av蜜臀av色欲av | 色一情一乱一伦一视频免费看 | 亚洲春色在线视频 | 51国偷自产一区二区三区 | 中文字幕无码视频专区 | 4hu四虎永久在线观看 | 亚洲色大成网站www国产 | 国产欧美精品一区二区三区 | 日韩精品久久久肉伦网站 | 扒开双腿吃奶呻吟做受视频 | 漂亮人妻洗澡被公强 日日躁 | 欧美阿v高清资源不卡在线播放 | 日韩人妻系列无码专区 | 精品无码av一区二区三区 | 人人妻人人澡人人爽欧美精品 | 色情久久久av熟女人妻网站 | 国产精品久久久久久无码 | 亚洲国产av精品一区二区蜜芽 | 丰满少妇弄高潮了www | 亚洲中文无码av永久不收费 | 国产黄在线观看免费观看不卡 | 欧美国产日韩亚洲中文 | 人妻少妇精品视频专区 | 亚洲熟妇色xxxxx亚洲 | 成人无码精品一区二区三区 | 日本丰满护士爆乳xxxx | 熟妇人妻无乱码中文字幕 | 美女扒开屁股让男人桶 | 樱花草在线播放免费中文 | 激情爆乳一区二区三区 | 亚洲成色www久久网站 | 少妇人妻av毛片在线看 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 美女扒开屁股让男人桶 | 久久无码中文字幕免费影院蜜桃 | 国产办公室秘书无码精品99 | 人妻体内射精一区二区三四 | 中文字幕日产无线码一区 | 青青草原综合久久大伊人精品 | 中文字幕+乱码+中文字幕一区 | 国产色视频一区二区三区 | 少妇无套内谢久久久久 | 97久久精品无码一区二区 | 丰满岳乱妇在线观看中字无码 | 免费国产黄网站在线观看 | 国产精品亚洲lv粉色 | 亚洲狠狠婷婷综合久久 | 久久国产精品二国产精品 | 人人妻人人澡人人爽欧美精品 | 18禁止看的免费污网站 | 日韩视频 中文字幕 视频一区 | 国产超级va在线观看视频 | 亚洲熟悉妇女xxx妇女av | 中文字幕av日韩精品一区二区 | 精品久久8x国产免费观看 | 午夜精品一区二区三区在线观看 | 亚洲第一无码av无码专区 | 欧美刺激性大交 | 欧美xxxx黑人又粗又长 | 国产真实伦对白全集 | 国产情侣作爱视频免费观看 | 精品人妻人人做人人爽 | 欧美一区二区三区视频在线观看 | 国产成人精品久久亚洲高清不卡 | 超碰97人人射妻 | 国产女主播喷水视频在线观看 | 77777熟女视频在线观看 а天堂中文在线官网 | 国产精品人人爽人人做我的可爱 | 精品一二三区久久aaa片 | 国产亚洲视频中文字幕97精品 | 中文无码精品a∨在线观看不卡 | 小sao货水好多真紧h无码视频 | 色诱久久久久综合网ywww | 欧美日韩久久久精品a片 | 国产人妻精品一区二区三区 | 亚洲成a人片在线观看日本 | 国产精品无码成人午夜电影 | 黑森林福利视频导航 | 亚洲色大成网站www | 亚洲va中文字幕无码久久不卡 | 婷婷五月综合激情中文字幕 | 精品成在人线av无码免费看 | 国产精品99爱免费视频 | 国产内射老熟女aaaa | 久久久久99精品成人片 | 少妇一晚三次一区二区三区 | 亚洲综合另类小说色区 | 久久综合狠狠综合久久综合88 | 3d动漫精品啪啪一区二区中 | 日本熟妇人妻xxxxx人hd | 少妇无码吹潮 | 国产sm调教视频在线观看 | 国精产品一品二品国精品69xx | 精品久久久久久人妻无码中文字幕 | 亚洲欧美国产精品专区久久 | 久久午夜无码鲁丝片午夜精品 | 国产激情综合五月久久 | 西西人体www44rt大胆高清 | 在线观看国产午夜福利片 | 美女张开腿让人桶 | 中文字幕乱码人妻无码久久 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 51国偷自产一区二区三区 | 国产成人无码区免费内射一片色欲 | 图片区 小说区 区 亚洲五月 | 日日摸天天摸爽爽狠狠97 | 成人动漫在线观看 | 少妇的肉体aa片免费 | 欧美喷潮久久久xxxxx | 欧美日韩久久久精品a片 | 鲁鲁鲁爽爽爽在线视频观看 | 沈阳熟女露脸对白视频 | 国产人妻精品一区二区三区不卡 | 特级做a爰片毛片免费69 | 国产手机在线αⅴ片无码观看 | 少妇被粗大的猛进出69影院 | 国产激情精品一区二区三区 | 好男人www社区 | 久久国产精品精品国产色婷婷 | 久久久久国色av免费观看性色 | 国产香蕉97碰碰久久人人 | 夜精品a片一区二区三区无码白浆 | 思思久久99热只有频精品66 | 免费观看又污又黄的网站 | 国语自产偷拍精品视频偷 | 久久久久久a亚洲欧洲av冫 | 亚洲国产精品无码一区二区三区 | 日韩欧美中文字幕公布 | 欧美日韩人成综合在线播放 | 九一九色国产 | 国产明星裸体无码xxxx视频 | 亚洲国产精品久久人人爱 | 丰满少妇高潮惨叫视频 | 国产女主播喷水视频在线观看 | 国产一精品一av一免费 | 久久天天躁狠狠躁夜夜免费观看 | 无码乱肉视频免费大全合集 | 精品厕所偷拍各类美女tp嘘嘘 | 在线观看国产午夜福利片 | 青草青草久热国产精品 | 亚洲综合在线一区二区三区 | 亚洲成av人片天堂网无码】 | 性生交片免费无码看人 | 久久精品99久久香蕉国产色戒 | 在线精品亚洲一区二区 | 欧洲极品少妇 | 又粗又大又硬毛片免费看 | 亚洲午夜无码久久 | 日韩少妇白浆无码系列 | 欧美国产日韩久久mv | 最近的中文字幕在线看视频 | 久久久精品人妻久久影视 | 欧美一区二区三区 | 18黄暴禁片在线观看 | 日本一区二区更新不卡 | 亚欧洲精品在线视频免费观看 | 精品无码av一区二区三区 | 最新版天堂资源中文官网 | 色五月五月丁香亚洲综合网 | 伊在人天堂亚洲香蕉精品区 | 日日摸日日碰夜夜爽av | 亚洲精品国产精品乱码不卡 | 久久99热只有频精品8 | 日本精品久久久久中文字幕 | 精品乱子伦一区二区三区 | 日本护士毛茸茸高潮 | 双乳奶水饱满少妇呻吟 | 欧美三级a做爰在线观看 | 国产激情艳情在线看视频 | 亚洲狠狠色丁香婷婷综合 | 无码人妻黑人中文字幕 | 四虎国产精品免费久久 | 国产成人午夜福利在线播放 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 欧美怡红院免费全部视频 | 午夜嘿嘿嘿影院 | 玩弄少妇高潮ⅹxxxyw | 久久久久国色av免费观看性色 | 奇米影视7777久久精品人人爽 | 亚洲の无码国产の无码影院 | 六月丁香婷婷色狠狠久久 | 免费无码一区二区三区蜜桃大 | 成人精品视频一区二区三区尤物 | 欧美午夜特黄aaaaaa片 | 无码av免费一区二区三区试看 | 国产99久久精品一区二区 | 久久久av男人的天堂 | 精品无人国产偷自产在线 | 老司机亚洲精品影院无码 | 最新国产麻豆aⅴ精品无码 | 男女性色大片免费网站 | 久久久久久久女国产乱让韩 | 久久99精品国产.久久久久 | 精品无码一区二区三区爱欲 | 人妻互换免费中文字幕 | 精品日本一区二区三区在线观看 | 国产9 9在线 | 中文 | 爆乳一区二区三区无码 | 日本丰满护士爆乳xxxx | 一本无码人妻在中文字幕免费 | 成人无码精品1区2区3区免费看 | 一本加勒比波多野结衣 | 亚洲成色在线综合网站 | 国产欧美精品一区二区三区 | 永久黄网站色视频免费直播 | 国精产品一品二品国精品69xx | 久久综合色之久久综合 | 日本xxxx色视频在线观看免费 | 人人妻人人藻人人爽欧美一区 | 久久人人97超碰a片精品 | 熟女俱乐部五十路六十路av | 国产一区二区不卡老阿姨 | 男女爱爱好爽视频免费看 | 精品午夜福利在线观看 | 丁香花在线影院观看在线播放 |