Apreendendo a utilizar o GNU Debugger (parte 2)

Neste artigo falarei de backtrace. O que é? Como usar? Pra que serve? Também explorei um pouco mais sobre breakpoints e alguns comandos para controlar o fluxo do programa em execução. Tudo isso no nosso depurador favorito, o GNU Debugger.

[ Hits: 42.549 ]

Por: Ricardo Rodrigues Lucca em 24/09/2004 | Blog: http://aventurasdeumdevop.blogspot.com.br/


Mais breakpoints



Agora nós vamos conhecer um pouquinho mais sobre os breakpoints. Primeiro de tudo, vamos aprender como vimos os breakpoints definidos atualmente. A exibição desse tipo de informação é feita através do comando "info" que tem como objetivo mostrar informações genéricas. Se quiser conhecê-lo a fundo utilize a ajuda online do gdb. Agora, como visualizamos os breakpoints atuais? Simples!

(gdb) info breakpoints
Num Type           Disp Enb Address    What
1   breakpoint     keep y   0x080483ca in bla at teste.c:7
        breakpoint already hit 1 time
2   breakpoint     keep y   0x080483e4 in bla at teste.c:9
        breakpoint already hit 1 time

Do mesmo modo, podemos abreviar o comando sem problemas!

(gdb) i b
Num Type           Disp Enb Address    What
1   breakpoint     keep y   0x080483ca in bla at teste.c:7
        breakpoint already hit 1 time
2   breakpoint     keep y   0x080483e4 in bla at teste.c:9
        breakpoint already hit 1 time

Agora, como faríamos para apagar um desses breakpoints? Para isso utilizamos o comando "delete" seguido do numero do breakpoint (que obtemos via "info b"). Assim, vamos remover o breakpoint da linha 9.

(gdb) del 2

Novamente estou mostrando como o gdb é poderoso, permitindo que se não acha outro comando com nome parecido possa haver a abreviação do nome. Assim, ao invés de escrever "delete" podemos escrever "del" ou até mesmo "d".

Vejamos um exemplo para remover todos os breakpoints de uma só vez.

(gdb) d
Delete all breakpoints? (y or n) y
(gdb) info breakpoints
No breakpoints or watchpoints.

No artigo anterior você aprendeu a utilizar o comando "break" com o número da linha informado com o comando "list". Mas fora essa opção também podemos utilizá-lo com o nome de uma função. Assim:

(gdb) b bla
Breakpoint 3 at 0x80483ca: file teste.c, line 7.

Essa linha "Breakpoint 3 at 0x80483ca: file teste.c, line 7." nos informa que o breakpoint foi bem sucedido. Mas não só isso. Nela é dita que foi criado o "breakpoint" de número 3, na linha 7 do arquivo "teste.c". Muito útil, não acham???

Página anterior     Próxima página

Páginas do artigo
   1. Introdução
   2. Fonte
   3. Continue e finish
   4. Mais breakpoints
   5. (un)display
   6. Backtrace, indo e vindo de funções
   7. Conclusão
Outros artigos deste autor

Utilizando a função QSort em C

Como posso recuperar o boot loader?

Criando um servidor de Ultima Online

Introdução à linguagem C - Parte IV

Introdução as Bibliotecas do C/C++

Leitura recomendada

Gerencie suas contas financeiras pessoais com Terminal Finances

Criando aplicativos para o Mac OS X no GNU/Linux

Como aprender a programar e produzir aplicativos usando Euphoria

Túnel do Tempo: a função itoa()

C - Include e Makefile

  
Comentários
[1] Comentário enviado por y2h4ck em 24/09/2004 - 10:30h

Como diram certos programadores, debbugar e uma arte que eu prefiro deixar a parte :D

Mas eu gosto de debbug ehehe sempre se encontra doces surpresas em cada
dissassemble :D

Maneiro o Artigo Jlluca..

abraços

[2] Comentário enviado por engos em 24/09/2004 - 13:13h

Nem da pra acreditar que foi você mesmo que fez o primeiro, esse ficou muito melhor! Nota 10!

Só uma coisa, segui seu artigo passo a passo e o "winheight" não funcionou comigo, onde digito isso e em que momento?

Ah, não achei que foi muita coisa para ser absorvida de uma única forma, até que achei o "básico", levando em consideração o assunto.

Parabéns pelo artigo!

[3] Comentário enviado por jllucca em 24/09/2004 - 13:23h

Aew, 'brigado pelos elogios y2h4ck e engos!

Sobre o "winheight" tava falando com o y2h4ck que em algumas maquinas que utilizo não achei ele(gdb 5.4). Deve ser porcausa das versões desatualizadas... Verifica se voce está com a versão 6.1.1, pois foi nessa que fiz o artigo :)

[]'s

[4] Comentário enviado por engos em 24/09/2004 - 17:20h

Infelizmente minha versão é a 5.3... :(

Mas é bom saber que atualizando tenho essa opção.

Valeu!

PS.: Não faço elogios, só falo a verdade como a vejo... :)

[5] Comentário enviado por macroney em 27/09/2004 - 14:40h

parabéns !
muito bom !!!

embora nem li tudo .......
mas vale ...

pô !, alguém conhece algum livro ou tem alguma apostila sobre Assembly , encontrei um em pt_BR , é novo, mas é muito superficial... eu acho ( embora nem programo em assembly) , Pois peguei uma apostila e me parece boa...

valeuz!

[6] Comentário enviado por wildtux em 16/01/2014 - 11:39h

Sei que o tópico é antigo. Mas mesmo assim parabéns pela iniciativa, está me ajudando muito a tirar algumas dúvidas, uso linux e gosto de usar também o cygwin.

Dica1: Pra quem ainda não se aventurou em Assembly, existem vários sites que ensinam sobre alguma coisa. Existem também alguns livros do autor Jon Erickson é só dar uma pesquisada.

Dica2: Pra quem quer debugar arquivos .exe no cygwin é só seguir o mesmo procedimento trocando o a.out pelo a.exe gerado no cygwin full.

Abraço ao jllucca, valeu cara! =D. Viva a comunidade, viva ao Linux!!!


Contribuir com comentário




Patrocínio

Site hospedado pelo provedor RedeHost.
Linux banner

Destaques

Artigos

Dicas

Tópicos

Top 10 do mês

Scripts