Struct std::io::Cursor 1.0.0[−][src]
pub struct Cursor<T> { /* fields omitted */ }
Expand description
Cursor
包装内存中的缓冲区,并为其提供 Seek
实现。
Cursor 与内存缓冲区一起使用,任何实现 AsRef
<[u8]>
的东西都允许它们实现 Read
或者 Write
,从而允许在实际使用 I/O 的 reader 或 writer 的任何地方使用这些缓冲区。
标准库在通常用作缓冲区的各种类型 (例如 Cursor<
Vec
<u8>>
和 Cursor<
&[u8]
>
) 上实现了一些 I/O traits。
Examples
我们可能想在生产代码中将字节写入 File
,但在测试中使用内存缓冲区。我们可以做到这一点
Cursor
:
use std::io::prelude::*; use std::io::{self, SeekFrom}; use std::fs::File; // 我们编写的库函数 fn write_ten_bytes_at_end<W: Write + Seek>(writer: &mut W) -> io::Result<()> { writer.seek(SeekFrom::End(-10))?; for i in 0..10 { writer.write(&[i])?; } // 一切顺利 Ok(()) } // 这是一些使用此库函数的代码。 // 我们可能想在此处使用 BufReader 来提高效率,但让我们继续关注此示例。 let mut file = File::create("foo.txt")?; write_ten_bytes_at_end(&mut file)?; // 现在让我们编写一个测试 #[test] fn test_writes_bytes() { // 设置一个真实的文件要比内存中的缓冲区慢得多,让我们用游标代替 use std::io::Cursor; let mut buff = Cursor::new(vec![0; 15]); write_ten_bytes_at_end(&mut buff).unwrap(); assert_eq!(&buff.get_ref()[5..15], &[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]); }Run
Implementations
返回此游标的当前位置。
Examples
use std::io::Cursor; use std::io::prelude::*; use std::io::SeekFrom; let mut buff = Cursor::new(vec![1, 2, 3, 4, 5]); assert_eq!(buff.position(), 0); buff.seek(SeekFrom::Current(2)).unwrap(); assert_eq!(buff.position(), 2); buff.seek(SeekFrom::Current(-1)).unwrap(); assert_eq!(buff.position(), 1);Run
返回剩余的三个。
Examples
#![feature(cursor_remaining)] use std::io::Cursor; let mut buff = Cursor::new(vec![1, 2, 3, 4, 5]); assert_eq!(buff.remaining_slice(), &[1, 2, 3, 4, 5]); buff.set_position(2); assert_eq!(buff.remaining_slice(), &[3, 4, 5]); buff.set_position(4); assert_eq!(buff.remaining_slice(), &[5]); buff.set_position(6); assert_eq!(buff.remaining_slice(), &[]);Run
Trait Implementations
返回内部缓冲区的内容,如果内部缓冲区为空,则使用内部 reader 中的更多数据填充内部缓冲区。 Read more
🔬 This is a nightly-only experimental API. (buf_read_has_data_left
#86423)
recently added
检查底层 Read
是否有任何数据可供读取。 Read more
将所有字节读入 buf
,直到到达定界符 byte
或 EOF。 Read more
读取所有字节,直到到达换行符 (0xA
字节),然后将它们附加到提供的缓冲区中。 Read more
返回对该字节 byte
上的 reader 拆分内容的迭代器。 Read more
将格式化的字符串写入此 writer,返回遇到的任何错误。 Read more
将格式化的字符串写入此 writer,返回遇到的任何错误。 Read more
将格式化的字符串写入此 writer,返回遇到的任何错误。 Read more
将格式化的字符串写入此 writer,返回遇到的任何错误。 Read more