Warum ist es notwendig, zwei Casts auf einen veränderlichen rohen Zeiger hintereinander durchzuführen?
Beim Betrachten vonunix-socket
, Ich bin auf diesen Code gestoßen:
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
};
Ich war besonders neugierig auf diese Zeilen:
&mut timeout as *mut _ as *mut _,
&mut size as *mut _ as *mut _
Warum müssen zwei Casts hintereinander für einen veränderlichen Rohzeiger ausgeführt werden? Warum hätte es nicht gereicht, nur einmal zu wirken?