Rust引用借用 vs 原始指针

rust 复制代码
let v: i32 = 10;
let v1 = &v;
let a: *const i32 = &v;
println!("a={:p}", a);
let b = a as *mut i32;  //无法从&v直接转换成*mut i32,需要从*const i32过度
println!("b={:p}", b);
unsafe {
    *b+=1;
}
println!("v={}   v1={}", v, v1);

输出

复制代码
a=0xa7c8fb4d8
b=0xa7c8fb4d8
v=11   v1=11
rust 复制代码
    let mut mv: i32 = 10;
    let mut mv2 = &mut mv;
    *mv2 = *mv2 + 1;
    let p1 = mv2 as *const i32 as *mut i32;
    unsafe {
        *p1 += 1;
    }
    //let p2 = mv2 as *const i32;
    let mv3 = unsafe {
        let i: i32 = *p1;
        i
    };
    println!("mv2={}  mv3={}", mv2, mv3);

mv2=12 mv3=12

rust 复制代码
    use std::borrow::Cow;
    use std::os::raw::c_char;
    use std::ffi::CStr;
    let C: [u8; 11] = [116, 104, 97, 110, 107, 115, 102, 105, 115, 104, 0];
    let c_str: Cow<str>;
    unsafe{
        let c_ptr = &C as *const u8 as *const c_char;
        c_str = CStr::from_ptr(c_ptr).to_string_lossy();
    }
    println!("c_str is    {}", c_str);

c_str is thanksfish

原始指针和unsafe块配合,可以避过引用借用保护,但也失去了rust的优势。rust严谨也足够灵活...,除非必要原始指针慎用,用多了又变成c了...

相关推荐
doiito4 小时前
【Agent Harness】Gliding Horse 设计细节 -- 不跟风开发自己的AI Agent
架构·rust·agent
doiito6 小时前
【Agent Harness】Gliding Horse 核心设计理念,不跟风开发自己的AI Agent
ai·rust·架构设计·系统设计·ai agent
花褪残红青杏小16 小时前
Rust图像处理第6节- 均值模糊 & 中值模糊:3×3 邻域的两种经典玩法
rust·webassembly·图形学
子兮曰20 小时前
前端工具链的「Rust 化」:一场没有赢家的军备竞赛?
前端·后端·rust
星栈1 天前
写 Dioxus Demo 不难,难的是把它写成项目
前端·rust·前端框架
mCell1 天前
【锐评】桌面端技术营销:别拿跑分当工程判断
前端·rust·electron
武子康1 天前
调查研究-201 Rust 里的 dev build 和 release build:为什么同一份代码性能差这么多?
后端·架构·rust
doiito1 天前
【Agent Harness】Gliding Horse 的 L2 作战地图:让多 Agent 协作从“摸黑”变成“透明”
ai·rust·架构设计·系统设计·ai agent
星栈2 天前
我用 Rust + Dioxus 做了个全栈跨平台笔记应用:再把新建、编辑和交付补上
前端·rust·前端框架
独孤留白2 天前
从C到Rust:基本类型 C 的隐式不确定 vs Rust 的显式确定
rust