XCode:以编程方式启用符号断点?

时间:2015-12-01 23:08:41

标签: ios xcode uiscrollview uikit lldb

有没有办法以编程方式启用断点?通常我会使用断点条件,但我需要使用符号断点。

具体来说,在调用contentOffset和调用scrollToIndexPath之间,某些内容正在更改我的UIScrollView的reloadData。我想在调用scrollToIndexPath之后才启用符号断点。

2 个答案:

答案 0 :(得分:4)

Jim Ingham的回答适用于x86系统。对于iOS设备,我能够使用this answer中描述的方法以编程方式创建断点。插入行

asm("svc 0");

使调试器停止在XCode中的以下指令上。

enter image description here

有趣的是,如果您未连接到XCode,程序将继续正常执行。

答案 1 :(得分:1)

您可以使用__builtin_trap()来执行此操作。在x86系统上,您必须在按下陷阱后手动调整电脑。但这很容易做到,如果你的代码受到很多打击并且你只需要在一些复杂的情况下陷阱,那么它有时很有用。类似的东西:

 > lldb trapit
(lldb) target create "trapit"
Current executable set to 'trapit' (x86_64).
(lldb) run
Process 63363 launched: '/private/tmp/trapit' (x86_64)
About to trap.
Process 63363 stopped
* thread #1: tid = 0x2054b7, function: main , stop reason = EXC_BAD_INSTRUCTION (code=EXC_I386_INVOP, subcode=0x0)
    frame #0: 0x0000000100000f4d trapit`main at trapit.c:6
   3    int main()
   4    {
   5      printf ("About to trap.\n");
-> 6      __builtin_trap();
   7      printf("Trapped.\n");
   8    }
(lldb) dis -f
trapit`main:
    0x100000f30 <+0>:  pushq  %rbp
    0x100000f31 <+1>:  movq   %rsp, %rbp
    0x100000f34 <+4>:  subq   $0x10, %rsp
    0x100000f38 <+8>:  leaq   0x47(%rip), %rdi          ; "About to trap.\n"
    0x100000f3f <+15>: movb   $0x0, %al
    0x100000f41 <+17>: callq  0x100000f66               ; symbol stub for: printf
    0x100000f46 <+22>: leaq   0x49(%rip), %rdi          ; "Trapped.\n"
->  0x100000f4d <+29>: ud2    
    0x100000f4f <+31>: movl   %eax, -0x4(%rbp)
    0x100000f52 <+34>: movb   $0x0, %al
    0x100000f54 <+36>: callq  0x100000f66               ; symbol stub for: printf
    0x100000f59 <+41>: xorl   %ecx, %ecx
    0x100000f5b <+43>: movl   %eax, -0x8(%rbp)
    0x100000f5e <+46>: movl   %ecx, %eax
    0x100000f60 <+48>: addq   $0x10, %rsp
    0x100000f64 <+52>: popq   %rbp
    0x100000f65 <+53>: retq   
(lldb) reg write pc 0x100000f4f
(lldb) c
Process 63363 resuming
Trapped.
Process 63363 exited with status = 0 (0x00000000)