一个try...catch失误,我与19万美元年薪擦肩而过!

大家好,我是芝士,今天给大家一个因为try...catch 问题导致面试失败的经历。
以下是国外一个小伙分享的面试失败经历,总结的内容。

我参加了一次前端开发工程师的技术面试,岗位年薪大约为19万美元,不幸的是,我因为一个try...catch的面试问题错误而失败了。让我告诉你这个问题是什么,也许它也能帮助你。

在JavaScript中,try...catch结构通常被视为一种安全网,是代码块中意外错误的守护者。包括我自己在内的许多开发者,都在同步上下文中自信地使用它。然而,面试中的一个看似无害的问题打破了我的自满,揭示了我在理解上的一个盲点:try...catch只能捕获同步代码块中的错误。

面试中让我栽跟头的问题其实非常简单,但却极具欺骗性:

javascript 复制代码
try {
  setTimeout(() => {
    throw new Error('err');
  }, 200);
} catch (err) {
  console.log(err);
}

以及

javascript 复制代码
try {
  Promise.resolve().then(() => {
    throw new Error('err');
  });
} catch (err) {
  console.log(err);
}

我一头雾水,愣住了。这些片段怎么会有问题呢?毕竟,这不是编码中的常见模式吗?这清楚地提醒我们这句格言:熟悉滋生自满。

思考

面试后,怀着谦卑的心态,我深入研究了try...catch的细微差别。一次顿悟来势汹涌:由于其同步操作方式,try...catch无法有效处理异步错误。在JavaScript中,setTimeout是一个经典的异步函数,它将回调函数安排到事件队列中,使其与try...catch块的执行分离开来。

解决方案

要应对这种限制,我们必须在异步上下文中对错误处理进行范式转变。正确的方法是通过回调、Promise或现代的async/await语法直接将错误处理集成到异步操作中。

思考第一个代码片段的修正版本:

js 复制代码
new Promise((resolve, reject) => {
  setTimeout(() => {
    try {
      throw new Error('err');
    } catch (err) {
      reject(err);
    }
  }, 200); 
})
  .then(() => {
    // 处理成功执行的情况
  })
  .catch((err) => {
    console.log(err); // 错误在这里被捕获
  });

对于第二个片段:

js 复制代码
// 方法一:使用Promise链式调用
Promise.resolve()
  .then(() => {
    throw new Error('err');
  })
  .catch((err) => {
    console.log(err); // 错误在这里被捕获
  });

// 方法二:使用async/await
async function handleError() {
  try {
    await Promise.resolve().then(() => {
      throw new Error('err');
    });
  } catch (err) {
    console.log(err); // 错误在这里被捕获
  }
}

handleError();

这些修改后的实现,展示了在异步场景中处理错误的方法,利用了Promiseasync/await的内在能力。

从面试失败到觉醒, 发现在不断变化的软件开发领域中,持续学习和谦卑的重要性。拥抱JavaScript中错误处理的细微差别不仅丰富了我们的理解,还使我们能够编写更健壮、更具弹性的代码。

因此,各位开发者同仁,让我们不要回避面对自己的误区。因为正是在承认自己的弱点中,才能铺就了精通技术的道路。

欢迎关注公众号《前端界》,文章会同步更新,也可快速加入前端交流群!

readmedium.com/zh/i-failed...

相关推荐
玩电脑的辣条哥2 小时前
Python如何播放本地音乐并在web页面播放
开发语言·前端·python
ew452182 小时前
ElementUI表格表头自定义添加checkbox,点击选中样式不生效
前端·javascript·elementui
suibian52352 小时前
AI时代:前端开发的职业发展路径拓宽
前端·人工智能
画月的亮2 小时前
element-ui 使用过程中遇到的一些问题及解决方法
javascript·vue.js·ui
Moon.92 小时前
el-table的hasChildren不生效?子级没数据还显示箭头号?树形数据无法展开和收缩
前端·vue.js·html
m0_526119402 小时前
点击el-dialog弹框跳到其他页面浏览器的滚动条消失了多了 el-popup-parent--hidden
javascript·vue.js·elementui
垚垚 Securify 前沿站2 小时前
深入了解 AppScan 工具的使用:筑牢 Web 应用安全防线
运维·前端·网络·安全·web安全·系统安全
工业甲酰苯胺5 小时前
Vue3 基础概念与环境搭建
前端·javascript·vue.js
lyj1689975 小时前
el-tree选中数据重组成树
javascript·vue.js·elementui
mosquito_lover16 小时前
怎么把pyqt界面做的像web一样漂亮
前端·python·pyqt