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?

Antworten auf die Frage(2)

Ihre Antwort auf die Frage