在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

深度剖析C語言的main函數(shù)

璟琰乀 ? 來源:csdn ? 作者:z_ryan ? 2020-12-18 17:07 ? 次閱讀

main的返回值

main函數(shù)的返回值用于說明程序的退出狀態(tài)。如果返回0,則代表程序正常退出。返回其它數(shù)字的含義則由系統(tǒng)決定。通常,返回非零代表程序異常退出。

void main()

有一些書上的,都使用了void main( ) ,其實這是錯誤的。C/C++ 中從來沒有定義過void main( ) 。

C++ 之父 Bjarne Stroustrup 在他的主頁上的 FAQ 中明確地寫著 “The definition void main( ) { /* … */ } is not and never has been C++, nor has it even been C.” 這可能是因為 在 C 和 C++ 中,不接收任何參數(shù)也不返回任何信息的函數(shù)原型為“void foo(void);”。

可能正是因為這個,所以很多人都誤認(rèn)為如果不需要程序返回值時可以把main函數(shù)定義成void main(void) 。然而這是錯誤的!main 函數(shù)的返回值應(yīng)該定義為 int 類型,C 和 C++ 標(biāo)準(zhǔn)中都是這樣規(guī)定的。

雖然在一些編譯器中,void main() 可以通過編譯,但并非所有編譯器都支持 void main() ,因為標(biāo)準(zhǔn)中從來沒有定義過 void main 。

g++3.2 中如果 main 函數(shù)的返回值不是 int 類型,就根本通不過編譯。而 gcc3.2 則會發(fā)出警告。所以,為了程序擁有很好的可移植性,一定要用 int main ()。測試如下:

#include 《stdio.h》void main(){ printf(“Hello world”); return;}

運行結(jié)果:g++ test.c

main()

那既然main函數(shù)只有一種返回值類型,那么是不是可以不寫?規(guī)定:不明確標(biāo)明返回值的,默認(rèn)返回值為int,也就是說 main()等同于int main(),而不是等同于void main()。

在C99中,標(biāo)準(zhǔn)要求編譯器至少給 main() 這種用法來個警告,而在c89中這種寫法是被允許的。但為了程序的規(guī)范性和可讀性,還是應(yīng)該明確的指出返回值的類型。測試代碼:

#include 《stdio.h》main(){ printf(“Hello world”); return 0;}

運行結(jié)果:

C和C++的標(biāo)準(zhǔn)

在 C99 標(biāo)準(zhǔn)中,只有以下兩種定義方式是正確的:

int main( void ) int main( int argc, char *argv[] )

若不需要從命令行中獲取參數(shù),就使用int main(void) ;否則的話,就用int main( int argc, char *argv[] )。當(dāng)然參數(shù)的傳遞還可以有其他的方式,在下一節(jié)中,會單獨來講。

main 函數(shù)的返回值類型必須是 int ,這樣返回值才能傳遞給程序的調(diào)用者(如操作系統(tǒng)),等同于 exit(0),來判斷函數(shù)的執(zhí)行結(jié)果。

C++89中定義了如下兩種 main 函數(shù)的定義方式:

int main( ) int main( int argc, char *argv[] )

int main( ) 等同于 C99 中的 int main( void ) ;int main( int argc, char*argv[] ) 的用法也和C99 中定義的一樣。同樣,main函數(shù)的返回值類型也必須是int。

return 語句

如果 main 函數(shù)的最后沒有寫 return 語句的話,C99 和c++89都規(guī)定編譯器要自動在生成的目標(biāo)文件中加入return 0,表示程序正常退出。

不過,建議你最好在main函數(shù)的最后加上return語句,雖然沒有這個必要,但這是一個好的習(xí)慣。在linux下我們可以使用shell命令:echo $? 查看函數(shù)的返回值。

#include 《stdio.h》int main(){ printf(“Hello world”);}

運行結(jié)果:

同時,需要說明的是return的返回值會進(jìn)行 類型轉(zhuǎn)換,比如:若return 1.2 ;會將其強(qiáng)制轉(zhuǎn)換為1,即真正的返回值是1,同理,return ‘a(chǎn)’ ;的話,真正的返回值就是97,;但是若return “abc”;便會報警告,因為無法進(jìn)行隱式類型轉(zhuǎn)換。

測試main函數(shù)返回值的意義

前文說到,main函數(shù)如果返回0,則代表程序正常退出。通常,返回非零代表程序異常退出。在本文的最后,測試一下: test.c:

#include 《stdio.h》int main(){ printf(“c 語言”); return 11.1; }

在終端執(zhí)行如下:

testSigpipe git:(master) vim test.c testSigpipe git:(master) gcc test.c testSigpipe git:(master) 。/a.out && echo “hello world” #&&與運算,前面為真,才會執(zhí)行后邊的c 語言

可以看出,操作系統(tǒng)認(rèn)為main函數(shù)執(zhí)行失敗,因為main函數(shù)的返回值是11

testSigpipe git:(master) 。/a.out testSigpipe git:(master) echo $?11

若將main函數(shù)中返回值該為0的話:

testSigpipe git:(master) vim test.c testSigpipe git:(master) gcc test.c testSigpipe git:(master) 。/a.out && echo “hello world” #helloc 語言hello world

可以看出,正如我們所期望的一樣,main函數(shù)返回0,代表函數(shù)正常退出,執(zhí)行成功;返回非0,代表函數(shù)出先異常,執(zhí)行失敗。

main函數(shù)傳參

首先說明的是,可能有些人認(rèn)為main函數(shù)是不可傳入?yún)?shù)的,但是實際上這是錯誤的。main函數(shù)可以從命令行獲取參數(shù),從而提高代碼的復(fù)用性。

函數(shù)原形

為main函數(shù)傳參時,可選的main函數(shù)原形為:

int main(int argc , char* argv[],char* envp[]);

參數(shù)說明:

①、第一個參數(shù)argc表示的是傳入?yún)?shù)的個數(shù) 。

②、第二個參數(shù)char* argv[],是字符串?dāng)?shù)組,用來存放指向的字符串參數(shù)的指針數(shù)組,每一個元素指向一個參數(shù)。各成員含義如下:

argv[0]:指向程序運行的全路徑名。

argv[1]:指向執(zhí)行程序名后的第一個字符串 ,表示真正傳入的第一個參數(shù)。

argv[2]:指向執(zhí)行程序名后的第二個字符串 ,表示傳入的第二個參數(shù)。

…… argv[n]:指向執(zhí)行程序名后的第n個字符串 ,表示傳入的第n個參數(shù)。

規(guī)定:argv[argc]為NULL ,表示參數(shù)的結(jié)尾。

③、第三個參數(shù)char* envp[],也是一個字符串?dāng)?shù)組,主要是保存這用戶環(huán)境中的變量字符串,以NULL結(jié)束。envp[]的每一個元素都包含ENVVAR=value形式的字符串,其中ENVVAR為環(huán)境變量,value為其對應(yīng)的值。

envp一旦傳入,它就只是單純的字符串?dāng)?shù)組而已,不會隨著程序動態(tài)設(shè)置發(fā)生改變。可以使用putenv函數(shù)實時修改環(huán)境變量,也能使用getenv實時查看環(huán)境變量,但是envp本身不會發(fā)生改變;平時使用到的比較少。

注意:main函數(shù)的參數(shù)char* argv[]和char* envp[]表示的是字符串?dāng)?shù)組,書寫形式不止char* argv[]這一種,相應(yīng)的argv[][]和 char** argv均可。

char* envp[]

寫個小測試程序,測試main函數(shù)的第三個參數(shù):

#include 《stdio.h》int main(int argc ,char* argv[] ,char* envp[]){ int i = 0; while(envp[i++]) { printf(“%s”, envp[i]); } return 0;}

運行結(jié)果:部分截圖

envp[] 獲得的信息等同于Linux下env命令的結(jié)果。

常用版本

在使用main函數(shù)的帶參版本的時,最常用的就是:**int main(int argc , char* argv[]);**變量名稱argc和argv是常規(guī)的名稱,當(dāng)然也可以換成其他名稱。

命令行執(zhí)行的形式為:可執(zhí)行文件名 參數(shù)1 參數(shù)2 … … 參數(shù)n。可執(zhí)行文件名稱和參數(shù)、參數(shù)之間均使用空格隔開。

示例程序

#include 《stdio.h》int main(int argc, char* argv[]){ int i; printf(“Total %d arguments”,argc); for(i = 0; i 《 argc; i++) { printf(“Argument argv[%d] = %s ”,i, argv[i]); } return 0;}

運行結(jié)果:

cpp_workspace git:(master) vim testmain.c cpp_workspace git:(master) gcc testmain.c cpp_workspace git:(master) 。/a.out 1 2 3 #./a.out為程序名 1為第一個參數(shù) , 2 為第二個參數(shù), 3 為第三個參數(shù)Total 4 argumentsArgument argv[0] = 。/a.out Argument argv[1] = 1 Argument argv[2] = 2 Argument argv[3] = 3 Argument argv[4] = (null) #默認(rèn)argv[argc]為null

main的執(zhí)行順序

可能有的人會說,這還用說,main函數(shù)肯定是程序執(zhí)行的第一個函數(shù)。那么,事實果然如此嗎?相信在看了本節(jié)之后,會有不一樣的認(rèn)識。

為什么說main()是程序的入口

linux系統(tǒng)下程序的入口是”_start”,這個函數(shù)是linux系統(tǒng)庫(Glibc)的一部分,當(dāng)我們的程序和Glibc鏈接在一起形成最終的可執(zhí)行文件的之后,這個函數(shù)就是程序執(zhí)行初始化的入口函數(shù)。通過一個測試程序來說明:

#include 《stdio.h》int main(){ printf(“Hello world”); return 0;}

編譯:

gcc testmain.c -nostdlib # -nostdlib (不鏈接標(biāo)準(zhǔn)庫)

程序執(zhí)行會引發(fā)錯誤:/usr/bin/ld: warning: cannot find entry symbol _start;未找到這個符號

所以說:

編譯器缺省是找 __start 符號,而不是 main

__start 這個符號是程序的起始

main 是被標(biāo)準(zhǔn)庫調(diào)用的一個符號

那么,這個_start和main函數(shù)有什么關(guān)系呢?下面我們來進(jìn)行進(jìn)一步探究。

_start函數(shù)的實現(xiàn)該入口是由ld鏈接器默認(rèn)的鏈接腳本指定的,當(dāng)然用戶也可以通過參數(shù)進(jìn)行設(shè)定。_start由匯編代碼實現(xiàn)。大致用如下偽代碼表示:

void _start(){ %ebp = 0; int argc = pop from stack char ** argv = top of stack; __libc_start_main(main, argc, argv, __libc_csu_init, __linc_csu_fini, edx, top of stack);}

對應(yīng)的匯編代碼如下:

_start: xor ebp, ebp //清空ebp pop esi //保存argc,esi = argc mov esp, ecx //保存argv, ecx = argv push esp //參數(shù)7保存當(dāng)前棧頂 push edx //參數(shù)6 push __libc_csu_fini//參數(shù)5 push __libc_csu_init//參數(shù)4 push ecx //參數(shù)3 push esi //參數(shù)2 push main//參數(shù)1 call _libc_start_mainhlt

可以看出,在調(diào)用_start之前,裝載器就會將用戶的參數(shù)和環(huán)境變量壓入棧中。

main函數(shù)運行之前的工作

從_start的實現(xiàn)可以看出,main函數(shù)執(zhí)行之前還要做一系列的工作。主要就是初始化系統(tǒng)相關(guān)資源:

Some of the stuff that has to happen before main():set up initial stack pointer initialize static and global data zero out uninitialized data run global constructorsSome of this comes with the runtime library‘s crt0.o file or its __start() function. Some of it you need to do yourself.Crt0 is a synonym for the C runtime library.

1.設(shè)置棧指針

2.初始化static靜態(tài)和global全局變量,即data段的內(nèi)容

3.將未初始化部分的賦初值:數(shù)值型short,int,long等為0,bool為FALSE,指針為NULL,等等,即.bss段的內(nèi)容

4.運行全局構(gòu)造器,類似c++中全局構(gòu)造函數(shù)

5.將main函數(shù)的參數(shù),argc,argv等傳遞給main函數(shù),然后才真正運行main函數(shù)

main之前運行的代碼

下面,我們就來說說在mian函數(shù)執(zhí)行之前到底會運行哪些代碼:(1)全局對象的構(gòu)造函數(shù)會在main 函數(shù)之前執(zhí)行。

(2)一些全局變量、對象和靜態(tài)變量、對象的空間分配和賦初值就是在執(zhí)行main函數(shù)之前,而main函數(shù)執(zhí)行完后,還要去執(zhí)行一些諸如釋放空間、釋放資源使用權(quán)等操作

(3)進(jìn)程啟動后,要執(zhí)行一些初始化代碼(如設(shè)置環(huán)境變量等),然后跳轉(zhuǎn)到main執(zhí)行。全局對象的構(gòu)造也在main之前。

(4)通過關(guān)鍵字attribute,讓一個函數(shù)在主函數(shù)之前運行,進(jìn)行一些數(shù)據(jù)初始化、模塊加載驗證等。

示例代碼

①、通過關(guān)鍵字attribute

#include 《stdio.h》__attribute__((constructor)) void before_main_to_run() { printf(“Hi~,i am called before the main function!”); printf(“%s”,__FUNCTION__); } __attribute__((destructor)) void after_main_to_run() { printf(“%s”,__FUNCTION__); printf(“Hi~,i am called after the main function!”);} int main( int argc, char ** argv ) { printf(“i am main function, and i can get my name(%s) by this way.”,__FUNCTION__); return 0; }

②、全局變量的初始化

#include 《iostream》using namespace std;inline int startup_1(){ cout《《“startup_1 run”《《endl; return 0;}int static no_use_variable_startup_1 = startup_1();int main(int argc, const char * argv[]) { cout《《“this is main”《《endl; return 0;}

至此,我們就聊完了main函數(shù)執(zhí)行之前的事情,那么,你是否還以為main函數(shù)也是程序運行的最后一個函數(shù)呢?

結(jié)果當(dāng)然不是,在main函數(shù)運行之后還有其他函數(shù)可以執(zhí)行,main函數(shù)執(zhí)行完畢之后,返回到入口函數(shù),入口函數(shù)進(jìn)行清理工作,包括全局變量析構(gòu)、堆銷毀、關(guān)閉I/O等,然后進(jìn)行系統(tǒng)調(diào)用結(jié)束進(jìn)程。

main函數(shù)之后執(zhí)行的函數(shù)

1、全局對象的析構(gòu)函數(shù)會在main函數(shù)之后執(zhí)行;2、用atexit注冊的函數(shù)也會在main之后執(zhí)行。

atexit函數(shù)

原形:

int atexit(void (*func)(void));

atexit 函數(shù)可以“注冊”一個函數(shù),使這個函數(shù)將在main函數(shù)正常終止時被調(diào)用,當(dāng)程序異常終止時,通過它注冊的函數(shù)并不會被調(diào)用。

編譯器必須至少允許程序員注冊32個函數(shù)。如果注冊成功,atexit 返回0,否則返回非零值,沒有辦法取消一個函數(shù)的注冊。

在 exit 所執(zhí)行的任何標(biāo)準(zhǔn)清理操作之前,被注冊的函數(shù)按照與注冊順序相反的順序被依次調(diào)用。每個被調(diào)用的函數(shù)不接受任何參數(shù),并且返回類型是 void。被注冊的函數(shù)不應(yīng)該試圖引用任何存儲類別為 auto 或 register 的對象(例如通過指針),除非是它自己所定義的。

多次注冊同一個函數(shù)將導(dǎo)致這個函數(shù)被多次調(diào)用。函數(shù)調(diào)用的最后的操作就是出棧過程。main()同樣也是一個函數(shù),在結(jié)束時,按出棧的順序調(diào)用使用atexit函數(shù)注冊的,所以說,函數(shù)atexit是注冊的函數(shù)和函數(shù)入棧出棧一樣,是先進(jìn)后出的,先注冊的后執(zhí)行。通過atexit可以注冊回調(diào)清理函數(shù)。可以在這些函數(shù)中加入一些清理工作,比如內(nèi)存釋放、關(guān)閉打開的文件、關(guān)閉socket描述符、釋放鎖等等。

#include《stdio.h》#include《stdlib.h》void fn0( void ), fn1( void ), fn2( void ), fn3( void ), fn4( void );int main( void ){ //注意使用atexit注冊的函數(shù)的執(zhí)行順序:先注冊的后執(zhí)行 atexit( fn0 ); atexit( fn1 ); atexit( fn2 ); atexit( fn3 ); atexit( fn4 ); printf( “This is executed first.” ); printf(“main will quit now!”); return 0;}void fn0(){ printf( “first register ,last call” );}void fn1({ printf( “next.” );}void fn2(){ printf( “executed ” );}void fn3(){ printf( “is ” );}void fn4(){ printf( “This ” );}

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • C語言
    +關(guān)注

    關(guān)注

    180

    文章

    7624

    瀏覽量

    139452
  • 編程
    +關(guān)注

    關(guān)注

    88

    文章

    3670

    瀏覽量

    94616
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4361

    瀏覽量

    63644
收藏 人收藏

    評論

    相關(guān)推薦

    為什么不需要給回調(diào)函數(shù)傳遞參數(shù)

    回調(diào)函數(shù)C語言里面一個重要機(jī)制。
    的頭像 發(fā)表于 04-15 10:11 ?69次閱讀

    C語言如何處理函數(shù)的返回值

    的那樣,直接把 1234 賦值給了變量 ret? 搞懂這個問題不難,只要看下匯編代碼就行。 把代碼編譯一下,只編譯不鏈接,得到的就是C對應(yīng)的匯編代碼。 這塊是 test 函數(shù),不用管上面這些代碼,如果一行一行去分析,沒有匯編基礎(chǔ)的話確實會頭疼。 看下這行代碼,很明顯,12
    的頭像 發(fā)表于 01-16 09:21 ?264次閱讀

    EE-128:C語言中的DSP:從C調(diào)用匯編類成員函數(shù)

    電子發(fā)燒友網(wǎng)站提供《EE-128:C語言中的DSP:從C調(diào)用匯編類成員函數(shù).pdf》資料免費下載
    發(fā)表于 01-07 13:48 ?0次下載
    EE-128:<b class='flag-5'>C</b><b class='flag-5'>語言</b>中的DSP:從<b class='flag-5'>C</b>調(diào)用匯編類成員<b class='flag-5'>函數(shù)</b>

    C語言筆試題

    來看一個C語言筆試題,應(yīng)該很少有人能給出正確答案。 #include int f(){ printf("this is f ..."); return 1;}int g(){ printf
    的頭像 發(fā)表于 12-30 09:48 ?293次閱讀

    同樣是函數(shù),在CC++中有什么區(qū)別

    同樣是函數(shù),在 CC++ 中有什么區(qū)別? 第一個返回值。 C語言函數(shù)可以不寫返回值類型,
    的頭像 發(fā)表于 11-29 10:25 ?679次閱讀

    使用C語言實現(xiàn)函數(shù)模板

      用C語言能不能實現(xiàn)一個通用的函數(shù),既能完成整數(shù)的相加,又能完成浮點數(shù)的相加?
    的頭像 發(fā)表于 11-09 11:38 ?701次閱讀

    C語言中的socket編程基礎(chǔ)

    數(shù)據(jù) 步驟6:關(guān)閉socket 創(chuàng)建socket 在C語言中,創(chuàng)建socket需要使用socket()函數(shù)。這個函數(shù)需要兩個參數(shù):域
    的頭像 發(fā)表于 11-01 16:51 ?813次閱讀

    C語言與Java語言的對比

    C語言和Java語言都是當(dāng)前編程領(lǐng)域中的重要成員,它們各自具有獨特的優(yōu)勢和特點,適用于不同的應(yīng)用場景。以下將從語法特性、內(nèi)存管理、跨平臺性、性能、應(yīng)用領(lǐng)域等多個方面對C
    的頭像 發(fā)表于 10-29 17:31 ?779次閱讀

    MEMS 可編程振蕩器的卓越代表:SiT9121 系列(1 to 220 MHZ)深度剖析

    MEMS 可編程振蕩器的卓越代表:SiT9121 系列(1 to 220 MHZ)深度剖析
    的頭像 發(fā)表于 08-13 10:56 ?803次閱讀
    MEMS 可編程振蕩器的卓越代表:SiT9121 系列(1 to 220 MHZ)<b class='flag-5'>深度</b><b class='flag-5'>剖析</b>

    探索巔峰性能 | 迅為RK3588開發(fā)板深度剖析

    探索巔峰性能 | 迅為RK3588開發(fā)板深度剖析
    的頭像 發(fā)表于 08-12 14:07 ?1302次閱讀
    探索巔峰性能 | 迅為RK3588開發(fā)板<b class='flag-5'>深度</b><b class='flag-5'>剖析</b>

    表面貼裝低相位噪音晶體振蕩器 DSO531SHH 深度剖析

    表面貼裝低相位噪音晶體振蕩器 DSO531SHH 深度剖析
    的頭像 發(fā)表于 07-26 14:12 ?567次閱讀
    表面貼裝低相位噪音晶體振蕩器 DSO531SHH <b class='flag-5'>深度</b><b class='flag-5'>剖析</b>

    利用Matlab函數(shù)實現(xiàn)深度學(xué)習(xí)算法

    在Matlab中實現(xiàn)深度學(xué)習(xí)算法是一個復(fù)雜但強(qiáng)大的過程,可以應(yīng)用于各種領(lǐng)域,如圖像識別、自然語言處理、時間序列預(yù)測等。這里,我將概述一個基本的流程,包括環(huán)境設(shè)置、數(shù)據(jù)準(zhǔn)備、模型設(shè)計、訓(xùn)練過程、以及測試和評估,并提供一個基于Matlab的
    的頭像 發(fā)表于 07-14 14:21 ?2955次閱讀

    PLC編程語言C語言的區(qū)別

    在工業(yè)自動化和計算機(jī)編程領(lǐng)域中,PLC(可編程邏輯控制器)編程語言C語言各自扮演著重要的角色。盡管兩者都是編程語言,但它們在多個方面存在顯著的區(qū)別。本文將從多個維度深入探討PLC編程
    的頭像 發(fā)表于 06-14 17:11 ?4057次閱讀

    請問為什么非main.c的其他文件能調(diào)用庫函數(shù)

    main.c中調(diào)用庫函數(shù)我可能理解: 是因為在main.c中引用了#include \"sys.h\"頭文件,而這個頭文件包含了各庫函數(shù)的定義聲明。 但其他文件諸如這樣
    發(fā)表于 04-25 06:49

    提高C代碼可讀性的編寫技巧與策略

    指針是 C 語言的靈魂,是 C 比其他語言更靈活,更強(qiáng)大的地方。所以學(xué)習(xí) C 語言必須很好的掌握
    發(fā)表于 04-23 18:25 ?675次閱讀
    主站蜘蛛池模板: 黄色工厂在线播放 | 天天干天天骑 | 日韩三级视频在线观看 | 日本全黄视频 | 国产亚洲综合色就色 | 精品国产乱码一区二区三区 | www.色播| 中文字幕一区二区在线观看 | 国产精品久久女同磨豆腐 | 亚洲国产色婷婷精品综合在线观看 | 四虎永久影院永久影库 | 天天夜夜人人 | 国产亚洲欧美一区 | 美国bj69video18视频 | 午夜色a大片在线观看免费 午夜色大片在线观看 | 色婷婷色综合 | 色婷综合 | aa视频在线 | videosex久久麻豆| 网站在线播放 | 婷婷在线五月 | 97伊人久久 | 天堂8资源8在线 | 68日本xxxxxxxxx777| 欧美日韩精品一区二区在线线 | 自拍偷拍综合网 | 可以免费观看的一级毛片 | 欧美性猛交xxxx黑人猛交 | 91在线国内在线播放大神 | 一级日本高清视频免费观看 | 一区中文字幕 | 久久天天躁夜夜躁狠狠躁2020 | 亚洲阿v天堂2018在线观看 | 亚洲毛片大全 | 四虎永久在线精品免费观看地址 | 九九福利视频 | 日日操夜夜 | 成人午夜在线观看国产 | 国产美女动态免费视频 | 啪啪黄色片 | 国产卡1卡2卡三卡网站免费 |