以下代码用于将 a 转换sockaddr
为 asockaddr_in6
以获取 IPv6 地址:
extension sockaddr {
private var addressV6: String {
var me = self
var buffer = [Int8](repeating: 0, count: Int(INET6_ADDRSTRLEN))
withUnsafePointer(to: &me) {
$0.withMemoryRebound(to: sockaddr_in6.self, capacity: 1) {
var addrV6 = $0.pointee.sin6_addr
inet_ntop(AF_INET6, &addrV6, &buffer, socklen_t(INET6_ADDRSTRLEN))
}
}
return String(cString: buffer)
}
}
当我使用 Address Sanitizer 在 Xcode 9 beta 中运行代码时,执行会在这一行停止:
var addrV6 = $0.pointee.sin6_addr
使用以下消息(加上大量内存信息):
AddressSanitizer:堆栈缓冲区溢出地址 0x000131810077 在 pc 0x00010a3c06d5 bp 0x7fff55ded010 sp 0x7fff55ded008 在 0x000131810077 线程 T0 处读取大小 16
我可以理解,ASAN 担心我正在阅读超出边界sockaddr
以获取完整信息sockaddr_in6
(sockaddr
即 16 字节,sockaddr_in6
即 28 字节)。
但由于这个原因,我似乎无法使用 ASAN 测试我的应用程序的其余部分。任何使用withMemoryRebound
都会使 ASAN 跳闸似乎有点奇怪。
我尝试以不同的方式编写它,甚至Data
用作字节的容器。但我似乎总能找到触发 ASAN 的解决方案。
我的代码有问题吗?
或者我可以以某种方式忽略 ASAN 中的这个功能吗?