说明: 您的C代码(以及下面的Swift版本)检查程序是否在 调试器的控制 下运行 ,
而不是是否从Xpre运行。一个人可以在Xpre之外调试程序(直接调用lldb或gdb),一个人可以在不调试的情况下从Xpre运行程序(如果scheme设置中的“
Debug Executable”复选框已关闭)。
您可以简单地保留C函数并从Swift调用它。
但是将代码转换为Swift实际上并不复杂:
func amIBeingDebugged() -> Bool { var info = kinfo_proc() var mib : [Int32] = [CTL_KERN, KERN_PROC, KERN_PROC_PID, getpid()] var size = strideofValue(info) let junk = sysctl(&mib, UInt32(mib.count), &info, &size, nil, 0) assert(junk == 0, "sysctl failed") return (info.kp_proc.p_flag & P_TRACED) != 0}
备注:
kinfo_proc()
创建一个完全初始化的结构,其中所有字段都设置为零,因此info.kp_proc.p_flag = 0
不需要设置。- C
int
类型Int32
是Swift。 sizeof(info)
C语言中的代码必须strideOfValue(info)
在Swift中包含结构填充。使用sizeofValue(info)
上述代码,对于64位设备,在Simulator中始终返回false。这是最难弄清的部分。
Swift 3(Xpre 8)更新:
strideofValue并且相关功能已不存在,已被替换为
MemoryLayout:
func amIBeingDebugged() -> Bool { var info = kinfo_proc() var mib : [Int32] = [CTL_KERN, KERN_PROC, KERN_PROC_PID, getpid()] var size = MemoryLayout<kinfo_proc>.stride let junk = sysctl(&mib, UInt32(mib.count), &info, &size, nil, 0) assert(junk == 0, "sysctl failed") return (info.kp_proc.p_flag & P_TRACED) != 0}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)