1.88.0稳定版中有什么
让链
此功能允许在如和当条件中,甚至布尔式中,允许&&链接let语句,因此if/if let和while/while let之间的区别较小.
let子式内的模式可以是无可辩驳的,链中稍后部分及体中可用绑定.
如,此代码段结合了多个之前需要嵌套iflet和如块的条件:
cpp
if let Channel::Stable(v) = release_info()
&& let Semver { major, minor, .. } = v
&& major == 1
&& minor == 88
{
println!("`let_chains` was stabilized in this version");
}
let链仅在Rust2024版本中可用,因为此功能依赖iflet临时域的变化以取得更一致的放顺序,这里.
裸函数
Rust现在支持编写没有编译器生成的尾声和序言的裸函数,从而允许完全控制特定函数生成的汇编.这是在global_asm!中定义函数的更符合人体工程学的块.
用主体由单个naked_asm!组成的#[unsafe(naked)]属性标记裸函数.
如:
cpp
#[unsafe(naked)]
pub unsafe extern "sysv64" fn wrapping_add(a: u64, b: u64) -> u64 {
// 相当于`"a.wrapping_add(b)"`.
core::arch::naked_asm!(
"lea rax, [rdi + rsi]",
"ret"
);
}
手写汇编块定义了整个函数体:与非裸函数不同,编译器不会为参数或返回值添加任何特殊处理.裸函数用在低级设置,如Rust的编译器内置,操作系统和嵌入式应用.
布尔配置
配置(cfg)判定语言现在支持,分别用作总是允许或禁止的配置的真和假布尔字面.这适合有配置和cfg_attr属性及内置配置!宏及配置和清单中的Cargo[target]表的Rust条件编译.
以前,空判定列表可用在无条件配置,如cfg(all())表示允许,cfg(any())表示禁止,但该含义相当隐式且易于倒退.
cfg(true)和cfg(false)更直接的表达你的意思.
这里
这里
货物自动缓存清理
稳定的API
cpp
Cell::update
impl Default for *const T
impl Default for *mut T
mod ffi::c_str
HashMap::extract_if
HashSet::extract_if
hint::select_unpredictable
proc_macro::Span::line
proc_macro::Span::column
proc_macro::Span::start
proc_macro::Span::end
proc_macro::Span::file
proc_macro::Span::local_file
<[T]>::as_chunks
<[T]>::as_rchunks
<[T]>::as_chunks_unchecked
<[T]>::as_chunks_mut
<[T]>::as_rchunks_mut
<[T]>::as_chunks_unchecked_mut
这些以前稳定的API,现在在常环境中是稳定的:
cpp
NonNull<T>::replace
<*mut T>::replace
std::ptr::swap_nonoverlapping
Cell::replace
Cell::get
Cell::get_mut
Cell::from_mut
Cell::as_slice_of_cells