本文简要介绍rust语言中 std::string::String.from_raw_parts
的用法。
用法
pub unsafe fn from_raw_parts( buf: *mut u8, length: usize, capacity: usize) -> String
根据长度、容量和指针创建一个新的 String
。
安全性
由于未检查的不变量的数量,这是非常不安全的:
buf
处的内存需要由标准库使用的同一个分配器先前分配,并且所需的对齐正好为 1。length
需要小于或等于capacity
。capacity
必须是正确的值。buf
的第一个length
字节需要是有效的 UTF-8。
违反这些可能会导致诸如破坏分配器的内部数据结构之类的问题。
buf
的所有权有效地转移到String
,然后可以随意释放、重新分配或更改指针指向的内存内容。确保调用此函数后没有其他任何东西使用该指针。
例子
基本用法:
use std::mem;
unsafe {
let s = String::from("hello");
// Prevent automatically dropping the String's data
let mut s = mem::ManuallyDrop::new(s);
let ptr = s.as_mut_ptr();
let len = s.len();
let capacity = s.capacity();
let s = String::from_raw_parts(ptr, len, capacity);
assert_eq!(String::from("hello"), s);
}
相关用法
- Rust String.from_utf16_lossy用法及代码示例
- Rust String.from_utf8_lossy用法及代码示例
- Rust String.from_utf16用法及代码示例
- Rust String.from_utf8_unchecked用法及代码示例
- Rust String.from_utf8用法及代码示例
- Rust String.try_reserve用法及代码示例
- Rust String.insert_str用法及代码示例
- Rust String.into_raw_parts用法及代码示例
- Rust String.extend_from_within用法及代码示例
- Rust String.clear用法及代码示例
- Rust String.reserve用法及代码示例
- Rust String.push用法及代码示例
- Rust String.as_bytes用法及代码示例
- Rust String.as_str用法及代码示例
- Rust String.with_capacity用法及代码示例
- Rust String.remove用法及代码示例
- Rust String.into_bytes用法及代码示例
- Rust String.replace_range用法及代码示例
- Rust String.split_off用法及代码示例
- Rust String.shrink_to_fit用法及代码示例
- Rust String.into_boxed_str用法及代码示例
- Rust String.new用法及代码示例
- Rust String.insert用法及代码示例
- Rust String.capacity用法及代码示例
- Rust String.try_reserve_exact用法及代码示例
注:本文由纯净天空筛选整理自rust-lang.org大神的英文原创作品 std::string::String.from_raw_parts。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。