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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > Ubuntu >内容正文

Ubuntu

GDB调试程序-Ubuntu

發(fā)布時(shí)間:2024/4/15 Ubuntu 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 GDB调试程序-Ubuntu 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

導(dǎo)讀:


用GDB調(diào)試程序
出自Ubuntu中文
目錄
[隱藏]
1 GDB概述
2 一個(gè)調(diào)試示例
3 使用GDB
4 GDB的命令概貌
5 GDB中運(yùn)行UNIX的shell程序
6 在GDB中運(yùn)行程序
7 調(diào)試已運(yùn)行的程序
8 暫停/恢復(fù)程序運(yùn)行
8.1 設(shè)置斷點(diǎn)(Break Points)
8.2 設(shè)置觀察點(diǎn)(WatchPoint)
8.3 設(shè)置捕捉點(diǎn)(CatchPoint)
8.4 維護(hù)停止點(diǎn)
8.5 停止條件維護(hù)
8.6 為停止點(diǎn)設(shè)定運(yùn)行命令
8.7 斷點(diǎn)菜單
8.8 恢復(fù)程序運(yùn)行和單步調(diào)試
8.9 信號(hào)(Signals)
8.10 線程(Thread Stops)
9 查看棧信息
10 查看源程序
10.1 顯示源代碼
10.2 搜索源代碼
10.3 指定源文件的路徑
10.4 源代碼的內(nèi)存
11 查看運(yùn)行時(shí)數(shù)據(jù)
11.1 表達(dá)式
11.2 程序變量
11.3 數(shù)組
11.4 輸出格式
11.5 查看內(nèi)存
11.6 自動(dòng)顯示
11.7 設(shè)置顯示選項(xiàng)
11.8 歷史記錄
11.9 GDB環(huán)境變量
11.10 查看寄存器
12 改變程序的執(zhí)行
12.1 修改變量值
12.2 跳轉(zhuǎn)執(zhí)行
12.3 產(chǎn)生信號(hào)量
12.4 強(qiáng)制函數(shù)返回
12.5 強(qiáng)制調(diào)用函數(shù)
13 在不同語言中使用GDB
14 後記
15 相關(guān)詞條
?
?
用GDB調(diào)試程序(zz)
作 者:haoel (QQ是:753640,MSN是:haoel@hotmail.com )
來源:http://blog.csdn.net/haoel/archive/2003/07/02/2879.aspx
1.GDB概述
GDB 是GNU開源組織發(fā)布的一個(gè)強(qiáng)大的UNIX
下的程序調(diào)試工具。或許,各位比較喜歡那種圖形界面方 式的,像VC、BCB等IDE
的調(diào)試,但如果你是在 UNIX平臺(tái)下做軟件,你會(huì)發(fā)現(xiàn)GDB這個(gè)調(diào)試工具有比VC、BCB
的圖形化調(diào)試器 更強(qiáng)大的功能。所謂“寸有所長(zhǎng),尺有所短”就是這個(gè)道理。

一般來說,GDB主要幫忙你完成下面四個(gè)方面的功能:

啟動(dòng)你的程序,可以按照你的自定義的要求隨心所欲的運(yùn)行程序。
可讓被調(diào)試的程序在你所指定的調(diào)置的斷點(diǎn)處停住。(斷點(diǎn)可以是條件表達(dá)式)
當(dāng)程序被停住時(shí),可以檢查此時(shí)你的程序中所發(fā)生的事。
動(dòng)態(tài)的改變你程序的執(zhí)行環(huán)境。
從上面看來,GDB
和一般的調(diào) 試工具沒有什么兩樣,基本上也是完成這些功能,不過在細(xì)節(jié)上,你會(huì)發(fā)現(xiàn)
GDB
這個(gè)調(diào)試工具的強(qiáng)大,大家可能比較習(xí)慣了圖形化的調(diào)試工具, 但有時(shí)候,命令行的調(diào)試?
ぞ呷從兇磐夾位ぞ咚荒芡瓿傻墓δ堋H夢(mèng)頤且灰豢蠢礎(chǔ)?

2.一個(gè)調(diào)試示例
源程序:tst.c

?1 #include <stdio.h
>????????????????????????????????????????????????????????????????
?2
?3 int func(int n)
?4 {
?5???? int sum=0,i;
?6???? for(i=1; i<=n; i++)
?7???? {
?8???????? sum+=i;
?9???? }
10???? return sum;
11 }
12
13
14 int main()
15 {
16???? int i;
17???? long result = 0;
18???? for(i=1; i<=100; i++)
19???? {
20???????? result += i;
21???? }
22
23???? printf("result[1-100] = %ld /n", result );
24???? printf("result[1-250] = %d /n", func(250) );
25???? return 0;
26 }
27

編譯生成執(zhí)行文件:

$gcc -g -Wall tst.c -o tst

使用GDB調(diào)試:

$ gdb tst?? <---------- 啟動(dòng)GDB
GNU gdb 6.7.1-debian
Copyright (C) 2007 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html >
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.? Type "show copying"
and "show warranty" for details.
This GDB was configured as "i486-linux-gnu"...
Using host libthread_db library "/lib/tls/i686/cmov/libthread_db.so.1".
(gdb) l 1?? <-------------------- l命令相當(dāng)于list,從第一行開始例出原碼。
1?????? #include <stdio.h>
2
3?????? int func(int n)
4?????? {
5?????????????? int sum=0,i;
6?????????????? for(i=1; i<=n; i++)
7?????????????? {
8?????????????????????? sum+=i;
9?????????????? }
10????????????? return sum;
(gdb)??? <-------------------- 直接回車表示,重復(fù)上一次命令
11????? }
12
13
14????? int main()
15????? {
16????????????? int i;
17????????????? long result = 0;
18????????????? for(i=1; i<=100; i++)
19????????????? {
20???result += i;
(gdb) break 16??? <-------------------- 設(shè)置斷點(diǎn),在源程序第16行處。
Breakpoint 1 at 0x80483b2: file tst.c, line 16.
(gdb) break func?? <-------------------- 設(shè)置斷點(diǎn),在函數(shù)func()入口處。
Breakpoint 2 at 0x804837a: file tst.c, line 5.
(gdb) info break?? <-------------------- 查看斷點(diǎn)信息。
Num Type?????????? Disp Enb Address??? What
1?? breakpoint???? keep y?? 0x080483b2 in main at tst.c:16
2?? breakpoint???? keep y?? 0x0804837a in func at tst.c:5
(gdb) r??? <--------------------- 運(yùn)行程序,run命令簡(jiǎn)寫
Starting program: /home/dbzhang/tst

Breakpoint 1, main () at tst.c:17
17??long result = 0;
(gdb) n???? <--------------------- 單條語句執(zhí)行,next命令簡(jiǎn)寫。
18??for(i=1; i<=100; i++)
(gdb) n
20???result += i;
(gdb) n
18??for(i=1; i<=100; i++)
(gdb) n
20???result += i;
(gdb) c??? <--------------------- 繼續(xù)運(yùn)行程序,continue命令簡(jiǎn)寫。
Continuing.
result[1-100] = 5050??? <----------程序輸出。

Breakpoint 2, func (n=250) at tst.c:5
5??int sum=0,i;
(gdb) n
6??for(i=1; i<=n; i++)
(gdb) p i?? <--------------------- 打印變量i的值,print命令簡(jiǎn)寫。
$1 = -1074568236
(gdb) n
8???sum+=i;
(gdb) n
6??for(i=1; i<=n; i++)
(gdb) p sum
$2 = 1
(gdb) n
8???sum+=i;
(gdb) p i
$3 = 2
(gdb) n
6??for(i=1; i<=n; i++)
(gdb) p sum
$4 = 3
(gdb) bt?? <--------------------- 查看函數(shù)堆棧。
#0? func (n=250) at tst.c:6
#1? 0x080483f1 in main () at tst.c:24
(gdb) finish?? <--------------------- 退出函數(shù)。
Run till exit from #0? func (n=250) at tst.c:6
0x080483f1 in main () at tst.c:24
24??printf("result[1-250] = %d /n", func(250) );
Value returned is $5 = 31375
(gdb) c?? <--------------------- 繼續(xù)運(yùn)行。
Continuing.
result[1-250] = 31375??? <----------程序輸出。

Program exited normally.?? <--------程序退出,調(diào)試結(jié)束。
(gdb) q?? <--------------------- 退出gdb。


好了,有了以上的感性認(rèn)識(shí),還是讓我們來系統(tǒng)地認(rèn)識(shí)一下gdb吧。

3.使用GDB
一般來說GDB主要調(diào)試的是C/C++的程序。要調(diào)試C/C
++的程序,首先在編譯時(shí),我們必須要把調(diào)試信息 加到可執(zhí)行文件中。使用編譯器(cc/
gcc/g++)的 -g 參數(shù)可以做到這一點(diǎn)。如:

$gcc -g -Wall hello.c -o hello
$g++ -g -Wall hello.cpp -o hello

如果沒有-g
,你將看不見程序的函數(shù)名、變量名,所代替的全是運(yùn)行時(shí)的內(nèi)存地址。當(dāng)你用-g
把調(diào)試信息加入之後,并成功編譯目標(biāo)代 碼以後,讓我們來看看如何用gdb來調(diào)試他。

啟動(dòng)GDB的方法有以下幾種:

gdb <program>
program也就是你的執(zhí)行文件,一般在當(dāng)然目錄下。
gdb <program> core
用gdb同時(shí)調(diào)試一個(gè)運(yùn)行程序和core文件,core是程序非法執(zhí)行後core dump
後 產(chǎn)生的文件。
gdb <program> <PID>
如果你的程序是一個(gè)服務(wù)程序,那么你可以指定這個(gè)服務(wù) 程序運(yùn)行時(shí)的進(jìn)程ID。gdb
會(huì)自動(dòng)attach上去,并調(diào)試他。program應(yīng)該在PATH環(huán)境變量中搜索得到。
GDB啟動(dòng)時(shí),可 以加上一些GDB的啟動(dòng)開關(guān),詳細(xì)的開關(guān)可以用gdb -help
查看。我在下面只例舉一些比較常用的參數(shù):

-symbols <file>
-s <file>
從指定文件中讀取符號(hào)表。
-se file
從指定文件中讀取符號(hào)表信息,并把他用在可執(zhí)行文件中。
-core <file>
-c <file>
調(diào)試時(shí)core dump的core文件。
-directory <directory>
-d <directory>
加入一個(gè)源文件的搜索路徑。默認(rèn)搜索路徑是環(huán)境變量中PATH所定義的路徑。
4. GDB的命令概貌
啟動(dòng)gdb後,就你被帶入gdb的調(diào)試環(huán)境中,就可以使用gdb的命令開始調(diào)試程序了,gdb
的命令可以使用help命 令來查看,如下所示:

$ gdb
GNU gdb 6.7.1-debian
Copyright (C) 2007 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html >
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.? Type "show copying"
and "show warranty" for details.
This GDB was configured as "i486-linux-gnu".
(gdb) help
List of classes of commands:

aliases -- Aliases of other commands
breakpoints -- Making program stop at certain points
data -- Examining data
files -- Specifying and examining files
internals -- Maintenance commands
obscure -- Obscure features
running -- Running the program
stack -- Examining the stack
status -- Status inquiries
support -- Support facilities
tracepoints -- Tracing of program execution without stopping the program
user-defined -- User-defined commands

Type "help" followed by a class name for a list of commands in that class.
Type "help all" for the list of all commands.
Type "help" followed by command name for full documentation.
Type "apropos word" to search for commands related to "word".
Command name abbreviations are allowed if unambiguous.
(gdb)

gdb 的命令很多,gdb把之分成許多個(gè)種類。help命令只是例出gdb
的命令種類,如果要看種類中的命令,可以使用help <class> 命令,如:help
breakpoints,查看設(shè)置斷點(diǎn)的所有命令。也可以直接help <command
>來查看命令的幫助。

gdb
中,輸入命令時(shí),可以不用打全命令,只用打命令的前幾個(gè)字符就可以了,當(dāng)然,命令的?
凹父鱟址Ω靡曛咀乓桓鑫ㄒ壞拿睿 贚inux下,你可以敲擊兩次TAB
鍵來補(bǔ)齊命令的全稱,如果有重復(fù)的,那么gdb會(huì)把其例出來。

示例一:在進(jìn)入函數(shù)func時(shí),設(shè)置一個(gè)斷點(diǎn)。可以敲入break func,或是直接就是b func

(gdb) b func
Breakpoint 1 at 0x804837a: file tst.c, line 5.

示例二:敲入b按兩次TAB鍵,你會(huì)看到所有b打頭的命令:

(gdb) b
backtrace break bt
(gdb)

示例三:只記得函數(shù)的前綴,可以這樣:

(gdb) b make_ <按TAB鍵>
(再按下一次TAB鍵,你會(huì)看到:)
make_a_section_from_file make_environ
make_abs_section make_function_type
make_blockvector make_pointer_type
make_cleanup make_reference_type
make_command make_symbol_completion_list
(gdb) b make_
GDB把所有make開頭的函數(shù)全部例出來給你查 看。

示例四:調(diào)試C++的程序時(shí),有可以函數(shù)名一樣。如:

(gdb) b 'bubble( M-?
bubble(double,double) bubble(int,int)
(gdb) b 'bubble(

你可以查看到C++中的所有的重載函數(shù)及參數(shù)。(注:M-?和“按兩次TAB
鍵”是一個(gè)意思)

要退出gdb時(shí),只用發(fā)quit或命令簡(jiǎn)稱q就行了。

5. GDB中運(yùn)行UNIX的shell程序
在gdb環(huán)境中,你可以執(zhí)行UNIX的shell的命令,使用gdb的shell命令來完 成:

shell <command string>

調(diào)用UNIX的shell來執(zhí)行<command string>,環(huán)境變量SHELL中定義的UNIX的shell
將會(huì)被用 來執(zhí)行<command string>,如果SHELL沒有定義,那就使用UNIX的標(biāo)準(zhǔn)shell:/
bin/sh。(在 Windows中使用Command.com或cmd.exe)

還有一個(gè)gdb命令是make:

make <make-args>

可以在gdb中執(zhí)行make命令來重新build自己的程序。這個(gè)命令等價(jià)于“shell make <make
-args>”。

?

6. 在GDB中運(yùn)行程序
當(dāng)以gdb <program>方式啟動(dòng)gdb後,gdb會(huì)在PATH路徑和當(dāng)前目錄中搜索<program
>的源文件。如要確認(rèn) gdb是否讀到源文件,可使用l或list命令,看看gdb
是否能列出源代碼。

在gdb中,運(yùn)行程序使用r或是run
命令。程序的運(yùn)行,你有可能需要設(shè)置下面四方面的事。

1、程序運(yùn)行參數(shù)。
set args 可指定運(yùn)行時(shí)參數(shù)。(如:set args 10 20 30 40 50)
show args 命令可以查看設(shè)置好的運(yùn)行參數(shù)。

2、運(yùn)行環(huán)境。
path <dir> 可設(shè)定程序的運(yùn)行路徑。
show paths 查看程序的運(yùn)行路徑。
set environment varname [=value] 設(shè)置環(huán)境變量。如:set env USER=hchen
show environment [varname] 查看環(huán)境變量。

3、工作目錄。
cd <dir> 相當(dāng)于shell的cd命令。
pwd 顯示當(dāng)前的所在目錄。

4、程序的輸入輸出。
info terminal 顯示你程序用到的終端的模式。
使用重定向控制程序輸出。如:run > outfile
tty命令可以指寫輸入輸出的終端設(shè)備。如:tty /dev/ttyb

?

7.調(diào)試已運(yùn)行的程序
兩種方法:

在UNIX下用ps查看正在運(yùn)行的程序的PID(進(jìn)程ID),然後用gdb <program> PID
格式掛接正在運(yùn)行的程 序。
先用gdb <program>關(guān)聯(lián)上源代碼,并進(jìn)行g(shù)db,在gdb中用attach命令來掛接進(jìn)程的PID
。并用 detach來取消掛接的進(jìn)程。
8. 暫停/恢復(fù)程序運(yùn)行
調(diào)試程序中,暫停程序運(yùn)行是必須的,GDB
可以方便地暫停程序的 運(yùn)行。你可以設(shè)置程序的在哪行停住,在什么條件下停住,在收到?
裁蔥藕攀蓖M鵲取R員閿諛悴榭叢誦惺鋇謀淞浚約霸誦惺鋇牧鞒獺?

當(dāng)進(jìn)程被gdb停住時(shí),你可以使用info program
來查看程序的是否在運(yùn)行,進(jìn)程號(hào),被暫停的原因。

在gdb中,我們可以有以下幾種暫停方式:斷點(diǎn)(BreakPoint)、觀察點(diǎn)(Watch Point
)、捕捉點(diǎn)(Catch Point)、信號(hào)(Signals)、線程停止(Thread Stops
)。如果要恢復(fù)程序運(yùn)行,可以使用c或是 continue命令。

8.1 設(shè)置斷點(diǎn)(Break Points)
我們用break命令來設(shè)置斷點(diǎn)。正面有幾點(diǎn)設(shè)置斷點(diǎn)的方法:

break <function>
在進(jìn)入指定函數(shù)時(shí)停住。C++中可以使用class::function或 function(type,type)
格式來指定函數(shù)名。
break <linenum>
在指定行號(hào)停住。
break +offset
break -offset
在當(dāng)前行號(hào)的前面或後面的offset行停住。offiset為自然數(shù)。
break filename:linenum
在源文件filename的linenum行處停住。
break filename:function
在源文件filename的function函數(shù)的入口處停住。
break *address
在 程序運(yùn)行的內(nèi)存地址處停住。
break
break命令沒有參數(shù)時(shí),表示在下一條指令處停住。
break ... if <condition>
...可以是上述的參數(shù),condition
表示條件,在條件成立時(shí)停住。比如在循環(huán)境體中,可以 設(shè)置break if i=100,表示當(dāng)i
為100時(shí)停住程序。
查看斷點(diǎn)時(shí),可使用info命令,如下所示:(注:n表示斷點(diǎn)號(hào))

info breakpoints [n]
info break [n]
8.2 設(shè)置觀察點(diǎn)(WatchPoint)
觀 察點(diǎn)一般來觀察某個(gè)表達(dá)式(變量也是一種表達(dá)式)的值是否有變化了,如果有變化,?
砩賢W〕絳頡N頤怯邢旅嫻募鋼址椒ɡ瓷柚霉鄄斕悖?

watch <expr>
為表達(dá)式(變量)expr設(shè)置一個(gè)觀察點(diǎn)。一量表達(dá)式值有變化時(shí),馬上停住程序。
rwatch <expr>
當(dāng)表達(dá)式(變量)expr被讀時(shí),停住程序。
awatch <expr>
當(dāng)表達(dá)式 (變量)的值被讀或被寫時(shí),停住程序。
info watchpoints
列出當(dāng)前所設(shè)置了的所有觀察點(diǎn)。
8.3 設(shè)置捕捉點(diǎn)(CatchPoint)
?? 你可設(shè)置捕捉點(diǎn)來補(bǔ)捉程序運(yùn)行時(shí)的一些事件。如:載入共享庫(動(dòng)態(tài)鏈接庫)或是C
++的異常。 設(shè)置捕捉點(diǎn)的格式為:

catch <event>
當(dāng)event發(fā)生時(shí),停住程序。event可以是下面的內(nèi)容:

throw 一個(gè)C++拋出的異常。(throw為關(guān)鍵字)
catch 一個(gè)C++捕捉到的異常。(catch為關(guān)鍵字)
exec 調(diào)用系統(tǒng)調(diào)用exec時(shí)。(exec為關(guān)鍵字,目前此功能只在HP-UX下有用)
fork 調(diào)用系統(tǒng)調(diào)用fork時(shí)。(fork為關(guān)鍵字,目前此功能只在HP-UX下有用)
vfork 調(diào)用系統(tǒng)調(diào)用vfork時(shí)。(vfork為關(guān)鍵字,目前此功能只在HP-UX下有用)
load 或 load <libname> 載入共享庫(動(dòng)態(tài)鏈接庫)時(shí)。(load
為關(guān)鍵字,目前此功能只在HP-UX下有用)
unload 或 unload <libname> 卸載共享庫(動(dòng)態(tài)鏈接庫)時(shí)。(unload
為關(guān)鍵字,目前此功能只在HP-UX下有用)
tcatch <event>
只設(shè)置一次捕捉點(diǎn),當(dāng)程序停住以後,應(yīng)點(diǎn)被自動(dòng)刪除。

8.4 維護(hù)停止點(diǎn)
上面說了如何設(shè)置程序的停止點(diǎn),GDB中的停止點(diǎn)也就是上述的三類。在GDB
中,如果你覺得已定義好的停止點(diǎn) 沒有用了,你可以使用delete、clear、disable、
enable這幾個(gè)命令來進(jìn)行維護(hù)。

clear
清除所有的已定義的停止點(diǎn)。
clear <function>
clear <filename:function>
清除所有設(shè)置在函數(shù)上的停止點(diǎn)。
clear <linenum>
clear <filename:linenum>
清除所有設(shè)置在指定行上的停止點(diǎn)。
delete [breakpoints] [range...]
刪除指定的斷點(diǎn),breakpoints為斷點(diǎn)號(hào)。如果不指定斷點(diǎn)號(hào),則表示刪除所有的斷點(diǎn)。
range 表示斷點(diǎn)號(hào)的范圍(如:3-7)。其簡(jiǎn)寫命令為d。

比刪除更好的一種方法是disable停止點(diǎn),disable了的停止點(diǎn),GDB
不會(huì)刪除,當(dāng)你還需要時(shí),enable即可,就好像回收站 一樣。

disable [breakpoints] [range...]
disable所指定的停止點(diǎn),breakpoints為停止點(diǎn)號(hào)。 如果什么都不指定,表示disable
所有的停止點(diǎn)。簡(jiǎn)寫命令是dis.
enable [breakpoints] [range...]
enable所指定的停止點(diǎn),breakpoints為停止點(diǎn)號(hào)。
enable [breakpoints] once range...
enable所指定的停止點(diǎn)一次,當(dāng)程序停止後,該停止點(diǎn)馬上被GDB自動(dòng)disable。
enable [breakpoints] delete range...
enable所指定的停止點(diǎn)一次,當(dāng)程序停止後,該停止點(diǎn)馬上被GDB自動(dòng)刪 除。
8.5停止條件維護(hù)
前面在說到設(shè)置斷點(diǎn)時(shí),我們提到過可以設(shè)置一個(gè)條件,當(dāng)條件成立時(shí),程序自動(dòng)停止,?
饈且桓齜淺G 看蟮墓δ埽飫錚蟻胱潘鄧嫡飧鎏跫南喙匚っ睢R話憷此擔(dān)?
點(diǎn)設(shè)置一個(gè)條件,我們使用if
關(guān)鍵詞,後面跟其斷點(diǎn)條件。并且, 條件設(shè)置好後,我們可以用condition
命令來修改斷點(diǎn)的條件。(只有break和watch命令支持if,catch目前暫不支持if)

condition <bnum> <expression>
修改斷點(diǎn)號(hào)為bnum的停止條件為 expression。
condition <bnum>
清除斷點(diǎn)號(hào)為bnum的停止條件。

還有一個(gè)比較特殊的維護(hù)命令ignore,你可以指定程序運(yùn)行時(shí),忽略停止條件幾次。

ignore <bnum> <count>
表示忽略斷點(diǎn)號(hào)為bnum的停止條件count次。
8.6為停止點(diǎn)設(shè)定運(yùn)行命令
我們可以使用GDB提供的command
命令來設(shè)置停止點(diǎn)的運(yùn)行命令。也就是說,當(dāng)運(yùn)行的程序在被停止住時(shí), 我們可以讓其自?
誦幸恍┍鸕拿睿夂苡欣兇遠(yuǎn)魘浴6曰贕DB
的自動(dòng)化調(diào)試是一個(gè)強(qiáng)大的支持。

commands [bnum]
... command-list ...
end

為斷點(diǎn)號(hào)bnum指寫一個(gè)命令列表。當(dāng)程序被該斷點(diǎn)停住時(shí),gdb
會(huì)依次運(yùn)行命令列表中的命令。例如:

break foo if x>0
commands
printf "x is %d/n",x
continue
end

斷點(diǎn)設(shè)置在函數(shù)foo中,斷點(diǎn)條件是x>0,如果程序被斷住後,也就是,一旦x的值在foo
函數(shù)中大于0,GDB會(huì)自動(dòng)打印出x的 值,并繼續(xù)運(yùn)行程序。

如果你要清除斷點(diǎn)上的命令序列,那么只要簡(jiǎn)單的執(zhí)行一下commands命令,并直接在打個(gè)
end就行了。

8.7 斷點(diǎn)菜單
在C++中,可能會(huì)重復(fù)出現(xiàn)同一個(gè)名字的函數(shù)若干次(函數(shù)重載),在這種情況下,
break <function>不能告訴GDB要停在哪個(gè)函數(shù)的入口。當(dāng)然,你可以使用break <
function(type)> 也就是把函數(shù)的參數(shù)類型告訴GDB,以指定一個(gè)函數(shù)。否則的話,GDB
會(huì)給你列出一個(gè)斷點(diǎn)菜單供你選擇你所需要的斷點(diǎn)。你只要輸入你菜單列表中的 編號(hào)就可?
粵恕H紓?

(gdb) b String::after
[0] cancel
[1] all
[2] file:String.cc; line number:867
[3] file:String.cc; line number:860
[4] file:String.cc; line number:875
[5] file:String.cc; line number:853
[6] file:String.cc; line number:846
[7] file:String.cc; line number:735
> 2 4 6
Breakpoint 1 at 0xb26c: file String.cc, line 867.
Breakpoint 2 at 0xb344: file String.cc, line 875.
Breakpoint 3 at 0xafcc: file String.cc, line 846.
Multiple breakpoints were set.
Use the "delete" command to delete unwanted
breakpoints.
(gdb)

可見,GDB列出了所有after的重載函數(shù),你可以選一下列表編號(hào)就行了。0
表示放棄設(shè)置斷點(diǎn),1表示所有函數(shù)都設(shè)置斷點(diǎn)。

8.8 恢復(fù)程序運(yùn)行和單步調(diào)試
當(dāng)程序被停住了,你可以用continue
命令恢復(fù)程序的運(yùn)行直到程序結(jié)束,或下一個(gè)斷點(diǎn)到來。 也可以使用step或next
命令單步跟蹤程序。

continue [ignore-count]
c [ignore-count]
fg [ignore-count]
恢 復(fù)程序運(yùn)行,直到程序結(jié)束,或是下一個(gè)斷點(diǎn)到來。ignore-count
表示忽略其後的斷點(diǎn)次數(shù)。continue,c,fg三個(gè)命令都是一樣 的意思。
step <count>
單步跟蹤,如果有函數(shù)調(diào)用,他會(huì)進(jìn)入該函數(shù)。進(jìn)入函數(shù)的前提是,此函數(shù)被編譯有
debug 信息。很像VC等工具中的step in。後面可以加count
也可以不加,不加表示一條條地執(zhí)行,加表示執(zhí)行後面的count條指令,然後再停 住。
next <count>
同樣單步跟蹤,如果有函數(shù)調(diào)用,他不會(huì)進(jìn)入該函數(shù)。很像VC等工具中的step over
。 後面可以加count也可以不加,不加表示一條條地執(zhí)行,加表示執(zhí)行後面的count
條指令,然後再停住。
set step-mode
set step-mode on
打開step-mode模式,于是,在進(jìn)行單步跟蹤時(shí),程序不會(huì)因?yàn)闆]有debug
信息而不停住。這個(gè)參數(shù) 有很利于查看機(jī)器碼。
set step-mod off
關(guān)閉step-mode模式。
finish
運(yùn)行程序,直 到當(dāng)前函數(shù)完成返回。并打印函數(shù)返回時(shí)的堆棧地址和返回值及參數(shù)值等信?
ⅰ?
until 或 u
當(dāng)你厭倦了在一個(gè)循環(huán)體內(nèi)單步 跟蹤時(shí),這個(gè)命令可以運(yùn)行程序直到退出循環(huán)體。
stepi 或 si
nexti 或 ni
單步跟蹤一條機(jī)器指令!一條程序代 碼有可能由數(shù)條機(jī)器指令完成,stepi和nexti
可以單步執(zhí)行機(jī)器指令。與之一樣有相同功能的命令是 “display/i $pc”
, 當(dāng)運(yùn)行完這個(gè)命令後,單步跟蹤會(huì)在打出程序代碼的同時(shí)打出機(jī)器指令(也就是匯編代?
耄?
8.9信號(hào)(Signals)
信號(hào)是 一種軟中斷,是一種處理異步事件的方法。一般來說,操作系統(tǒng)都支持許多信號(hào)。?
繞涫?UNIX,比較重要應(yīng)用程序一般都會(huì)處理信號(hào)。UNIX定義 了許多信號(hào),比如SIGINT
表示中斷字符信號(hào),也就是Ctrl+C的信號(hào),SIGBUS表示硬件故障的信號(hào);SIGCHLD
表示子進(jìn)程 狀態(tài)改變信號(hào);SIGKILL表示終止程序運(yùn)行的信號(hào),等等。信號(hào)量編程是UNIX
下非常重要的一種技術(shù)。

GDB有能力在你調(diào)試程序的時(shí)候處理任何一種信號(hào),你可以告訴GDB
需要處理哪一種信號(hào)。你可以要求GDB
收到你所指定的信號(hào)時(shí), 馬上停住正在運(yùn)行的程序,以供你進(jìn)行調(diào)試。你可以用GDB的
handle命令來完成這一功能。

handle <signal> <keywords...>

在GDB中定義一個(gè)信號(hào)處理。信號(hào)<signal>可以以SIG開頭或不以SIG
開頭,可以用定義一個(gè)要處理信號(hào)的范圍 (如:SIGIO- SIGKILL,表示處理從SIGIO
信號(hào)到SIGKILL的信號(hào),其中包括SIGIO,SIGIOT,SIGKILL
三 個(gè)信號(hào)),也可以使用關(guān)鍵字 all
來標(biāo)明要處理所有的信號(hào)。一旦被調(diào)試的程序接收到信號(hào),運(yùn)行程序馬上會(huì)被GDB
停住,以供調(diào)試。 其<keywords>可以是以下幾種關(guān)鍵字的一個(gè)或多個(gè)。

nostop
當(dāng)被調(diào)試的程序收到信號(hào)時(shí),GDB
不會(huì)停住程序的運(yùn)行,但會(huì)打出消息告訴你收到這種信號(hào)。
stop
當(dāng) 被調(diào)試的程序收到信號(hào)時(shí),GDB會(huì)停住你的程序。
print
當(dāng)被調(diào)試的程序收到信號(hào)時(shí),GDB會(huì)顯示出一條信息。
noprint
當(dāng)被調(diào)試的程序收到信號(hào)時(shí),GDB不會(huì)告訴你收到信號(hào)的信息。
pass
noignore
當(dāng)被調(diào)試的程序收到信號(hào) 時(shí),GDB不處理信號(hào)。這表示,GDB
會(huì)把這個(gè)信號(hào)交給被調(diào)試程序會(huì)處理。
nopass
ignore
當(dāng)被調(diào)試的程序 收到信號(hào)時(shí),GDB不會(huì)讓被調(diào)試程序來處理這個(gè)信號(hào)。
info signals
info handle
查看有哪些信號(hào)在被 GDB檢測(cè)中。
8.10 線程(Thread Stops)
如果你程序是多線程的話,你可以定義你的斷點(diǎn)是否在所有的線程上,或是在某 個(gè)特定的?
叱獺DB很容易幫你完成這一工作。

break <linespec> thread <threadno>
break <linespec> thread <threadno> if ...

linespec指定了斷點(diǎn)設(shè)置在的源程序的行號(hào)。threadno指定了線程的ID,注意,這個(gè)ID是
GDB分配的,你可以通過 “info threads
”命令來查看正在運(yùn)行程序中的線程信息。如果你不指定thread <threadno
>則表示 你的斷點(diǎn)設(shè)在所有線程上面。你還可以為某線程指定斷點(diǎn)條件。如:

(gdb) break frik.c:13 thread 28 if bartab > lim

當(dāng)你的程序被GDB
停住時(shí),所有的運(yùn)行線程都會(huì)被停住。這方便你你查看運(yùn)行程序的總體情況。而在你恢復(fù)?
絳蛟誦惺保械南叱桃不 岜換指叢誦小D橋率侵鶻淘詒壞ゲ降魘允薄?

9. 查看棧信息
當(dāng)程序被停住了,你需要做的第一件事就是查看程序是在哪里停住的。當(dāng)你的程序調(diào)用了?
桓齪牡刂罰 問詰木植勘淞慷薊岜謊谷搿罷弧保⊿tack
)中。你可以用GDB命令來查看當(dāng)前的棧中的信息。

下面是一些查看函數(shù)調(diào)用棧信息的GDB命令:

backtrace
bt
打印當(dāng)前的函數(shù)調(diào)用棧的所有信息。如:
(gdb) bt
#0? func (n=250) at tst.c:6
#1? 0x08048524 in main (argc=1, argv=0xbffff674) at tst.c:30
#2? 0x400409ed in __libc_start_main () from /lib/libc.so.6

從上可以看出函數(shù)的調(diào)用棧信息:__libc_start_main --> main() --> func()


backtrace <n>
bt <n>
n是一個(gè)正整數(shù),表示只打印棧頂上n層的棧信息。
backtrace <-n>
bt <-n>
-n表一個(gè)負(fù)整數(shù),表示只打印棧底下n層的棧信息。
如果你要查看某一層的 信息,你需要在切換當(dāng)前的棧,一般來說,程序停止時(shí),最頂層的?
瘓褪塹鼻罷唬綣鬩榭湊幌旅娌愕南晗感畔ⅲ紫紉齙氖喬謝壞鼻罷弧?

frame <n>
f <n>
n是一個(gè)從0開始的整數(shù),是棧中的層編號(hào)。比如:frame 0,表示棧頂,frame 1
,表示棧的第二層。
up <n>
表示向棧的上面移動(dòng)n層,可以不打n,表示向上移 動(dòng)一層。
down <n>
表示向棧的下面移動(dòng)n層,可以不打n,表示向下移動(dòng)一層。

上面的命令,都會(huì)打印出移動(dòng)到的棧層的信息。如果你不想讓其打出信息。你可以使用這?
雒睿?

select-frame <n> 對(duì)應(yīng)于 frame 命令。
up-silently <n> 對(duì)應(yīng)于 up 命令。
down-silently <n> 對(duì)應(yīng)于 down 命令。

查看當(dāng)前棧層的信息,你可以用以下GDB命令:

frame 或 f
會(huì)打印出這些信息:棧的層編號(hào),當(dāng)前的函數(shù)名,函數(shù)參數(shù)值,函數(shù)所在文件及行號(hào),函?
蔥械降撓錁洹?
info frame
info f
這個(gè)命令會(huì)打印出更為詳細(xì)的當(dāng)前棧層的信息,只不過,大多數(shù)都是運(yùn)行時(shí)的內(nèi)內(nèi)地址。?
熱紓漢刂罰 饔煤牡刂罰壞饔煤牡刂罰殼暗暮怯墑裁囪某絳蠐镅?
寫成的、函數(shù)參數(shù)地址及值、局部變量的地址等等。如:
(gdb) info f
Stack level 0, frame at 0xbffff5d4:
eip = 0x804845d in func (tst.c:6); saved eip 0x8048524
called by frame at 0xbffff60c
source language c.
Arglist at 0xbffff5d4, args: n=250
Locals at 0xbffff5d4, Previous frame's sp is 0x0
Saved registers:
ebp at 0xbffff5d4, eip at 0xbffff5d8

info args
打印出當(dāng)前函數(shù)的參數(shù)名及其值。
info locals
打印出當(dāng)前函數(shù)中所有局部變量及其值。
info catch
打印出當(dāng)前的函數(shù)中的異常處理信息。
10. 查看源程序
10.1 顯示源代碼
GDB 可以打印出所調(diào)試程序的源代碼,當(dāng)然,在程序編譯時(shí)一定要加上-g
的參數(shù),把源程序信息編譯到執(zhí)行文件中。不然就看不到源程序了。當(dāng)程序停下來以 後,
GDB會(huì)報(bào)告程序停在了那個(gè)文件的第幾行上。你可以用list
命令來打印程序的源代碼。還是來看一看查看源代碼的GDB命令吧。

list <linenum>
顯示程序第linenum行的周圍的源程序。
list <function>
顯示函數(shù)名為function的函數(shù)的源程序。
list
顯示當(dāng)前行後面的源程序。
list -
顯示當(dāng)前行前面的源程序。
一般是打印當(dāng)前行的上5行和下5行,如果顯示函數(shù)是是上2行下8行,默認(rèn)是10
行,當(dāng)然,你也 可以定制顯示的范圍,使用下面命令可以設(shè)置一次顯示源程序的行數(shù)。

set listsize <count>
設(shè)置一次顯示源代碼的行數(shù)。
show listsize
查看 當(dāng)前l(fā)istsize的設(shè)置。
list命令還有下面的用法:

list <first>, <last>
顯示從first行到last行之間的源代碼。
list , <last>
顯示從當(dāng)前行到last行之間的源代碼。
list +
往後顯示源代碼。
一般來說在 list後面可以跟以下這們的參數(shù):

<linenum>?? 行號(hào)。
<+offset>?? 當(dāng)前行號(hào)的正偏移量。
<-offset>?? 當(dāng)前行號(hào)的負(fù)偏移量。
<filename:linenum>? 哪個(gè)文件的哪一行。
<function>? 函數(shù)名。
<filename:function> 哪個(gè)文件中的哪個(gè)函數(shù)。
<*address>? 程序運(yùn)行時(shí)的語句在內(nèi)存中的地址。

10.2 搜索源代碼
不僅如此,GDB還提供了源代碼搜索的命令:

forward-search <regexp>
search <regexp>
向前面搜索。
reverse-search <regexp>
全部搜索。
其中,<regexp
>就是正則表達(dá)式,也主一個(gè)字符串的匹配模式, 關(guān)于正則表達(dá)式,我就不在這里講了,還
請(qǐng)各位查看相關(guān)資料。

10.3 指定源文件的路徑
某些時(shí)候,用-g編譯過後的執(zhí)行程序中只是包括了源文件的名字,沒有路徑名。GDB
提供了可以讓你指定 源文件的路徑的命令,以便GDB進(jìn)行搜索。

directory <dirname ... >
dir <dirname ... >
加一個(gè)源文件 路徑到當(dāng)前路徑的前面。如果你要指定多個(gè)路徑,UNIX
下你可以使用“:”,Windows下你可以使用“;”。
directory
清 除所有的自定義的源文件搜索路徑信息。
show directories
顯示定義了的源文件搜索路徑。
10.4源代碼的內(nèi)存
你可以使用info line命令來查看源代碼在內(nèi)存中的地址。info line
後面可以跟“行號(hào)”,“函數(shù)名”,“文件 名:行號(hào)”,“文件名:函數(shù)名”,這個(gè)命令會(huì)?
蠐〕鏊付ǖ腦綽朐讜誦惺鋇哪詿嫻刂罰紓?

(gdb) info line tst.c:func
Line 5 of "tst.c" starts at address 0x8048456 <func+6> and ends at 0x804845d <
func+13>.

還有一個(gè)命令(disassemble
)你可以查看源程序的當(dāng)前執(zhí)行時(shí)的機(jī)器碼,這個(gè)命令會(huì)把目前內(nèi)存中的指令dump
出來。如下 面的示例表示查看函數(shù)func的匯編代碼。

(gdb) disassemble func
Dump of assembler code for function func:
0x8048450 <func>:?????? push?? %ebp
0x8048451 <func+1>:???? mov??? %esp,%ebp
0x8048453 <func+3>:???? sub??? $0x18,%esp
0x8048456 <func+6>:???? movl?? $0x0,0xfffffffc(%ebp)
0x804845d <func+13>:??? movl?? $0x1,0xfffffff8(%ebp)
0x8048464 <func+20>:??? mov??? 0xfffffff8(%ebp),%eax
0x8048467 <func+23>:??? cmp??? 0x8(%ebp),%eax
0x804846a <func+26>:??? jle??? 0x8048470 <func+32>
0x804846c <func+28>:??? jmp??? 0x8048480 <func+48>
0x804846e <func+30>:??? mov??? %esi,%esi
0x8048470 <func+32>:??? mov??? 0xfffffff8(%ebp),%eax
0x8048473 <func+35>:??? add??? %eax,0xfffffffc(%ebp)
0x8048476 <func+38>:??? incl?? 0xfffffff8(%ebp)
0x8048479 <func+41>:??? jmp??? 0x8048464 <func+20>
0x804847b <func+43>:??? nop
0x804847c <func+44>:??? lea??? 0x0(%esi,1),%esi
0x8048480 <func+48>:??? mov??? 0xfffffffc(%ebp),%edx
0x8048483 <func+51>:??? mov??? %edx,%eax
0x8048485 <func+53>:??? jmp??? 0x8048487 <func+55>
0x8048487 <func+55>:??? mov??? %ebp,%esp
0x8048489 <func+57>:??? pop??? %ebp
0x804848a <func+58>:??? ret
End of assembler dump.

11.查看運(yùn)行時(shí)數(shù)據(jù)
在你調(diào)試程序時(shí),當(dāng)程序被停住時(shí),你可以使用print命令(簡(jiǎn)寫命令為p
),或是同義命令 inspect來查看當(dāng)前程序的運(yùn)行數(shù)據(jù)。print命令的格式是:

print <expr>
print /<f> <expr>

<expr>是表達(dá)式,是你所調(diào)試的程序的語言的表達(dá)式(GDB可以調(diào)試多種編程語言),<f
>是輸出的格式,比 如,如果要把表達(dá)式按16進(jìn)制的格式輸出,那么就是/x。

11.1 表達(dá)式
print和許多GDB的命令一樣,可以接受一個(gè)表達(dá)式,GDB
會(huì)根據(jù)當(dāng)前的程序運(yùn)行的數(shù)據(jù)來計(jì)算這個(gè)表達(dá)式,既 然是表達(dá)式,那么就可以是當(dāng)前程序?
誦兄械腸onst常量、變量、函數(shù)等內(nèi)容。可惜的是GDB不能使用你在程序中所定義的宏。

表達(dá)式的語法應(yīng)該是當(dāng)前所調(diào)試的語言的語法,由于C/C
++是一種大眾型的語言,所以,本文中的例子都是關(guān)于C/C++的。(而關(guān)于用 GDB
調(diào)試其它語言的章節(jié),我將在後面介紹)

在表達(dá)式中,有幾種GDB所支持的操作符,它們可以用在任何一種語言中。

@

是一個(gè)和數(shù)組有關(guān)的操作符,在後面會(huì)有更詳細(xì)的說明。
::

指定一個(gè)在文件或是一個(gè)函數(shù)中的變量。
{<type>} <addr>

表示一個(gè)指向內(nèi)存地址<addr>的類型為type的一個(gè)對(duì)象。
11.2程序變量
在GDB中,你可以隨時(shí)查看以下 三種變量的值:

全局變量(所有文件可見的)
靜態(tài)全局變量(當(dāng)前文件可見的)
局部變量(當(dāng)前Scope可見的)
如果你的局部變量和全 局變量發(fā)生沖突(也就是重名),一般情況下是局部變量會(huì)隱藏全?
直淞浚簿褪撬擔(dān)綣桓鋈直淞亢鴕桓齪械木植勘淞客保綣鼻巴V溝 閽?
函數(shù)中,用print
顯示出的變量的值會(huì)是函數(shù)中的局部變量的值。如果此時(shí)你想查看全局變量的值時(shí),你可?
允褂謾?:”操作 符:

file::variable
function::variable

可以通過這種形式指定你所想查看的變量,是哪個(gè)文件中的或是哪個(gè)函數(shù)中的。例如,查?
次募2.c中的全局變量x的值:

(gdb) p 'f2.c'::x

當(dāng)然,“::”操作符會(huì)和C++中的發(fā)生沖突,GDB能自動(dòng)識(shí)別“::” 是否C
++的操作符,所以你不必?fù)?dān)心在調(diào)試C++程序時(shí)會(huì)出現(xiàn)異 常。

另外,需要注意的是,如果你的程序編譯時(shí)開啟了優(yōu)化選項(xiàng),那么在用GDB
調(diào)試被優(yōu)化過的程序時(shí),可能會(huì)發(fā)生某些變量不能訪問,或是取值錯(cuò)誤 碼的情況。這個(gè)是?
苷5模蛭嘔絳蚧嶸靖哪愕某絳潁砟慍絳虻撓錁淥承潁蕹恍┪摶庖宓謀淞?
等,所以在GDB
調(diào)試這 種程序時(shí),運(yùn)行時(shí)的指令和你所編寫指令就有不一樣,也就會(huì)出現(xiàn)你所想象不到的?
峁6愿墩庵智榭鍪保枰詒嘁氤絳蚴憊乇氈嘁胗嘔R話憷此擔(dān) 負(fù)跛械謀嘁肫鞫?
支持編譯優(yōu)化的開關(guān),例如,GNU 的C/C++編譯器GCC,你可以使用“-gstabs
”選項(xiàng)來解決這個(gè)問題。關(guān) 于編譯器的參數(shù),還請(qǐng)查看編譯器的使用說明文檔。

11.3 數(shù)組
有時(shí)候,你需要查看一段連續(xù)的內(nèi)存空間的值。比如數(shù)組的一段,或是動(dòng)態(tài)分配的數(shù)據(jù)的?
笮 D憧梢允褂肎DB
的 “@”操作符,“@”的左邊是第一個(gè)內(nèi)存的地址的值,“@”的右邊則你你想查看內(nèi)存的
長(zhǎng)度。例如,你的程序中有這樣的語句:

int *array = (int *) malloc (len * sizeof (int));

于是,在GDB調(diào)試過程中,你可以以如下命令顯示出這個(gè)動(dòng)態(tài)數(shù)組的取值:

p *array@len

@的左邊是數(shù)組的首地址的值,也就是變量array
所指向的內(nèi)容,右邊則是數(shù)據(jù)的長(zhǎng)度,其保存在變量len
中,其輸出結(jié)果,大約是 下面這個(gè)樣子的:

(gdb) p *array@len
$1 = {2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36, 38,
40}

如果是靜態(tài)數(shù)組的話,可以直接用print數(shù)組名,就可以顯示數(shù)組中所有數(shù)據(jù)的內(nèi)容了。

11.4 輸出格式
一般來說,GDB會(huì)根據(jù)變量的類型輸出變量的值。但你也可以自定義GDB
的輸出的格式。例如,你想輸出一個(gè)整數(shù) 的十六進(jìn)制,或是二進(jìn)制來查看這個(gè)整型變量的?
械奈壞那榭觥R齙秸庋憧梢允褂肎DB的數(shù)據(jù)顯示格式:

x? 按十六進(jìn)制格式顯示變量。
d? 按十進(jìn)制格式顯示變量。
u? 按十六進(jìn)制格式顯示無符號(hào)整型。
o? 按八進(jìn)制格式顯示變量。
t? 按二進(jìn)制格式顯示變量。
a? 按十六進(jìn)制格式顯示變量。
c? 按字符格式顯示變量。
f? 按浮點(diǎn)數(shù)格式顯示變量。

(gdb) p i
$21 = 101??
(gdb) p/a i
$22 = 0x65
(gdb) p/c i
$23 = 101 'e'
(gdb) p/f i
$24 = 1.41531145e-43
(gdb) p/x i
$25 = 0x65
(gdb) p/t i
$26 = 1100101

11.5查看內(nèi)存
你可以使用examine命令(簡(jiǎn)寫是x)來查看內(nèi)存地址中的值。x命令的語法如下所示:

x/<n/f/u> <addr>

n、f、u是可選的參數(shù)。

n 是一個(gè)正整數(shù),表示顯示內(nèi)存的長(zhǎng)度,也就是說從當(dāng)前地址向後顯示幾個(gè)地址的內(nèi)容。
f 表示顯示的格式,參見上面。如果地址所指的是字符串,那么格式可以是s
,如果地十是指令地址,那么格式可以是i。
u 表示從當(dāng)前地址往後請(qǐng)求的字節(jié)數(shù),如果不指定的話,GDB默認(rèn)是4個(gè)bytes。u
參數(shù)可以用下面的字符來代替,b表示單字節(jié),h表示雙字節(jié),w 表示四字節(jié),g
表示八字節(jié)。當(dāng)我們指定了字節(jié)長(zhǎng)度後,GDB
會(huì)從指內(nèi)存定的內(nèi)存地址開始,讀寫指定字節(jié),并把其當(dāng)作一個(gè)值取出來。
<addr> 表示一個(gè)內(nèi)存地址。

n/f/u三個(gè)參數(shù)可以一起使用。例如:

命令:x/3uh 0x54320 表示,從內(nèi)存地址0x54320讀取內(nèi)容,h表示以雙字節(jié)為一個(gè)單位,
3表示三個(gè)單位,u表示按十六進(jìn) 制顯示。

11.6 自動(dòng)顯示
你可以設(shè)置一些自動(dòng)顯示的變量,當(dāng)程序停住時(shí),或是在你單步跟蹤時(shí),這些變量會(huì)自動(dòng)?
允盡O喙氐腉DB命令是 display。

display <expr>
display/<fmt> <expr>
display/<fmt> <addr>

expr是一個(gè)表達(dá)式,fmt表示顯示的格式,addr表示內(nèi)存地址,當(dāng)你用display
設(shè)定好了一個(gè)或多個(gè)表達(dá)式後,只要你的程序被停 下來,GDB
會(huì)自動(dòng)顯示你所設(shè)置的這些表達(dá)式的值。

格式i和s同樣被display支持,一個(gè)非常有用的命令是:

display/i $pc

$pc是GDB的環(huán)境變量,表示著指令的地址,/i
則表示輸出格式為機(jī)器指令碼,也就是匯編。于是當(dāng)程序停下後,就會(huì)出現(xiàn)源代碼和機(jī)器?
噶 盥胂嘍雜Φ那樾危饈且桓齪苡幸饉嫉墓δ堋?

下面是一些和display相關(guān)的GDB命令:

undisplay <dnums...>
delete display <dnums...>

刪除自動(dòng)顯示,dnums
意為所設(shè)置好了的自動(dòng)顯式的編號(hào)。如果要同時(shí)刪除幾個(gè),編號(hào)可以用空格分隔,如果要?
境桓齜段詰謀嗪 牛梢雜眉鹺瘧硎荊ㄈ紓?-5)

disable display <dnums...>
enable display <dnums...>

disable和enalbe不刪除自動(dòng)顯示的設(shè)置,而只是讓其失效和恢復(fù)。

info display

查看display設(shè)置的自動(dòng)顯示的信息。GDB
會(huì)打出一張表格,向你報(bào)告當(dāng)然調(diào)試中設(shè)置了多少個(gè)自動(dòng)顯示設(shè)置,其中包括,設(shè)置的編?
牛 澩鍤劍欠馿nable。

11.7 設(shè)置顯示選項(xiàng)
GDB中關(guān)于顯示的選項(xiàng)比較多,這里我只例舉大多數(shù)常用的選項(xiàng)。

set print address
set print address on
打開地址輸出,當(dāng)程序顯示函數(shù)信息時(shí),GDB
會(huì) 顯出函數(shù)的參數(shù)地址。系統(tǒng)默認(rèn)為打開的,如:
(gdb) f
#0? set_quotes (lq=0x34c78 "<<", rq=0x34c88 ">>")
??? at input.c:530
530???????? if (lquote != def_lquote)

set print address off
關(guān)閉函數(shù)的參數(shù)地址顯示,如:
(gdb) set print addr off
(gdb) f
#0? set_quotes (lq="<<", rq=">>") at input.c:530
530???????? if (lquote != def_lquote)

show print address
查看當(dāng)前地址顯示選項(xiàng)是否打開。
set print array
set print array on
打開數(shù)組顯示,打開後當(dāng)數(shù)組顯示時(shí),每個(gè)元素占一行,如果不打開的話,每個(gè)元素則以?
漢歐指簟U飧鲅∠钅 鮮槍乇盞摹S脛喙氐牧礁雒釗縵攏揖筒輝俁嗨盜恕?
set print array off
show print array
set print elements <number-of-elements>
這個(gè)選項(xiàng)主要是設(shè)置數(shù)組的,如果你的數(shù)組太大了,那么 就可以指定一個(gè)<number-of-
elements>來指定數(shù)據(jù)顯示的最大長(zhǎng)度,當(dāng)?shù)竭_(dá)這個(gè)長(zhǎng)度時(shí),GDB
就不再往下顯 示了。如果設(shè)置為0,則表示不限制。
show print elements
查看print elements的選項(xiàng)信息。
set print null-stop <on/off>
如果打開了這個(gè)選項(xiàng),那么當(dāng)顯示字符串時(shí),遇到結(jié)束符則停止顯示。這個(gè)選項(xiàng)默 認(rèn)為
off。
set print pretty on
如果打開printf pretty這個(gè)選項(xiàng),那么當(dāng)GDB顯示結(jié)構(gòu)體時(shí)會(huì)比較漂亮。如:
$1 = {
? next = 0x0,
? flags = {
??? sweet = 1,
??? sour = 1
? },
? meat = 0x54 "Pork"
}

set print pretty off
關(guān)閉printf pretty這個(gè)選項(xiàng),GDB顯示結(jié)構(gòu)體時(shí)會(huì)如下顯示:
$1 = {next = 0x0, flags = {sweet = 1, sour = 1}, meat = 0x54 "Pork"}

show print pretty
查看GDB是如何顯示結(jié)構(gòu)體的。
set print sevenbit-strings <on/off>
設(shè)置字符顯示,是否按“/nnn”的格式顯示,如果打開,則字符串或字符數(shù)據(jù)按/nnn
顯示,如 “/065”。
show print sevenbit-strings
查看字符顯示開關(guān)是否打開。
set print union <on/off>
設(shè)置顯示結(jié)構(gòu)體時(shí),是否顯式其內(nèi)的聯(lián)合體數(shù)據(jù)。例如有以下數(shù)據(jù)結(jié)構(gòu):
typedef enum {Tree, Bug} Species;
typedef enum {Big_tree, Acorn, Seedling} Tree_forms;
typedef enum {Caterpillar, Cocoon, Butterfly}
????????????? Bug_forms;

struct thing {
? Species it;
? union {
??? Tree_forms tree;
??? Bug_forms bug;
? } form;
};

struct thing foo = {Tree, {Acorn}};

當(dāng)打開這個(gè)開關(guān)時(shí),執(zhí)行 p foo 命令後,會(huì)如下顯示:

$1 = {it = Tree, form = {tree = Acorn, bug = Cocoon}}

當(dāng)關(guān)閉這個(gè)開關(guān)時(shí),執(zhí)行 p foo 命令後,會(huì)如下顯示:

$1 = {it = Tree, form = {...}}

show print union
查看聯(lián)合體數(shù)據(jù)的顯示方式
set print object <on/off>:在C
++中,如果一個(gè)對(duì)象指針指向其派生類,如果打開這個(gè)選項(xiàng),GDB
會(huì)自動(dòng)按照虛方法調(diào)用的規(guī)則顯示輸 出,如果關(guān)閉這個(gè)選項(xiàng)的話,GDB
就不管虛函數(shù)表了。這個(gè)選項(xiàng)默認(rèn)是off。
show print object
查看對(duì)象選 項(xiàng)的設(shè)置。
set print static-members <on/off>
這個(gè)選項(xiàng)表示,當(dāng)顯示一個(gè)C++對(duì)象中 的內(nèi)容是,是否顯示其中的靜態(tài)數(shù)據(jù)成員。默認(rèn)是
on。
show print static-members
查看靜態(tài)數(shù)據(jù)成員 選項(xiàng)設(shè)置。
set print vtbl <on/off>
當(dāng)此選項(xiàng)打開時(shí),GDB將用比較規(guī)整的格式來顯示虛函數(shù)表 時(shí)。其默認(rèn)是關(guān)閉的。
show print vtbl
查看虛函數(shù)顯示格式的選項(xiàng)。
11.8 歷史記錄
當(dāng)你用GDB 的print查看程序運(yùn)行時(shí)的數(shù)據(jù)時(shí),你每一個(gè)print都會(huì)被GDB記錄下來。GDB
會(huì)以$1, $2, $3 .....這樣的方式為你每一個(gè)print
命令編上號(hào)。于是,你可以使用這個(gè)編號(hào)訪問以前的表達(dá)式,如$1
。這個(gè)功能所帶來的好處是,如 果你先前輸入了一個(gè)比較長(zhǎng)的表達(dá)式,如果你還想查看這?
霰澩鍤降鬧擔(dān)憧梢允褂美芳鍬祭捶夢(mèng)剩∪チ酥馗詞淙搿?

11.9 GDB環(huán)境變量
你可以在GDB
的調(diào)試環(huán)境中定義自己的變量,用來保存一些調(diào)試程序中的運(yùn)行數(shù)據(jù)。要定義一個(gè)GDB
的 變量很簡(jiǎn)單只需。使用GDB的set命令。GDB的環(huán)境變量和UNIX一樣,也是以$起頭。如:

set $foo = *object_ptr

使用環(huán)境變量時(shí),GDB
會(huì)在你第一次使用時(shí)創(chuàng)建這個(gè)變量,而在以後的使用中,則直接對(duì)其賦值。環(huán)境變量沒有?
嘈停憧梢愿肪潮淞 慷ㄒ迦我壞睦嘈汀0ń峁固搴褪欏?

show convenience
該命令查看當(dāng)前所設(shè)置的所有的環(huán)境變量。
這是一個(gè)比較強(qiáng)大的功能,環(huán)境變量和程序變量的交互 使用,將使得程序調(diào)試更為靈活便?
蕁@紓?

set $i = 0
print bar[$i++]->contents

于是,當(dāng)你就不必,print bar[0]->contents, print bar[1]->contents
地輸入命 令了。輸入這樣的命令後,只用敲回車,重復(fù)執(zhí)行上一條語句,環(huán)境變量會(huì)自動(dòng)?
奐櫻傭瓿芍鷥鍪涑齙墓δ堋?

11.10 查看寄存器
要查看寄存器的值,很簡(jiǎn)單,可以使用如下命令:

info registers
查看寄存器的情況。(除了浮點(diǎn)寄存器)
info all-registers
查看所有 寄存器的情況。(包括浮點(diǎn)寄存器)
info registers <regname ...>
查看所指定的寄存器的情 況。
寄存器中放置了程序運(yùn)行時(shí)的數(shù)據(jù),比如程序當(dāng)前運(yùn)行的指令地址(ip
),程序的當(dāng)前堆棧地址(sp)等等。你同樣可以使用 print
命令來訪問寄存器的情況,只需要在寄存器名字前加一個(gè)$符號(hào)就可以了。如:p $eip。

12. 改變程序的執(zhí)行
一旦使用GDB
掛上被調(diào)試程序,當(dāng)程序運(yùn)行起來後,你可以根據(jù)自己的調(diào)試思路來動(dòng)態(tài)地在GDB
中 更改當(dāng)前被調(diào)試程序的運(yùn)行線路或是其變量的值,這個(gè)強(qiáng)大的功能能夠讓你更好的調(diào)試?
愕某絳潁熱紓憧梢栽誄絳虻囊淮臥誦兄兇弒槌絳虻乃蟹種 А?

12.1 修改變量值
修改被調(diào)試程序運(yùn)行時(shí)的變量值,在GDB中很容易實(shí)現(xiàn),使用GDB的print
命令即可完成。如:

(gdb) print x=4

x=4這個(gè)表達(dá)式是C/C++的語法,意為把變量x的值修改為4,如果你當(dāng)前調(diào)試的語言是
Pascal,那么你可以使用Pascal的語 法:x:=4。

在某些時(shí)候,很有可能你的變量和GDB中的參數(shù)沖突,如:

(gdb) whatis width
type = double
(gdb) p width
$4 = 13
(gdb) set width=47
Invalid syntax in expression.

因?yàn)?#xff0c;set width是GDB的命令,所以,出現(xiàn)了“Invalid syntax in expression
”的設(shè)置錯(cuò)誤,此時(shí), 你可以使用set var命令來告訴GDB,width不是你GDB
的參數(shù),而是程序的變量名,如:

(gdb) set var width=47

另外,還可能有些情況,GDB
并不報(bào)告這種錯(cuò)誤,所以保險(xiǎn)起見,在你改變程序變量取值時(shí),最好都使用set var
格式的GDB命 令。

12.2跳轉(zhuǎn)執(zhí)行
一般來說,被調(diào)試程序會(huì)按照程序代碼的運(yùn)行順序依次執(zhí)行。GDB
提供了亂序執(zhí)行的功能,也就是說,GDB
可 以修改程序的執(zhí)行順序,可以讓程序執(zhí)行隨意跳躍。這個(gè)功能可以由GDB的jump
命令來完:

jump <linespec>
指定下一條語句的運(yùn)行點(diǎn)。<linespce>可以是文件的行號(hào),可以是 file:line
格式,可以是+num這種偏移量格式。表式著下一條運(yùn)行語句從哪里開始。
jump <address>
這里的<address>是代碼行的內(nèi)存地址。
注意,jump
命令不會(huì)改變當(dāng)前的程序棧中的內(nèi)容,所以,當(dāng)你從 一個(gè)函數(shù)跳到另一個(gè)函數(shù)時(shí),當(dāng)函數(shù)?
誦型攴禱厥苯械徊僮魘北厝換岱⑸砦螅贍芙峁故欠淺F婀值模踔劣誆絳?
Core Dump。所以最好是同一個(gè)函數(shù)中進(jìn)行跳轉(zhuǎn)。

熟悉匯編的人都知道,程序運(yùn)行時(shí),有一個(gè)寄存器用于保存當(dāng)前代碼所在的內(nèi)存地址。所?
裕琷ump命令也就是改變了這個(gè)寄存器中的值。于是, 你可以使用“set $pc
”來更改跳轉(zhuǎn)執(zhí)行的地址。如:

set $pc = 0x485

12.3產(chǎn)生信號(hào)量
使用singal命令,可以產(chǎn)生一個(gè)信號(hào)量給被調(diào)試的程序。如:中斷信號(hào)Ctrl+C
。這非常方便于程序的調(diào) 試,可以在程序運(yùn)行的任意位置設(shè)置斷點(diǎn),并在該斷點(diǎn)用GDB
產(chǎn)生一個(gè)信號(hào)量,這種精確地在某處產(chǎn)生信號(hào)非常有利程序的調(diào)試。

語法是:signal <singal>,UNIX的系統(tǒng)信號(hào)量通常從1到15。所以<singal
>取值也在這 個(gè)范圍。

single命令和shell的kill命令不同,系統(tǒng)的kill命令發(fā)信號(hào)給被調(diào)試程序時(shí),是由GDB
截獲的,而single命令所發(fā)出 一信號(hào)則是直接發(fā)給被調(diào)試程序的。

12.4強(qiáng)制函數(shù)返回
如果你的調(diào)試斷點(diǎn)在某個(gè)函數(shù)中,并還有語句沒有執(zhí)行完。你可以使用return
命令強(qiáng)制函數(shù)忽略還沒有執(zhí)行 的語句并返回。

return
return <expression>
?? 使用return命令取消當(dāng)前函數(shù)的執(zhí)行,并立即返回,如果指定了<expression
>,那么該表達(dá)式的值會(huì)被認(rèn)作函數(shù)的返回 值。

12.5 強(qiáng)制調(diào)用函數(shù)
call <expr>

表達(dá)式中可以一是函數(shù),以此達(dá)到強(qiáng)制調(diào)用函數(shù)的目的。并顯示函數(shù)的返回值,如果函數(shù)?
禱刂凳莢oid,那么就不顯示。

另一個(gè)相似的命令也可以完成這一功能——print,print
後面可以跟表達(dá)式,所以也可以用他來調(diào)用函數(shù),print和call的不同 是,如果函數(shù)返回
void,call則不顯示,print則顯示函數(shù)返回值,并把該值存入歷史數(shù)據(jù)中。

13. 在不同語言中使用GDB
GDB支持下列語言:C, C++, Fortran, PASCAL, Java, Chill, assembly, 和 Modula-2
。一般說來,GDB
會(huì)根據(jù)你所調(diào)試的程序來確定當(dāng)然的調(diào)試語言,比如:發(fā)現(xiàn)文件名後綴為 “.c”的,GDB
會(huì)認(rèn)為是C程序。文件名後綴為 “.C, .cc, .cp, .cpp, .cxx, .c++”的,GDB會(huì)認(rèn)為是C
++ 程序。而後綴是“.f, .F”的,GDB會(huì)認(rèn)為是Fortran程序,還有,後綴為如果是“.s,
.S”的會(huì)認(rèn)為是匯編語言。

也就是說,GDB會(huì)根據(jù)你所調(diào)試的程序的語言,來設(shè)置自己的語言環(huán)境,并讓GDB
的命令跟著語言環(huán)境的改變而改變。比如一些GDB
命 令需要用到表達(dá)式或變量時(shí),這些表達(dá)式或變量的語法,完全是根據(jù)當(dāng)前的語言環(huán)境而?
謀淶摹@鏑/C++中對(duì)指針的語法是*p,而在 Modula-2中則是p
^。并且,如果你當(dāng)前的程序是由幾種不同語言一同編譯成的,那到在調(diào)試過程中,GDB
也能根據(jù)不同的語言自動(dòng)地 切換語言環(huán)境。這種跟著語言環(huán)境而改變的功能,真是體貼開?
⑷嗽鋇囊恢稚杓啤?

下面是幾個(gè)相關(guān)于GDB語言環(huán)境的命令:

show language
查看當(dāng)前的語言環(huán)境。如果GDB不能識(shí)為你所調(diào)試的編程語言,那么,C
語言被認(rèn)為是默認(rèn)的環(huán)境。
info frame
查看當(dāng)前函數(shù)的程序語言。
info source
查看當(dāng)前文件的程序語言。
如果GDB沒有檢測(cè)出當(dāng) 前的程序語言,那么你也可以手動(dòng)設(shè)置當(dāng)前的程序語言。使用set
language命令即可做到。

當(dāng)set language命令後什么也不跟的話,你可以查看GDB所支持的語言種類:

(gdb) set language
The currently understood settings are:

local or auto??? Automatic setting based on source file
c??????????????? Use the C language
c++????????????? Use the C++ language
asm????????????? Use the Asm language
chill??????????? Use the Chill language
fortran????????? Use the Fortran language
java???????????? Use the Java language
modula-2???????? Use the Modula-2 language
pascal?????????? Use the Pascal language
scheme?????????? Use the Scheme language

于是你可以在set language後跟上被列出來的程序語言名,來設(shè)置當(dāng)前的語言環(huán)境。

14. 後記
GDB
是一個(gè)強(qiáng)大的命令行調(diào)試工具。大家知道命令行的強(qiáng)大就是在于,其可以形成執(zhí)行序列,?
緯山瘧盡 NIX
下的軟件全是命令行的,這給程序開發(fā)提代供了極大的便利,命令行軟件的優(yōu)勢(shì)在于,它?
強(qiáng)梢苑淺H菀椎募稍諞黃穡褂眉父黽虻サ 囊延泄ぞ叩拿睿涂梢宰齔鲆桓齜淺G看?
的功能。

于是UNIX下的軟件比Windows
下的軟件更能有機(jī)地結(jié)合,各自發(fā)揮各自的長(zhǎng)處,組合成更為強(qiáng)勁的功能。而Windows
下的 圖形軟件基本上是各自為營(yíng),互相不能調(diào)用,很不利于各種軟件的相互集成。在這里?
⒉皇且蚖indows
做個(gè)什么比較,所謂“寸有所長(zhǎng), 尺有所短”,圖形化工具還是有不如命令行的地方。(?
吹秸餼浠笆保M魑磺蛟僖膊灰銜揖褪恰氨墑?dòng)蛫A謂緱妗保臀姨Ц芰?)

我是根據(jù)版本為5.1.1的GDB
所寫的這篇文章,所以可能有些功能已被修改,或是又有更為強(qiáng)勁的功能。而且,我寫得?
淺2執(zhí)伲 吹帽冉霞蚵裕⑶遙渲形乙丫吹接行磯啻肀鹱至耍ㄎ矣夢(mèng)灞剩源磣秩?
你看不懂),所以,我在這里對(duì)我文中的差錯(cuò)表示萬分的歉意。

文中所羅列的GDB的功能時(shí),我只是羅列了一些帶用的GDB
的命令和使用方法,其實(shí),我這里只講述的功能大約只占GDB所有功能的60
% 吧,詳細(xì)的文檔,還是請(qǐng)查看GDB
的幫助和使用手冊(cè)吧,或許,過段時(shí)間,如果我有空,我再寫一篇GDB的高級(jí)使用。

我個(gè)人非常喜歡GDB的自動(dòng)調(diào)試的功能,這個(gè)功能真的很強(qiáng)大,試想,我在UNIX
下寫個(gè)腳本,讓腳本自動(dòng)編譯我的程序,被自動(dòng)調(diào)試,并把結(jié) 果報(bào)告出來,調(diào)試成功,自?
痗heckin源碼庫。一個(gè)命令,編譯帶著調(diào)試帶著checkin,多爽啊。只是GDB
對(duì)自動(dòng)化調(diào)試目前支持 還不是很成熟,只能實(shí)現(xiàn)半自動(dòng)化,真心期望著GDB
的自動(dòng)化調(diào)試功能的成熟。

如果各位對(duì)GDB或是別的技術(shù)問題有興趣的話,歡迎和我討論交流。本人目前主要在UNIX
下做產(chǎn)品軟件的開發(fā),所以,對(duì)UNIX
下 的軟件開發(fā)比較熟悉,當(dāng)然,不單單是技術(shù),對(duì)軟件工程實(shí)施,軟件設(shè)計(jì),系統(tǒng)分析,?
钅抗芾砦乙猜雜行牡謾;隊(duì)蠹藝椅醫(yī)渙鰨≦Q 是:753640,MSN 是:haoel@hotmail .
com)

[編輯] 相關(guān)詞條
GCC新手入門
C/C++ IDE簡(jiǎn)介
用GDB調(diào)試程序
Gtk與Qt編譯環(huán)境安裝與配置
跟我一起寫Makefile
?C編譯初步
C++編譯初步
Fortran編譯初步
C和C++混合編譯初 步
C和Fortran混合編譯初步

取自"http://wiki.ubuntu.org.cn/index.php?title=%E7%94%A8GDB%E8%B0%83%E8%AF%95%
E7%A8%8B%E5%BA%8F&variant=zh-cn"
1 個(gè)分類: 程序開發(fā)


本文轉(zhuǎn)自
http://wiki.ubuntu.org.cn/index.php?title=%E7%94%A8GDB%E8%B0%83%E8%AF%95%E7%A8
%8B%E5%BA%8F&variant=zh-cn

總結(jié)

以上是生活随笔為你收集整理的GDB调试程序-Ubuntu的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

中文字幕国产在线 | 国产一级黄色免费看 | 久久久免费在线观看 | 91精品区 | 91九色免费视频 | www国产亚洲精品久久网站 | 欧美日韩视频一区二区三区 | 激情综合网天天干 | 日韩理论电影网 | 精品理论片 | 午夜在线免费视频 | 久久国产精品一区二区三区四区 | 91精品国自产在线 | 最近高清中文字幕在线国语5 | 亚洲电影自拍 | 国产99中文字幕 | 久久久久久久久久久久久9999 | 五月激情站| 国产69精品久久app免费版 | 黄色一级动作片 | 午夜12点 | 久久一区二区三区国产精品 | 激情综合亚洲 | 天天干天天干天天干 | 91福利在线观看 | 在线观看视频一区二区三区 | www.夜夜操.com | 黄色动态图xx | 热九九精品| 999久久久免费视频 午夜国产在线观看 | 欧美激情综合色综合啪啪五月 | 成人毛片在线观看 | 成人v| 狠狠色狠狠色合久久伊人 | 九九视频在线播放 | 在线中文字幕网站 | 国产精品伦一区二区三区视频 | 国产九九热 | 91看毛片 | 午夜精品久久久久99热app | 日韩草比 | 色婷婷国产精品一区在线观看 | 国产视频中文字幕在线观看 | 亚洲特级片 | 亚洲国产wwwccc36天堂 | 99久久精品国产一区 | 99久久精品久久亚洲精品 | 干 操 插| 亚洲精品视频第一页 | 香蕉久久久久 | 中文av在线播放 | 久久99久久99精品免视看婷婷 | 亚洲国产精品日韩 | 国产精品美女免费 | 亚洲精品国产精品国自产在线 | 日日躁夜夜躁aaaaxxxx | 亚洲国产激情 | 国产不卡精品 | 一区二区三区在线视频111 | 24小时日本在线www免费的 | 涩av在线 | 成人黄色片在线播放 | 国产99久久 | 亚洲在线成人精品 | 99久久久久| 欧美日韩精品影院 | 国产成人精品网站 | 亚洲国产999 | 色综合天天综合网国产成人网 | 日韩高清一区在线 | 亚洲精品黄网站 | 免费的国产精品 | 91激情视频在线观看 | 色综合久久精品 | 婷婷新五月 | 久久久久国产精品午夜一区 | 三级av在线播放 | 成人网在线免费视频 | 亚洲理论片 | 欧美在线18| 国产精品毛片一区二区在线看 | 亚洲天堂香蕉 | 亚洲一区二区三区毛片 | 国产午夜精品久久久久久久久久 | 国产一卡二卡四卡国 | av观看在线观看 | 伊人伊成久久人综合网小说 | 激情文学综合丁香 | 丁香六月婷| 精品国产伦一区二区三区观看方式 | 亚洲国产美女精品久久久久∴ | 欧美日韩高清在线一区 | av在线在线| 五月天久久久 | 国产精品久久久久9999吃药 | 久草男人天堂 | 久草网站在线观看 | 国产成人一区二区三区久久精品 | 久久综合成人 | 九九在线国产视频 | 天天射天天做 | 又黄又爽又刺激的视频 | 黄色小说视频网站 | 久章草在线 | 高清av在线免费观看 | 人人爽人人乐 | 中文字幕字幕中文 | 国产毛片在线 | 91自拍视频在线 | 国产成本人视频在线观看 | 九九免费在线观看 | 四虎永久免费 | 久久中文字幕导航 | 国产福利电影网址 | 亚洲在线成人精品 | 亚洲免费小视频 | 狠狠色2019综合网 | 精品视频网站 | 婷婷丁香在线视频 | 久久综合综合久久综合 | 国产精品久久久久久久久久久久午夜 | 国产明星视频三级a三级点| 青草草在线 | 免费看的毛片 | 国产很黄很色的视频 | 四虎国产精品成人免费影视 | 久久综合九色综合网站 | 久久久久久久久久久成人 | 亚洲2019精品 | 在线观看av黄色 | 成人午夜剧场在线观看 | 99久久99久久综合 | 久久高清免费观看 | 婷婷久操 | 欧美精品在线一区二区 | 99久久这里有精品 | 99精品色| 九热精品| 五月综合 | 青青看片 | 成人免费看黄 | 国产日韩精品一区二区三区在线 | 成年人免费观看在线视频 | 麻豆视频国产在线观看 | 欧美一级黄大片 | 97精品免费视频 | 免费福利视频网 | 久草在线免费色站 | 久久成人黄色 | 依人成人综合网 | 中文字幕欧美三区 | 日韩国产欧美视频 | 丁香婷婷激情国产高清秒播 | 偷拍精偷拍精品欧洲亚洲网站 | 日韩一区二区三区视频在线 | 国产乱码精品一区二区三区介绍 | 午夜视频免费在线观看 | 日韩啪视频 | 91在线国产观看 | 日韩天天操 | 欧美一级性生活片 | 亚洲国产理论片 | 日韩在线在线 | 久久久久成人精品免费播放动漫 | 国产专区在线 | 一区在线免费观看 | 在线观看不卡视频 | 国产天天爽 | 亚洲激情婷婷 | 欧美永久视频 | 永久免费看av | 亚洲区精品 | 久视频在线播放 | 97超在线 | 性色av免费看 | 国产色就色| 午夜精品久久久久久久久久 | 国产精品乱码久久久久 | 国产福利精品在线观看 | 精品久久久久久久 | 久久av黄色| 国产三级久久久 | 免费亚洲片 | 天天操天天添天天吹 | 亚洲欧美在线综合 | 一区二区三区四区精品视频 | 日本免费久久高清视频 | 青草视频网 | 免费高清在线视频一区· | 麻豆一二三精选视频 | 一区二区男女 | 97综合网| 亚洲最快最全在线视频 | 成年免费在线视频 | 免费韩国av| 欧美在线观看视频一区二区 | 欧美日韩一区二区在线观看 | 超碰在线94 | 日韩av电影手机在线观看 | 日本中文乱码卡一卡二新区 | 欧美在线1区 | 欧美日韩国产三级 | 免费碰碰 | 九九久久久 | 中文字幕在线观看三区 | 国产黄色精品 | 在线播放一区二区三区 | 91精品久久久久久综合乱菊 | 久久久 精品 | 97夜夜澡人人双人人人喊 | 99视频在线免费播放 | 日韩激情av在线 | 日韩成人邪恶影片 | 成年人在线观看 | 99久久www免费 | 中文字幕 欧美性 | 国产精品一区免费看8c0m | 97超碰人| 精品久久一区二区 | 日本不卡一区二区三区在线观看 | 精品人人人 | 国产精品淫片 | 欧美成人一二区 | 五月天综合色激情 | 干天天 | 999在线视频 | 国产亚洲精品久久久久久移动网络 | 国产又粗又猛又黄 | 国产亚洲一区 | av导航福利 | 日日夜夜狠狠 | 1024在线看片 | 91成人在线观看喷潮 | 婷婷av网站| 精品少妇一区二区三区在线 | 狠狠干夜夜 | 国产精品99视频 | ww亚洲ww亚在线观看 | 97超在线视频| 久草在线视频资源 | 日韩精品影视 | 日批在线观看 | 欧美精品一区二区在线播放 | 亚洲人久久久 | 亚洲天天摸日日摸天天欢 | 日韩av中文 | 欧美视频在线观看免费网址 | 久久亚洲福利 | 欧美日韩国产网站 | 丰满少妇在线观看网站 | av免费观看在线 | 91片黄在线观看 | 国产色在线 | 久久玖 | 国产精品久久99综合免费观看尤物 | 亚洲欧洲成人精品av97 | 夜又临在线观看 | 国产一区二区三区在线 | 国产精品久免费的黄网站 | 一区二区三区日韩在线观看 | a级国产乱理论片在线观看 特级毛片在线观看 | 99久久这里有精品 | 中文字幕在线观看一区二区 | 亚洲欧美视频 | 久久五月婷婷丁香社区 | 天天操天天艹 | 成人黄色在线视频 | 亚洲 欧美日韩 国产 中文 | 久久乐九色婷婷综合色狠狠182 | 中文字幕婷婷 | 五月激情在线 | 亚洲精品中文在线资源 | 蜜臀av夜夜澡人人爽人人 | 国产精品久久久久高潮 | 中文字幕乱码亚洲精品一区 | 亚洲开心色 | www.天天干.com| 一区二区三区在线视频观看58 | 91视频免费视频 | 亚洲区另类春色综合小说 | 日韩成人黄色av | 精品色综合 | 九九热免费观看 | 黄色日批网站 | 激情视频在线观看网址 | 久久一线 | 亚洲午夜av久久乱码 | 色综合天 | 日韩日韩日韩日韩 | 国产精品久久久久久久久久久免费看 | 国产区久久 | 婷婷黄色片| 欧美一级黄色网 | 9在线观看免费高清完整版 玖玖爱免费视频 | 免费看黄网站在线 | 亚洲欧美日韩不卡 | 国产在线不卡一区 | 四虎在线视频免费观看 | 久久久久成人免费 | 91视频啊啊啊 | 欧美成人猛片 | 四虎影视精品永久在线观看 | 毛片网免费 | 久久艹免费 | 在线看成人 | 免费亚洲电影 | 日韩av资源站 | 亚洲日本欧美 | 手机av电影在线 | 国产精品一区二区果冻传媒 | 久久精品黄色 | 日韩黄色免费 | av一区在线播放 | 最新中文字幕视频 | 日韩一级成人av | 亚洲国产视频在线 | 亚洲人成人在线 | 国产一区二区在线免费播放 | 麻豆传媒视频在线 | 激情视频网页 | 91香蕉国产| 24小时日本在线www免费的 | 久久在线免费观看 | 国产欧美精品一区二区三区四区 | 国产99久久精品 | 色五月激情五月 | 欧美伦理电影一区二区 | 亚洲欧美成人网 | 欧美视频99| 国产亚洲精品日韩在线tv黄 | 在线 成人| 丁香婷婷激情国产高清秒播 | 亚洲永久字幕 | 国产精品麻豆一区二区三区 | 成av人电影 | 草草草影院 | 久久久国产视频 | 亚洲高清精品在线 | 激情久久综合网 | 中文字幕免费看 | 精品久久九九 | 9色在线视频 | 国产精品综合久久久 | 99久久久国产精品免费观看 | 又黄又爽又湿又无遮挡的在线视频 | 五月天丁香综合 | 久久久久观看 | 中文字幕一区av | 伊人影院av | 国产九九九九九 | 97色婷婷人人爽人人 | 日b视频国产 | 亚洲欧洲精品一区二区 | 在线а√天堂中文官网 | 在线免费日韩 | a级免费观看 | 九九免费在线视频 | 欧美激情第一页xxx 午夜性福利 | 日韩黄色大片在线观看 | 一区av在线播放 | 成人国产网址 | 麻豆成人精品 | 国产精品久久久久久麻豆一区 | 国产伦精品一区二区三区无广告 | 国产色在线 | 91爱在线| 91aaa在线观看| 亚洲 中文 欧美 日韩vr 在线 | 亚洲国产精品va在线看黑人 | 亚洲综合网站在线观看 | 欧美一区影院 | 国产手机在线观看视频 | 中文字幕在线观看网址 | 久久不射影院 | 日韩成人免费观看 | 国产一级在线 | 伊人久操 | 亚洲免费在线观看视频 | 五月婷婷在线观看视频 | 国产成人精品在线播放 | www欧美色 | 久久99精品国产麻豆婷婷 | 国产成人久久精品77777 | 国产成人精品免费在线观看 | 视频在线观看国产 | 久久免费视频这里只有精品 | 日日夜夜狠狠操 | 黄色影院在线免费观看 | 色狠狠综合 | 免费在线成人av | 综合色在线观看 | 91亚洲影院 | 一区二区三区韩国免费中文网站 | 色婷婷综合在线 | 精品一区二区三区久久久 | 超碰人人在线 | 色网免费观看 | 黄色大全在线观看 | 激情五月在线 | 日本在线视频网址 | 在线欧美a | av线上免费观看 | 婷婷六月丁| 成人永久视频 | 永久免费观看视频 | 欧美日韩国产网站 | 久久99国产综合精品 | 欧美性粗大hdvideo | 亚洲男男gⅴgay双龙 | 免费在线观看av的网站 | а中文在线天堂 | 午夜精品婷婷 | 在线免费观看的av | 96精品高清视频在线观看软件特色 | 九九热在线精品视频 | 狠狠狠色丁香综合久久天下网 | 最新亚洲视频 | 最近中文字幕免费观看 | 奇米影视在线99精品 | 又黄又爽又刺激视频 | 色综合夜色一区 | 在线视频观看成人 | 成人小视频在线观看免费 | 国产尤物视频在线 | 久久国产经典视频 | 四虎5151久久欧美毛片 | 国产成人一区二区精品非洲 | 成人观看| 狠狠狠色丁香婷婷综合久久88 | 成年人黄色免费看 | 在线观看的av | 91在线入口| 在线中文字母电影观看 | 操操综合网| www.天天成人国产电影 | 日韩精品一区二区三区高清免费 | 成年人电影毛片 | 麻豆网站免费观看 | 国产精品综合久久久 | 美女视频一区二区 | 四虎在线观看精品视频 | 国产一级免费电影 | 欧美日韩不卡在线视频 | 欧美日韩精品在线播放 | 精品1区2区3区 | 国产免费一区二区三区最新 | 精品美女国产在线 | 青青河边草免费观看完整版高清 | 91在线国产观看 | 日本精品一区二区三区在线观看 | 激情婷婷 | 国产精品毛片一区二区三区 | 人人干在线 | 午夜精品久久久久久久久久久久久久 | 日韩av一区二区三区四区 | 可以免费观看的av片 | 激情婷婷丁香 | 久久免费精品一区二区三区 | 日韩免费小视频 | 中文区中文字幕免费看 | 一区二区视 | 国产99久久久久久免费看 | 国产伦理久久精品久久久久_ | 欧美特一级 | 亚洲成人av在线 | 狠狠ri | 在线观看一区二区视频 | 久久夜色网 | 欧洲精品在线视频 | 人人擦 | 精品久久久亚洲 | 国产精品一区一区三区 | 久久久国际精品 | www.成人久久 | a电影在线观看 | 天天综合天天做天天综合 | 国产精品免费一区二区三区在线观看 | 亚洲黄色免费电影 | 91麻豆高清视频 | 精品99免费 | 国产xxxx| 国产在线一线 | www.com.黄| 97av影院| 久久精品国产成人精品 | 国产精品亚洲片夜色在线 | 在线观看视频免费大全 | 国产美女黄网站免费 | 中文字幕电影在线 | 亚洲精品一区中文字幕乱码 | 狠狠网站| 欧美视频xxx | 日韩一区二区三区高清在线观看 | 久久综合毛片 | 欧美 亚洲 另类 激情 另类 | 中文字幕在线影视资源 | 黄色片视频免费 | www亚洲视频| 一区二区三区中文字幕在线 | 欧美激情视频免费看 | 91av国产视频 | 亚洲视频免费视频 | 久久久久国产免费免费 | 日b黄色片 | 成人免费视频免费观看 | 伊人伊成久久人综合网站 | 日日夜夜综合网 | 欧美在线视频第一页 | 久久高清国产视频 | 精品久久1 | 91人人人 | 亚洲视频在线看 | 久久久国产精品成人免费 | 日韩免费视频一区二区 | 亚洲精品久久久蜜桃直播 | 一区免费在线 | 激情婷婷 | 国内精品久久久久久 | 欧美亚洲一级片 | 国产精品免费观看国产网曝瓜 | 爱av在线网| 国产成人在线精品 | 日韩一区二区三区不卡 | 91精品国产91久久久久久三级 | 成人av直播| 亚洲国产精品99久久久久久久久 | 超碰97人人在线 | 最新高清无码专区 | 狠狠狠色丁香婷婷综合久久88 | 黄色视屏在线免费观看 | 国内精品久久久久久久久久清纯 | 中文字幕色在线 | 一本一道波多野毛片中文在线 | 国产精品av在线免费观看 | 最新黄色av网址 | 国产精品视频内 | 国产视频日韩 | 91成年人视频 | 丁香综合网 | 日韩av在线高清 | 色橹橹欧美在线观看视频高清 | 91亚洲国产成人 | 午夜.dj高清免费观看视频 | 日日夜夜精品免费 | 亚洲精品乱码久久久久久蜜桃91 | 五月婷婷另类国产 | 九九九国产 | 国产在线精品观看 | 4438全国亚洲精品观看视频 | 久久久天天操 | 久久精品一区二区三区中文字幕 | 天天操 夜夜操 | 精品a在线 | 日韩av资源在线观看 | 亚洲精品av中文字幕在线在线 | 久久a级片 | 国产99自拍| 国产精品丝袜 | 97超碰人人澡人人 | 中文av在线天堂 | 天操夜夜操 | 欧美精品久久久久久久久久丰满 | 丝袜制服综合网 | 国内99视频 | 91视频传媒 | 在线91色| 国产精品区二区三区日本 | 成人一区不卡 | 亚洲清纯国产 | 在线国产日本 | 日韩欧美高清在线观看 | 亚洲在线日韩 | 尤物九九久久国产精品的分类 | 久艹在线观看视频 | 91成人免费电影 | 国产日本三级 | 久久www免费视频 | 精品999| 国产一性一爱一乱一交 | 中文字幕色网站 | 久久观看免费视频 | 国产精品九九久久久久久久 | 片网站 | 成人资源在线观看 | 国产打女人屁股调教97 | 99在线观看免费视频精品观看 | 五月婷婷欧美视频 | 亚洲午夜久久久久久久久电影网 | 国产一区欧美日韩 | 亚洲专区视频在线观看 | 91香蕉视频在线 | 国产麻豆果冻传媒在线观看 | 成人黄色资源 | 国产美女在线观看 | 91亚洲精品久久久蜜桃 | 97超碰福利久久精品 | 亚洲91精品 | 中文字幕av有码 | 国产高清福利在线 | 国产亚洲成av片在线观看 | 日韩一二三 | 久久精品精品 | 五月婷婷另类国产 | 激情欧美丁香 | 狠狠干夜夜爱 | 成人超碰97| 久草香蕉在线 | 国产精品18久久久久久久网站 | 91av短视频 | 日韩在线电影一区二区 | 欧美一二三视频 | 亚洲精品乱码久久久久久久久久 | 高潮毛片无遮挡高清免费 | 18网站在线观看 | 婷婷去俺也去六月色 | 国产91免费观看 | 99成人免费视频 | 五月天综合激情 | 免费日韩电影 | www.超碰| 久久艹艹 | 色视频在线免费 | 国产伦理久久精品久久久久_ | 在线中文字母电影观看 | 91精品国产一区 | a在线v| 草在线| 亚洲aⅴ免费在线观看 | 伊人久久av| 成年人免费观看在线视频 | 一区二区三区免费在线观看视频 | 国产成人在线观看免费 | 欧美一级日韩免费不卡 | 日韩高清精品一区二区 | 国产aaa免费视频 | av色一区 | 狠狠狠干狠狠 | 国产视频在| 一区二区三区在线观看免费 | 久久超级碰 | 天天se天天cao天天干 | 日韩免费在线观看网站 | 国产成人精品国内自产拍免费看 | 欧美亚洲一区二区在线 | 色姑娘综合网 | 欧美日韩在线观看视频 | 夜夜婷婷 | 日日夜夜婷婷 | 久久免费黄色大片 | 最近最新最好看中文视频 | 国产黄在线看 | 国产综合久久 | 天天综合人人 | 中文字幕av播放 | 99精品久久只有精品 | 亚洲成人网av| 色综合久久精品 | 1024在线看片 | 一区二区不卡视频在线观看 | 91视视频在线直接观看在线看网页在线看 | 97精品久久人人爽人人爽 | 亚洲视频免费在线看 | 婷婷色在线播放 | 九九爱免费视频 | 91精品国产麻豆 | 亚洲美女精品区人人人人 | 日韩免费福利 | 日韩av电影网站在线观看 | 成人精品国产免费网站 | 国产视频在线播放 | 国产一区二区视频在线播放 | 亚洲观看黄色网 | 丁香激情综合久久伊人久久 | 亚洲无人区小视频 | 人人射人人插 | 国产福利免费在线观看 | 丁香激情综合国产 | 成人免费在线网 | 久爱综合| 99亚洲国产 | 人人干狠狠干 | 久热久草在线 | 午夜视频黄| 波多野结衣在线视频免费观看 | 天天操比| 久久avav| 久久精品视频4 | 99色 | 亚洲成av片人久久久 | 国产成人亚洲在线电影 | 成人毛片一区 | 久久久久国产精品一区二区 | 中文字幕日韩有码 | 美女视频黄免费网站 | 精品国产免费人成在线观看 | 九九热免费在线视频 | 波多野结衣在线观看一区二区三区 | 亚洲天堂网在线视频观看 | 狠狠色狠狠色综合日日92 | 欧美一级片在线免费观看 | 亚洲欧洲在线视频 | 99福利片| 婷婷在线视频 | 国内精品久久久久久久影视简单 | 日韩理论在线视频 | 美腿丝袜一区二区三区 | 99re国产视频 | 日本色小说视频 | 日韩91在线 | 国产精品美女久久久久久免费 | 激情综合五月 | 国产精品美女免费 | 91精品国产自产在线观看永久 | 国产伦精品一区二区三区照片91 | 日韩中文字幕电影 | 国产精品自产拍在线观看蜜 | 国产99在线免费 | 伊人国产女 | 波多野结衣一区三区 | 最新亚洲视频 | 色播五月婷婷 | japanese黑人亚洲人4k | 天天躁日日躁狠狠躁av中文 | 99中文视频在线 | 色伊人网 | 国产123区在线观看 国产精品麻豆91 | 中文字幕久久亚洲 | 中文字幕欧美日韩va免费视频 | 91九色网址| 国产成人精品一区二区三区网站观看 | 看v片 | 在线免费观看av网站 | 高清国产一区 | 三级小视频在线观看 | 免费观看的av | 99精品视频免费在线观看 | 天天色天天干天天 | 人人揉人人揉人人揉人人揉97 | 狠狠干中文字幕 | 男女日麻批| 手机看片1042 | 一区二区三区电影 | 99热精品久久 | 999久久精品| 久久综合免费视频影院 | 日本久久久久久久久久 | 免费在线观看中文字幕 | 亚洲精品456在线播放第一页 | 国产黄色大片 | 国产一级大片免费看 | 成年性视频 | 91爱爱视频 | 国产九九九视频 | 久草新在线 | 欧美少妇18p | 毛片888| 91av在线免费观看 | 香蕉国产91| 国产剧情一区在线 | 成人av在线一区二区 | 日韩电影一区二区在线观看 | 中文字幕在线第一页 | 国产精品视频区 | 中中文字幕av在线 | 亚洲高清在线精品 | 久久精品视频网站 | 在线观看91 | 亚洲高清免费在线 | 天天躁日日躁狠狠 | 成 人 黄 色 视频 免费观看 | 高潮久久久久久 | 天天操欧美 | 五月综合色婷婷 | 中文字幕在线影院 | 国产精品一区二区三区在线播放 | 蜜臀久久99精品久久久久久网站 | 国内精品久久久久影院日本资源 | 黄色成人av | 久久综合狠狠综合久久狠狠色综合 | 999在线精品 | 麻豆精品传媒视频 | 国产一区在线免费观看视频 | 国产在线中文 | 嫩小bbbb摸bbb摸bbb | 国产精品久久久久婷婷 | 2019国产精品 | 久久精品爱爱视频 | 国产三级精品在线 | 亚洲欧洲精品一区二区 | 国产精品一区二区三区在线看 | 综合色天天| 一级免费看 | 免费三级骚 | 久久久久五月天 | 国产在线观看91 | 在线免费高清一区二区三区 | 九九免费精品视频在线观看 | 最近免费中文字幕大全高清10 | 亚洲成人xxx| 久久精品国产99国产 | 国产又粗又猛又爽又黄的视频免费 | 亚洲日本在线视频观看 | 久久精品国产亚洲精品 | 婷婷色综合色 | 黄色中文字幕 | 久久久久女人精品毛片 | 天天舔天天射天天操 | 日日综合网 | 99精品国产在热久久下载 | 欧美日韩国内在线 | 国产成人在线精品 | 天天天操天天天干 | 96亚洲精品久久久蜜桃 | 日韩午夜小视频 | 免费看三片| 日韩狠狠操 | 国产专区日韩专区 | 在线看福利av | 91人人人 | 精品国精品自拍自在线 | 毛片视频网址 | 99精品热视频 | 97视频免费观看 | av福利资源 | 国产一区二区精品久久91 | 亚洲观看黄色网 | 日韩中文字幕电影 | 中文字幕在线观看一区二区三区 | 亚洲精品在线观看中文字幕 | 狠狠的操你 | 亚洲韩国一区二区三区 | 麻豆久久| 人人爽人人爽人人片av | 欧美嫩草影院 | 91精品国产福利 | 亚洲精品乱码白浆高清久久久久久 | 九九热在线观看视频 | 日韩三级免费 | www99精品| 国产伦精品一区二区三区… | 国产精品区二区三区日本 | 国产精品色婷婷视频 | 国产一区黄色 | 久久视频二区 | 欧美精品久久人人躁人人爽 | 日本高清免费中文字幕 | 91福利视频网站 | av不卡网站 | 97在线公开视频 | 国产成人精品福利 | 九九热精品在线 | 国产女v资源在线观看 | 中文字幕一区在线 | 国精产品一二三线999 | 国内久久精品 | www久草| 999视频在线播放 | 成全在线视频免费观看 | 91漂亮少妇露脸在线播放 | 国产精品一区免费看8c0m | 日韩高清激情 | 欧美看片| 免费看黄视频 | www.色的| 成人在线电影观看 | 在线观看视频福利 | 久久久久久久久久免费视频 | 亚洲男人天堂2018 | 精品一区二区电影 | 99久久精品国产毛片 | 亚洲一区美女视频在线观看免费 | 中文字幕电影在线 | 九九在线播放 | 国产在线欧美在线 | 婷婷色五| 国产精品日韩高清 | 亚洲精品国产麻豆 | 免费网站在线 | 91av免费看 | 国产精品第2页 | 91在线中文 | 五月综合激情婷婷 | 日韩高清一二区 | 国产视频97| 91久久在线观看 | 亚洲 欧美 变态 国产 另类 | 1000部18岁以下禁看视频 | 国产在线成人 | 久久久久久久久久久福利 | 国产婷婷vvvv激情久 | 日日夜夜人人天天 | 午夜久久福利影院 | 另类老妇性bbwbbw高清 | 99在线观看视频网站 | 一区二区三区在线观看中文字幕 | 91精品啪在线观看国产线免费 | 国产.精品.日韩.另类.中文.在线.播放 | 91在线观看黄 | 国产精品日韩在线观看 | 日韩免费在线观看网站 | 91精品久久久久久久久 | 亚洲电影成人 | av天天在线观看 | 偷拍精品一区二区三区 | 国产一区二区在线影院 | 欧美激情精品久久久久 | 91在线免费观看国产 | 国产97碰免费视频 | 欧美激情精品久久久久 | 91中文在线观看 | 草久久影院 | 91av在线视频播放 | 成人夜晚看av | 日韩一区二区免费播放 | 最新中文字幕在线播放 | av成年人电影 | 97视频免费在线观看 | 在线看岛国av | 超碰人人99 | 国产精品婷婷午夜在线观看 | 欧美一级黄色网 | 免费视频91| 久久国产精品99久久久久久丝袜 | 91精品国产成人www | 91爱爱电影 | 日韩一二区在线观看 | 久久免费在线观看视频 | 中文字幕国产一区 | 国产人成在线视频 | 99免费在线观看视频 | 日韩欧美高清视频在线观看 | 特级毛片在线 | 天天操天天爱天天爽 | 激情视频免费观看 | 久久久久久久久久久免费视频 | 日韩性色 | 美女视频网站久久 | 在线国产一区二区三区 | 中文字幕三区 | 国产aa免费视频 | 夜夜操天天操 | 日韩一级黄色大片 | 91精品一区国产高清在线gif | 手机av观看| 天天射天天做 | 免费日韩视频 | 国产手机视频在线观看 | 成片免费观看视频999 | 国产精品免费观看视频 | 欧美另类色图 | 欧美日高清视频 | 黄色av网站在线观看免费 | 麻豆手机在线 | 国产黄色精品在线 | 成人免费视频观看 | 在线免费观看一区二区三区 | 国产视频在线一区二区 | 久久人人爽人人人人片 | 韩日色视频 | 亚洲aaa毛片 | 日韩中字在线 | 免费a v观看| 中文成人字幕 | 国产精品九九九 | 国产美女网站在线观看 | 国产二区电影 | 午夜精品久久久久久久久久久久久久 | 精品毛片在线 | 国产高清精 | 看片的网址 | 视频91 | 色婷婷电影 | 91免费版在线 | 日韩亚洲欧美中文字幕 | 日日夜夜免费精品视频 | 色婷婷综合久久久中文字幕 | 免费三级影片 | 欧美视屏一区二区 | 久久国产精彩视频 | 国产成人一区二区精品非洲 | 亚洲欧美日本一区二区三区 | 午夜 免费| 最新日韩精品 | 波多野结衣精品在线 | 中文字幕视频一区二区 | 亚洲成av人片在线观看www | 欧美伦理电影一区二区 | 国产一区二区久久精品 | 亚洲午夜久久久久久久久电影网 | 国产精品嫩草影视久久久 | 亚洲精品一区二区三区四区高清 | 亚洲欧美国产视频 | 超级碰视频 | 国产精品美女久久久 | 国产精品av在线免费观看 | 国产精品系列在线播放 | 精品亚洲一区二区 | 在线播放亚洲激情 |