当前位置: 首页 > wzjs >正文

网站seo置顶厅网站建设中标公告

网站seo置顶,厅网站建设中标公告,规模以上工业企业分析,网站设置超链接代码1. 启用 Panic 日志 1.1 让 Panic 信息显示在浏览器控制台 如果 Rust 代码发生 panic!(),默认情况下不会在浏览器开发者工具中显示详细的错误信息。这使得排查问题变得困难。 我们可以使用 console_error_panic_hook 这个 Rust crate,将 Panic 信息打…

1. 启用 Panic 日志

1.1 让 Panic 信息显示在浏览器控制台

如果 Rust 代码发生 panic!(),默认情况下不会在浏览器开发者工具中显示详细的错误信息。这使得排查问题变得困难。

我们可以使用 console_error_panic_hook 这个 Rust crate,将 Panic 信息打印到 浏览器控制台

1.2 在 wasm-game-of-life/src/lib.rs 中修改 new 方法

pub fn new() -> Universe {utils::set_panic_hook();  // 让 Panic 信息出现在控制台// 其他初始化代码...
}

1.3 安装 console_error_panic_hook

如果 wasm-game-of-life/src/utils.rs 还没有 set_panic_hook() 方法,我们需要手动引入 console_error_panic_hook

pub fn set_panic_hook() {console_error_panic_hook::set_once();
}

这样,当 Rust 代码 崩溃(panic) 时,就能在 浏览器控制台 看到详细的错误信息,包括 Rust 堆栈回溯(stack trace)

2. 添加日志调试

2.1 使用 web_sys::console.log 记录日志

WebAssembly 代码无法直接使用 println!(),但可以借助 web_sys 将日志输出到 浏览器控制台

首先,在 Cargo.toml 文件中启用 web-sys 依赖

[dependencies.web-sys]
version = "0.3"
features = ["console"]

然后,在 wasm-game-of-life/src/lib.rs 定义一个 log!(),用于在 Rust 代码中方便地输出调试信息:

extern crate web_sys;// 定义 `log!()` 宏,类似 `println!()`,但输出到 `console.log`
macro_rules! log {( $( $t:tt )* ) => {web_sys::console::log_1(&format!( $( $t )* ).into());}
}

2.2 在 tick() 方法中记录细胞状态

我们可以在 tick() 方法中 记录每个细胞的状态变化

impl Universe {pub fn tick(&mut self) {let mut next = self.cells.clone();for row in 0..self.height {for col in 0..self.width {let idx = self.get_index(row, col);let cell = self.cells[idx];let live_neighbors = self.live_neighbor_count(row, col);// 记录当前细胞的状态和活邻居数量log!("cell[{}, {}] is initially {:?} and has {} live neighbors",row, col, cell, live_neighbors);let next_cell = match (cell, live_neighbors) {(Cell::Alive, x) if x < 2 => Cell::Dead,  // 过少 -> 死亡(Cell::Alive, 2) | (Cell::Alive, 3) => Cell::Alive,  // 繁衍 -> 存活(Cell::Alive, x) if x > 3 => Cell::Dead,  // 过度拥挤 -> 死亡(Cell::Dead, 3) => Cell::Alive,  // 复活(otherwise, _) => otherwise,};// 记录细胞变化if next_cell != cell {log!("    cell[{}, {}] transitioned from {:?} to {:?}",row, col, cell, next_cell);}next[idx] = next_cell;}}self.cells = next;}
}

3. 在 JavaScript 中使用 debugger 进行断点调试

3.1 在 renderLoop() 中设置断点

我们可以在 renderLoop()手动插入 debugger; 语句,让浏览器在每次 tick() 之前 暂停代码执行

const renderLoop = () => {debugger;  // 断点调试,暂停执行universe.tick();drawGrid();drawCells();requestAnimationFrame(renderLoop);
};

3.2 调试步骤

在这里插入图片描述

  1. 打开开发者工具(F12 或右键 → Inspect)
  2. 进入 “Sources” 选项卡
  3. 执行 npm run start 运行游戏
  4. 游戏在 debugger; 处暂停,你可以:
    • 逐步执行代码(Step Over)
    • 观察变量的值
    • 查看 WebAssembly 内存状态

4. 练习

练习 1:记录状态变化

任务:在 tick() 方法中,仅记录发生状态变化的细胞(从 AliveDeadDeadAlive)。
实现

if next_cell != cell {log!("cell[{}, {}] transitioned from {:?} to {:?}",row, col, cell, next_cell);
}

练习 2:手动触发 Panic**

任务:在 new() 方法中 故意触发 panic,观察不同情况下的 浏览器堆栈追踪
实现

pub fn new() -> Universe {utils::set_panic_hook();panic!("Intentional panic for debugging!");  // 触发崩溃
}

步骤

  1. 运行 npm run start
  2. 在控制台查看 panic!() 抛出的错误
  3. 尝试关闭 console_error_panic_hook 并重新测试
    • Cargo.toml 移除 console_error_panic_hook
    • 运行 wasm-pack build
    • 观察 错误信息变得难以理解,因为 Rust Panic 追踪信息消失了。

5. 总结

调试技巧作用
console_error_panic_hook让 Rust Panic 信息出现在浏览器控制台
log!()在 Rust 代码中使用 console.log() 输出日志
记录状态变化仅在细胞状态改变时记录日志,减少无用信息
debugger; 断点让浏览器暂停在 tick() 之前,手动调试
手动 panic!()观察 Panic 追踪信息,学习如何优化错误信息

6.下一步

  • 优化 WebAssembly 性能
    • 使用 位运算优化细胞存储(每个细胞只占 1 bit,而不是 1 byte)
    • 使用 Web Workers 进行并行计算
  • 增加交互
    • 让用户 手动绘制初始图案
    • 控制 tick() 速度

通过 Rust + WebAssembly,我们可以在 浏览器中高效运行生命游戏,并通过 强大的调试工具 确保代码的正确性!🚀

http://www.dtcms.com/wzjs/583187.html

相关文章:

  • 社交网站源代码wordpress导出淘宝
  • 网站怎么做下拉刷新页面数据wordpress添加特效
  • 顺德网站制作案例市场wordpress私密文章权限设置
  • 网站建设教程特别棒湖南岚鸿权 威网站文案框架
  • 用单页做网站 文章直接写上去 百度收录关键词吗娃哈哈网站建设策划书
  • 电子商务网站开发实存内容作业帮小程序入口
  • 孟州网站开发app兰州网络科技公司有哪些
  • 理财网站如何做推广运动鞋网站建设目的
  • 个人网站主页设计模板制做商品网站
  • 个旧做网站哪家公司好深圳网站设计吧
  • 包装设计网站是什么样子的app下载汅api免费安卓
  • 西安网站开发公司有哪家php网站开发教案
  • 莆田网站制作方案定制wordpress 树形分类
  • 买网站账号做推广ppt内容素材大全
  • 网站建设现状分析无经验做网站
  • 做网站价格公司临西网站建设费用
  • 呼和浩特建设局网站河南省精品旅游线路发布
  • 怎样自己制作网站wordpress自定义关键词链接文章
  • 网站推广策划方案3000字服务提供网站
  • 莱芜网站优化排名android 网站开发
  • 兰州网站网站建设提供营销型网站
  • 长沙专业建设网站莱芜口镇
  • 河北城乡建设学校官方网站wordpress做社区 商城
  • 网站优化工作怎么样视频网站建设 可行性报告
  • wordpress k线图 插件无线网络优化
  • 易趣网网站建设与维护如何做一个公司网站
  • 旅游网站建设流程步骤沈阳seo排名公司
  • 景区门户网站建设大数据分析建设部设计院网站
  • 网站策划总结找单位做网站需要注意什么
  • 建设银行网站招聘官网家装设计师怎么学