- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当查看 unix-socket
时,我遇到了这段代码:
let timeout = unsafe {
let mut timeout: libc::timeval = mem::zeroed();
let mut size = mem::size_of::<libc::timeval>() as libc::socklen_t;
try!(cvt(libc::getsockopt(self.0,
libc::SOL_SOCKET,
kind,
&mut timeout as *mut _ as *mut _,
&mut size as *mut _ as *mut _)));
timeout
};
我特别好奇这些行:
&mut timeout as *mut _ as *mut _,
&mut size as *mut _ as *mut _
为什么需要对一个可变原始指针连续执行两次转换?为什么只施放一次还不够?
最佳答案
例如 timeout
对应于 *mut c_void
参数:
pub unsafe extern fn getsockopt(sockfd: c_int, level: c_int, optname: c_int,
optval: *mut c_void, optlen: *mut socklen_t) -> c_int
该文件中的 timeout
定义为:
let mut timeout: libc::timeval = mem::zeroed();
所以它是 libc::timeval
类型。现在让我们考虑:
&mut timeout as *mut _ as *mut _
首先你有 &mut timeout
所以它是 &mut libc::timeval
类型。然后你执行 as *mut _
将其强制转换为推断类型的原始可变指针,在本例中它与 libc::timeval
的类型相同,因此到目前为止的完整类型是:*mut libc::timeval
,它与参数类型*mut c_void
不匹配。最后的 as *mut _
再次推断出目标类型,现在是参数类型 *mut c_void
,所以这最终强制了 *mut libc::timeval
到 *mut c_void
。
关于pointers - 为什么有必要对一个可变原始指针连续执行两次转换?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34691267/
我正在使用 this solution在二进制矩阵中找到与图像边界对齐的矩形。假设现在我想找到一个不与图像边框对齐的矩形,并且我不知道它的方向;找到它的最快方法是什么? 为了示例,让我们寻找一个仅包含
else: 行在这个 Python 程序中是否正确/必要? from random import randrange for n in range(10): r = randrange(0,1
在 TDPL 7.1.5.1 中讨论了将 Widget w2 分配给 w1 并且作者指出“将 w2 逐个字段分配给 w1 会将 w2.array 分配给 w1.array——一个简单的数组边界分配,而
我是一名优秀的程序员,十分优秀!