亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? cifa.c

?? c語言寫的pascal詞法語法分析器
?? C
?? 第 1 頁 / 共 2 頁
字號:


#include "stdio.h"
#include "stdlib.h"
#include "string.h"
#include "conio.h"
#include "iostream.h"
#include "ctype.h"

#define NORW 13//Pascal 子集的關鍵字的個數
#define TXMAX 100//標識符表的長度
#define NMAX 14 //數中數字的最大個數
#define AL 10 //標識符的長度
#define AMAX 2047 //最大地址
#define LEVMAX 3//分程序的最大深度
#define CXMAX 200//目標代碼數組的大小
#define STACKSIZE 500 //棧的深度

char *symbol[32]=
{
"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"
};

//PASCAL源程序關鍵字
char *word[NORW]=
{
"begin","call","const","do","end","if","odd","procedure",
"read","then","var","while","write"
};

//中間代碼關鍵字,與PASCAL源程序關鍵字對應
char *wsym[NORW]=
{
"beginsym","callsym","constsym","dosym","endsym","ifsym",
"oddsym","procsym","readsym","thensym","varsym","whilesym","writesym"
};

//操作命令代碼
char *mnemonic[8]=
{
"lit","opr","lod","sto","cal","ini","jmp","jpc"
};

char ch;//當前字符
char id[AL];//分析出的單詞的ID號即當前標識符
char sym[10];//當前符號
char line[81];//單詞輸入緩沖區
char a[AL];//暫存分析出的單詞
char fname[AL];//需讀入的文件名

enum object{constant,variable,procedur};
enum object kind;
enum fct{lit,opr,lod,sto,cal,ini,jmp,jpc};
enum listswitcher{fals,tru};//是否列目標清單的開關
enum listswitcher listswitch;


FILE *fa;
FILE *fa1,*fa2;
FILE *fin,*fout;

int err;//總的錯誤數
int num;//當前數
int cc;//字符計數
int ll;//行長
int kk;//預計要讀的單詞的長度
int cx=0;//code指針即目標代碼下標
int lev=0;//層次數
int tx=0;//table指針
int dx=0;//在s棧中相對的位置
int linecnt=0;//

struct instruction//生成的目標代碼的格式
{
enum fct f;//操作碼
int l;//層次值
int a;
};
struct instruction code[CXMAX+1];

struct table1
{//符號表
char name[AL];
enum object kind;
int val,level,adr,size;
};
struct table1 table[TXMAX+1];

//存放單詞
struct node
{
char *pa[32];
}*declbegsys,*statbegsys,*facbegsys,*tempsetsys;

//檢查str串是否在set結構體記錄中,若在返回1,否則返回0
int in(char *str,struct node *set)
{
int i=0;
while(set->pa[i]!=NULL)
{
if(strcmp(str,set->pa[i])==0)
{
return 1;
}
else
{
i++;
}
}
return 0;
}

//將set1和set1中沒有的set2的內容合成為一個node類型并返回(合并set1,set2)
struct node *add(struct node *set1,struct node *set2)
{
int i=0,j=0,k=0,cnt;
//定義pt,并申請空間
struct node *pt;
pt=(struct node *)malloc(sizeof(struct node));
for(cnt=0;cnt<32;cnt++)
{
pt->pa[cnt]=(char *)malloc(10*sizeof(char));
}
//將set1中內容拷貝到pt
while(set1->pa[i]!=NULL)
{
strcpy(pt->pa[j++],set1->pa[i++]);
}
//現在pt和set1中內容相同,但若set2中有與set1不同的內容,加入到pt中
while((set2->pa[k])!=NULL)
{
if(in(set2->pa[k],set1)==0)
{
strcpy(pt->pa[j++],set2->pa[k++]);
}
else
{
k++;
}
}
pt->pa[j]=NULL;
return(pt);
}

//輸出錯誤信息(錯誤類型代碼)并記錄總錯誤數
void error(int n)
{
int i;
printf("***");
fputs("***",fa1);
for(i=0;i<cc;i++)
{
printf("*");
}
for(i=0;i<cc;i++)
{
fputs("*",fa1);
}
printf("\nerror: %d\t",n);
fprintf(fa1,"\nerror: %d\t",n);
switch(n)
{
case 1:
printf("常量說明中的'='寫成了':='!\n");
fprintf(fa1,"常量說明中的'='寫成了':='!\n");
break;
case 2:
printf("常量說明中的'='之后不是數字!\n");
fprintf(fa1,"常量說明中的'='之后不是數字!\n");
break;
case 3:
printf("常量說明中的標識符的后繼符號不是'='!\n");
fprintf(fa1,"常量說明中的標識符的后繼符號不是'='!\n");
break;
case 4:
printf("CONST、VAR、PROCEDURE的后繼符號不是標識符!\n");
fprintf(fa1,"CONST、VAR、PROCEDURE的后繼符號不是標識符!\n");
break;
case 5:
printf("漏了','或';'!\n");
fprintf(fa1,"漏了','或';'!\n");
break;
case 6:
printf("過程說明結束符;的后繼符號既不是語句開始符也不是其它說明符(PROCEDURE)!\n");
fprintf(fa1,"過程說明結束符;的后繼符號既不是語句開始符也不是其它說明符(PROCEDURE)!\n");
break;
case 7:
printf("過程說明結束符;的后繼符號既不是語句開始符也不是其它說明符!\n");
fprintf(fa1,"過程說明結束符;的后繼符號既不是語句開始符也不是其它說明符!\n");
break;
case 8:
printf("程序體內語句部分的后繼符號不正確!\n");
fprintf(fa1,"程序體內語句部分的后繼符號不正確!\n");
break;
case 9:
printf("程序沒有以'.'結尾!\n");
fprintf(fa1,"程序沒有以'.'結尾!\n");
break;
case 10:
printf("語句之間缺';'!\n");
fprintf(fa1,"語句之間缺';'!\n");
break;
case 11:
printf("標識符未說明!\n");
fprintf(fa1,"標識符未說明!\n");
break;
case 12:
printf("賦值號左部標識符的屬性不是變量!\n");
fprintf(fa1,"賦值號左部標識符的屬性不是變量!\n");
break;
case 13:
printf("賦值號左部標識符的后繼符號不是':='!\n");
fprintf(fa1,"賦值號左部標識符的后繼符號不是':='!\n");
break;
case 14:
printf("CALL后繼符號不是標識符!\n");
fprintf(fa1,"CALL后繼符號不是標識符!\n");
break;
case 15:
printf("CALL后繼標識符的屬性不是過程!\n");
fprintf(fa1,"CALL后繼標識符的屬性不是過程!\n");
break;
case 16:
printf("條件語句缺'THEN'!\n");
fprintf(fa1,"條件語句缺'THEN'!\n");
break;
case 17:
printf("復合語句缺'END'!\n");
fprintf(fa1,"復合語句缺'END'!\n");
break;
case 18:
printf("WHILE型循環語句缺'DO'!\n");
fprintf(fa1,"WHILE型循環語句缺'DO'!\n");
break;
case 19:
printf("語句的后繼符號不正確!\n");
fprintf(fa1,"語句的后繼符號不正確!\n");
break;
case 20:
printf("布爾表達式中有非法關系運算符!\n");
fprintf(fa1,"布爾表達式中有非法關系運算符!\n");
break;
case 21:
printf("表達式內不能有過程標識符!\n");
fprintf(fa1,"表達式內不能有過程標識符!\n");
break;
case 22:
printf("因子中缺匹配的')'!\n");
fprintf(fa1,"因子中缺匹配的')'!\n");
break;
case 23:
printf("因子不能以此符號結束!\n");
fprintf(fa1,"因子不能以此符號結束!\n");
break;
case 24:
printf("因子不能以此符號開始!\n");
fprintf(fa1,"因子不能以此符號開始!\n");
break;
case 30:
printf("常數越界!\n");
fprintf(fa1,"常數越界!\n");
break;
case 31:
printf("表達式內常數越界!\n");
fprintf(fa1,"表達式內常數越界!\n");
break;
case 32:
printf("嵌套深度超過允許值!\n");
fprintf(fa1,"嵌套深度超過允許值!\n");
break;
case 33:
printf("READ或WRITE語句中缺')'!\n");
fprintf(fa1,"READ或WRITE語句中缺')'!\n");
break;
case 34:
printf("READ或WRITE語句中缺'('!\n");
fprintf(fa1,"READ或WRITE語句中缺'('!\n");
break;
case 35:
printf("READ語句中標識符未說明!\n");
fprintf(fa1,"READ語句中標識符未說明!\n");
break;
default:
printf("未處理的異常!\n");
fprintf(fa1,"未處理的異常!\n");
break;
}
err=err+1;
}

//如果緩沖區中有字符,則從中順序讀出一個字符,否則從文件讀入
void get_ch()
{
if(cc==ll+1)//已經完成上次讀入行的分析
{
if(feof(fin))
{ 
//已到文件結尾
printf("程序沒有結束!\n"); 
printf("要取消此次編譯嗎?(Y/N)");
char mychar;
cin>>mychar;
if(mychar=='Y'||mychar=='y')
{
exit(0);
}
}
ll=0;
cc=0;
//重新讀入一行
while(feof(fin)==false&&(ch=fgetc(fin))!='\n'&&ch!=-1)//尚未結束,將一行記錄輸出打印
{
putchar(ch);
fputc(ch,fa1);
line[ll++]=ch;
}
line[ll]=ch;
printf("\n");
line[ll]=ch;
fprintf(fa1,"\n");
}
ch=line[cc++];
if(ch>='A'&&ch<='Z')//處理大小寫區別
{
ch=ch+32;
}
}

//詞法分析,分解出一個單詞
void getsym()
{
int i,j,k;
while(ch==' '||ch=='\t'||ch=='\n')
{
get_ch();//讀字符
}
if(ch>='a'&&ch<='z')
{
k=0;

do
{
if(k<AL)
{
a[k]=ch;
k=k+1;
}
get_ch();
}
while((ch>='a'&&ch<='z')||(ch>='0'&&ch<='9'));

if(k>=kk)
{
kk=k;
}
else
{
if(k<kk-1)
{
a[k++]='\0';
}
}

strcpy(id,a);

i=0;
j=NORW-1;
do
{
k=(i+j)/2;
if(strcmp(id,word[k])<=0) j=k-1;
if(strcmp(id,word[k])>=0) i=k+1;
}
while(i<=j);

if(i-1>j)
{
strcpy(sym,wsym[k]);
}
else
{
strcpy(sym,"ident");
}
}
else if(ch>='0'&&ch<='9')
{
k=0;
num=0;
strcpy(sym,"number");
do
{
num=10*num+(int)ch-'0';
k=k+1;
get_ch();
}
while(ch>='0'&&ch<='9');

if(k>NMAX)
{
error(30);
}
}
else if(ch==':')
{
get_ch();
if(ch=='=')
{
strcpy(sym,"becomes");
get_ch();
}
else
{
strcpy(sym,"nul");
}
}
else if(ch=='<')
{
get_ch();
if(ch=='=')
{
strcpy(sym,"leq");
get_ch();
}
else 
{
strcpy(sym,"lss");
}
}
else if(ch=='>')
{
get_ch();
if(ch=='=')
{
strcpy(sym,"geq");
get_ch();
}
else
{
strcpy(sym,"gtr");
}
}
else
{
switch(ch)
{
case '+': strcpy(sym,"plus");break;
case '-': strcpy(sym,"minus");break;
case '*': strcpy(sym,"times");break;
case '/': strcpy(sym,"slash");break;
case '(': strcpy(sym,"lparen");break;
case ')': strcpy(sym,"rparen");break;
case '=': strcpy(sym,"eql");break;
case ',': strcpy(sym,"comma");break;
case '.': strcpy(sym,"period");break;
case '#': strcpy(sym,"neq");break;
case ';': strcpy(sym,"semicolon");break;
}
get_ch();
}
}

//生成偽代碼
void gen(enum fct x,int y,int z)
{
if(cx>CXMAX)
{
printf("程序太長!");
}
else
{
code[cx].f=x;
code[cx].l=y;
code[cx].a=z;
cx++;
}
}

//檢測錯誤,如果分析時有錯,輸出該錯誤并繼續分析
void test(struct node *s1,struct node *s2,int n)
{
if(in(sym,s1)==0)
{
error(n);
s1=add(s1,s2);
while(in(sym,s1)==0)
{
getsym();
}
}
}

//造符號表table,將k加入table,k為類型聲明
void enter(enum object k)
{
tx=tx+1;
strcpy(table[tx].name,id);
table[tx].kind=k;
switch(k)
{
case constant:
if(num>NMAX)
{
error(31);
num=0;
}
table[tx].val=num;
break;
case variable:
table[tx].level=lev; 
table[tx].adr=dx;
dx++;
break;
case procedur:
table[tx].level=lev;
break;
}
}

//定位ID :查符號表并返回位置
int position(char id[10])
{
int i;
strcpy(table[0].name,id);
i=tx;
while(i>=0&&strcmp(table[i].name,id)!=0)
{
i--; 
}
return i;
}

//造常量表
void constdeclaration()
{
if(strcmp(sym,"ident")==0)
{
getsym();
if(strcmp(sym,"eql")==0||strcmp(sym,"becomes")==0)
{
if(strcmp(sym,"becomes")==0)
{
error(1);
}
getsym();
if(strcmp(sym,"number")==0)
{
enter(constant);
getsym();
}
else error(2);
}
else error(3);
}
else error(4);
}

//造變量表
void vardeclaration()
{

if(strcmp(sym,"ident")==0)
{
enter(variable);
getsym();
}
else error(4);
}


void listcode(int *cx0)
{
//打印本層的偽代碼
int i;
if(listswitch==tru)
{
printf("\n");
for(i=*cx0;i<=cx-1;i++)
{
printf("%2d %5s %3d %5d\n",i,mnemonic[(int)code[i].f],code[i].l,code[i].a);
fprintf(fa,"%2d %5s %3d %5d\n",i,mnemonic[(int)code[i].f],code[i].l,code[i].a);
}
printf("\n");
printf("\n");
}
}

//處理因子
void factor(struct node *fsys)
{
void expression(struct node *fsys);
int m=0,n=0,i;
char *tempset[]={"rparen",NULL};
struct node *temp;
temp=(struct node*)malloc(sizeof(struct node));
while(tempset[m]!=NULL) 
{
temp->pa[n++]=tempset[m++];
}
temp->pa[n]=NULL;
test(facbegsys,fsys,24);
while(in(sym,facbegsys)==1)
{
if(strcmp(sym,"ident")==0)
{
i=position(id);
if(i==0)//標識符未聲明
{
error(11);
}
else 
{
switch(table[i].kind)
{
case constant:
gen(lit,0,table[i].val);
break;
case variable:
gen(lod,lev-table[i].level,table[i].adr);
break;
case procedur:
error(21);
break;
}
}
getsym();
}
else if(strcmp(sym,"number")==0)
{
if(num>AMAX)
{
error(31);
num=0;
}
gen(lit,0,num);
getsym();
}
else if(strcmp(sym,"lparen")==0)
{
getsym();
expression(add(temp,fsys));
if(strcmp(sym,"rparen")==0)
{
getsym();
}
else
{
error(22);//缺匹配的右括號
}
}
test(fsys,facbegsys,23);
}
}

//處理項
void term(struct node *fsys)
{
int i=0,j=0;
char mulop[10];
char *tempset[]={"times","slash",NULL};
struct node *temp;
temp=(struct node *)malloc(sizeof(struct node));
while(tempset[i]!=NULL)
{
temp->pa[i++]=tempset[j++];
}
temp->pa[i]=NULL;
factor(add(temp,fsys));
while(in(sym,temp)==1)
{
strcpy(mulop,sym);
getsym();
factor(add(temp,fsys));
if(strcmp(mulop,"times")==0)
{
gen(opr,0,4);
}
else
{
gen(opr,0,5);
}
}
}

//處理算術表達式
void expression(struct node *fsys)
{
int m=0,n=0;
char addop[10];
char *tempset[]={"plus","minus",NULL};
struct node *temp;
temp=(struct node *)malloc(sizeof(struct node));
while(tempset[m]!=NULL)
{
temp->pa[n++]=tempset[m++];
}
temp->pa[n]=NULL;

if(in(sym,temp)==1)
{
strcpy(addop,sym);
getsym();
term(add(fsys,temp));
if(strcmp(addop,"minus")==0)
{
gen(opr,0,1);
}
}
else
{
term(add(fsys,temp));
}

while(in(sym,temp)==1)
{
strcpy(addop,sym);
getsym();
term(add(fsys,temp));
if(strcmp(addop,"plus")==0)
{
gen(opr,0,2);
}
else
{
gen(opr,0,3);
}
}
}

//處理條件表達式
void condition(struct node *fsys)
{
int i=0,j=0;
char relop[10];
char *tempset[]={"eql","neq","lss","leq","gtr","geq",NULL};
struct node *temp;
temp=(struct node *)malloc(sizeof(struct node));
while(tempset[i]!=NULL)
{
temp->pa[j++]=tempset[i++];
}
temp->pa[j]=NULL;
if(strcmp(sym,"oddsym")==0)
{
getsym();
expression(fsys);
gen(opr,0,6);
}
else
{
expression(add(temp,fsys));
if(in(sym,temp)==0)
{
error(20);
}
else
{
strcpy(relop,sym);
getsym();
expression(fsys);
if(strcmp(relop,"eql")==0) gen(opr,0,8);
if(strcmp(relop,"neq")==0) gen(opr,0,9);
if(strcmp(relop,"lss")==0) gen(opr,0,10);

if(strcmp(relop,"geq")==0) gen(opr,0,11);
if(strcmp(relop,"gtr")==0) gen(opr,0,12);
if(strcmp(relop,"leq")==0) gen(opr,0,13);
}
}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美在线|欧美| 日本一区二区综合亚洲| 欧美性受极品xxxx喷水| 色综合天天综合网天天看片| 成人毛片视频在线观看| jiyouzz国产精品久久| 成人av资源在线| 99久久久久久| 色噜噜狠狠一区二区三区果冻| 99re免费视频精品全部| 91亚洲国产成人精品一区二区三| 懂色一区二区三区免费观看| 国产精品538一区二区在线| 风间由美一区二区三区在线观看| 丁香桃色午夜亚洲一区二区三区| 成人aaaa免费全部观看| 91麻豆免费在线观看| 欧美手机在线视频| 91精品国产综合久久久久久久| 日韩欧美亚洲一区二区| 欧美精品一区二区三区高清aⅴ| 久久久不卡影院| 国产精品久久久久一区二区三区| 中文字幕一区二区三区不卡| 亚洲图片你懂的| 亚洲制服丝袜av| 日韩不卡一区二区三区| 久久精品72免费观看| 国产一区二区三区久久久| 成人午夜激情影院| 色欧美片视频在线观看在线视频| 欧美日韩一区二区三区四区| 日韩一区二区视频| 欧美国产精品一区二区| 亚洲一线二线三线视频| 热久久免费视频| 成人久久视频在线观看| 欧美视频中文字幕| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 久久色在线视频| 亚洲午夜在线视频| 亚洲品质自拍视频| 亚洲大型综合色站| 精品一区免费av| 99精品国产一区二区三区不卡| 在线观看区一区二| 精品国产一区二区三区忘忧草| 中文字幕在线一区| 日日夜夜精品视频免费| 成人做爰69片免费看网站| 欧美视频一二三区| 国产农村妇女毛片精品久久麻豆 | 国产盗摄精品一区二区三区在线| 99久久99久久久精品齐齐| 91精品一区二区三区久久久久久| 国产亚洲一区二区三区在线观看| 一级特黄大欧美久久久| 久久99久久精品欧美| 91久久精品一区二区三| 26uuu欧美日本| 亚洲成人av免费| 成人免费av网站| 欧美一级免费观看| 亚洲精品久久久久久国产精华液| 国产制服丝袜一区| 欧美精品777| 亚洲视频精选在线| 国产一区久久久| 欧美日韩国产一级| 亚洲乱码中文字幕| 成人永久看片免费视频天堂| 欧美一区二区性放荡片| 亚洲手机成人高清视频| 精品一二三四在线| 欧美日韩aaa| 一区二区三区日韩欧美精品| 国产成人亚洲综合a∨婷婷| 欧美一区二区私人影院日本| 一区二区三国产精华液| 成人av网址在线| 精品久久免费看| 日本亚洲免费观看| 欧美视频一区二区三区四区| 亚洲视频一区在线| 成人免费高清在线| 国产午夜亚洲精品羞羞网站| 免费高清在线一区| 91精品国产综合久久久蜜臀图片| 亚洲最新视频在线播放| 91网页版在线| 国产精品久久久久影院| 懂色av一区二区三区免费看| 久久色在线观看| 国产一区二区在线视频| 精品国产一区二区三区四区四| 日本午夜一本久久久综合| 欧美三级日韩三级国产三级| 一区2区3区在线看| 在线影院国内精品| 亚洲综合一二三区| 欧美午夜精品一区二区三区| 亚洲最大的成人av| 在线观看视频一区二区欧美日韩| 樱花影视一区二区| 91久久一区二区| 亚洲愉拍自拍另类高清精品| 在线免费观看一区| 911精品国产一区二区在线| 亚洲欧美综合色| 成人激情动漫在线观看| 欧美国产在线观看| 国产99久久久精品| 国产精品久久网站| 色综合久久综合网欧美综合网| 亚洲人被黑人高潮完整版| 一本一道久久a久久精品综合蜜臀| 亚洲欧美精品午睡沙发| 91麻豆自制传媒国产之光| 亚洲激情中文1区| 欧美在线免费播放| 日本成人在线网站| 久久综合色婷婷| 成人午夜电影久久影院| **欧美大码日韩| 色婷婷狠狠综合| 日韩精彩视频在线观看| 欧美大尺度电影在线| 国产成人免费xxxxxxxx| 成人免费在线观看入口| 亚洲欧美色图小说| av电影在线观看不卡| 一区二区三区资源| 欧美精三区欧美精三区| 95精品视频在线| 亚洲黄色录像片| 欧美精品一二三| 国产精品夜夜爽| 亚洲人成网站影音先锋播放| 欧美日韩久久不卡| 国产精品一区二区三区99| 18成人在线观看| 欧美一区二区三区四区视频| 国内精品写真在线观看| 中文字幕在线不卡视频| 欧美日韩国产美女| 国产精品综合久久| 悠悠色在线精品| 久久综合久久综合久久| 91美女蜜桃在线| 激情五月激情综合网| 18涩涩午夜精品.www| 制服丝袜国产精品| 99视频有精品| 麻豆一区二区在线| 亚洲三级小视频| 日韩美女在线视频| 91久久精品国产91性色tv| 精品一区二区在线视频| 一区二区三区在线观看动漫 | 日韩欧美国产高清| 99re视频这里只有精品| 久久精品国产久精国产爱| 日韩美女视频一区二区| 精品少妇一区二区三区在线播放| 色综合久久久久综合| 精品一区二区三区在线播放视频 | 成人午夜视频免费看| 日韩精品欧美成人高清一区二区| 国产精品色呦呦| 日韩欧美久久久| 欧洲人成人精品| 成人网在线免费视频| 欧美aaaaa成人免费观看视频| 亚洲精品老司机| 国产精品无人区| 精品国产乱码久久久久久图片| 欧美性一二三区| av成人动漫在线观看| 国产一区二区三区视频在线播放| 亚洲成av人综合在线观看| 国产精品福利一区二区三区| 久久毛片高清国产| 3751色影院一区二区三区| 91黄色免费网站| 99r国产精品| 不卡一卡二卡三乱码免费网站| 精东粉嫩av免费一区二区三区| 石原莉奈在线亚洲三区| 亚洲一二三四区不卡| 国产精品久久久久四虎| 久久精品视频一区| 精品卡一卡二卡三卡四在线| 欧美日韩电影一区| 在线观看国产91| 色乱码一区二区三区88| 91看片淫黄大片一级在线观看| 波多野结衣在线一区| 成人永久aaa| 国产成人在线看| 国产激情偷乱视频一区二区三区|