當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


Rust UdpSocket.peek用法及代碼示例


本文簡要介紹rust語言中 std::net::UdpSocket.peek 的用法。

用法

pub fn peek(&self, buf: &mut [u8]) -> Result<usize>

在套接字上從它所連接的遠程地址接收單個數據報,而不從輸入隊列中刪除消息。成功時,返回查看的字節數。

必須使用具有足夠大小的有效字節數組buf 來調用該函數以保存消息字節。如果消息太長而無法放入提供的緩衝區,則可能會丟棄多餘的字節。

連續調用返回相同的數據。這是通過將MSG_PEEK 作為標誌傳遞給底層recv 係統調用來實現的。

不要使用這個函數來實現忙等待,而是使用libc::poll來同步一個或多個socket上的IO事件。

UdpSocket::connect 將此套接字連接到遠程地址。如果套接字未連接,此方法將失敗。

錯誤

如果套接字未連接,此方法將失敗。 connect 方法將此套接字連接到遠程地址。

例子

use std::net::UdpSocket;

let socket = UdpSocket::bind("127.0.0.1:34254").expect("couldn't bind to address");
socket.connect("127.0.0.1:8080").expect("connect function failed");
let mut buf = [0; 10];
match socket.peek(&mut buf) {
    Ok(received) => println!("received {} bytes", received),
    Err(e) => println!("peek function failed: {:?}", e),
}

相關用法


注:本文由純淨天空篩選整理自rust-lang.org大神的英文原創作品 std::net::UdpSocket.peek。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。