Rust: offset祼指针操作

offset是偏移元素个数,不是字节数!

bash 复制代码
fn main(){
    let student_a = Student{id:20240001,name:"张三娃".into(),class_id:3,age:14,grade:1};
    let student_b = Student{id:20240002,name:"李四牛".into(),class_id:3,age:15,grade:1};
    let student_c = Student{id:20240003,name:"王二狗".into(),class_id:3,age:14,grade:1};
    let student_d = Student{id:20240004,name:"吴七喜".into(),class_id:3,age:24,grade:1};
    let students= vec![student_a, student_b, student_c, student_d];
    let class = Class{students,class_id:3,grade:1};
    let student_size = std::mem::size_of::<Student>(); // student结构体大小
    let student_align= std::mem::align_of::<Student>();//student内部对齐
    println!("student_size:{:?} student_align:{:?}",student_size,student_align);
    let class_ptr   = &class as *const Class;
    let student_a_ptr = &class.students[0] as *const Student;
    println!("student_a value :{:?}",unsafe{&*student_a_ptr as &Student});
    //let student_b_ptr = unsafe{ student_a_ptr.add(1)}; // 也可以用add这种方式
    // 注意:offset不是偏移字节数,而是偏移元素个数!
    let student_b_ptr = unsafe{ student_a_ptr.offset(1)}; // offset方式
    let offset_between_a_and_b = unsafe{student_a_ptr.offset_from(student_b_ptr)};
    println!("offset_between_a_and_b:{}",offset_between_a_and_b);// -1
    println!("student_b value name :{:?}",unsafe{&*student_b_ptr as &Student}.name);
    //let student_c_ptr = unsafe{ student_a_ptr.add(2)};
    let student_c_ptr = unsafe{ student_a_ptr.offset(2)};
    let student_d_ptr = unsafe{ student_a_ptr.offset(3)};
    println!("student_b ref ptr address : {:p} convert raw ptr address : {:?}",&class.students[1],student_b_ptr);
    println!("student_b ref ptr address : {:p} convert raw ptr address : {:?}",&class.students[2],student_c_ptr);
    println!("student_b ref ptr address : {:p} convert raw ptr address : {:?}",&class.students[3],student_d_ptr);

}
// 某某中学
// 班级
struct Class{
    students: Vec<Student>,//学生
    class_id: u32, //3班
    grade:u32, //高3
}
#[derive(Debug)]
struct Student{
    id: u32, //学号 2024000001;
    name: String, // 姓名,name="张三"
    class_id: u32, //班级,class_id=3,3班
    age: u32, //年龄
    grade: i8, //年级,grade=1,高中一年级
}

输出:

bash 复制代码
student_size:40 student_align:8
student_a value :Student { id: 20240001, name: "张三娃", class_id: 3, age: 14, grade: 1 }
offset_between_a_and_b:-1
student_a value :Student { id: 20240001, name: "张三娃", class_id: 3, age: 14, grade: 1 }
offset_between_a_and_b:-1
offset_between_a_and_b:-1
student_b value name :"李四牛"
student_b ref ptr address : 0x1c2ff7f6f48 convert raw ptr address : 0x1c2ff7f6f48
student_b ref ptr address : 0x1c2ff7f6f70 convert raw ptr address : 0x1c2ff7f6f70
student_b ref ptr address : 0x1c2ff7f6f98 convert raw ptr address : 0x1c2ff7f6f98

其实,你可以通过offset函数源码,可以了解更清楚,在offset内部,会再以bytes的倍数进行check_add。

相关推荐
星栈20 小时前
Dioxus 多页面怎么做:`dioxus-router`、嵌套路由、`Outlet` 和页面组织,一篇给你讲顺
前端·rust·前端框架
JieE2121 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Rust研习社2 天前
组合真的优于继承吗?为什么 Rust 和 Go 都拥抱组合舍弃继承?
后端·rust·编程语言
Jack203 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树3 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2123 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2123 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像