前端百度一面:大厂有表现力的代码

前言

百度一面一般问的问题不会太难,但是我们要把问题答完整,答好,答到面试官的心窝窝里去是有点难度的。OK,现在给你一个情景,你能不能用代码把它描述出来。

情景描述

现在五一演出需要从动物王国中组成一支1000鸭子的合唱团,鸭子有一项技能是唱歌,请你用代码描述出来。

聪明机智的你是不是看到这里觉得这不很简单吗?看我三下五除二秒杀。相信在座的各位不久就能写出如下代码

javascript 复制代码
const choir =[]//合唱团
const duck={//鸭子
	name:'xx',
	sing:function(){//技能,唱歌
		console.log("嘎嘎嘎");
	}
}
for(let i =0;i<1000;i++){
     choir.push(duck);
 }

是不是感觉特别简单,觉得自己写的还不错,但是如果你这么写,那么可能面试官就让你回家等等了。

首先,没有封装的思想,这里我们应该把加入合唱团这个动作封装成一个方法,封装有助于降低复杂性、提高安全性和可维护性,并促进代码的重用。

scss 复制代码
function join(animal){
            choir.push(animal);
            console.log("恭喜加入");
        }
for(let i =0;i<1000;i++){
            join(duck);
        }

但是写出这样的代码还是有问题,是所有动物都能加入合唱团吗?显然不是,我们需要能嘎嘎叫的鸭子,而且我们似乎还没有作非空判断。完善一下如下

javascript 复制代码
function join(animal){
            //严谨性 加入合唱团的要求
            if(animal&&typeof animal.sing==="function"){
                choir.push(animal);
            }
            console.log("恭喜加入");
            }

这个时候我们需求变化一下,全世界只有999只鸭子,但是就是需要1000只能嘎嘎唱歌的鸭子,缺少的一只你应该怎么办?用代码描述并解决。

这个时候你能想到面试官想考你什么呢?其实这个时候我们就应该要想到JS的弱类型,这里我们可以让某一种动物去学嘎嘎叫这项技能,这样就能以假乱真,加入合唱团啦。

javascript 复制代码
const chicken ={
            name:'wm',
            sing:function(){
                console.log("gagaga");
            }
        }
join(chicken);

OK,这样我们就基本完成这道百度面试题啦。

总结

这道题主要考察了我们基本的情景编程能力和封装的思想,还考察了我们的编程习惯,是否会考虑代码的健壮性,JS的基本语言特性等等。

相关推荐
绝知此事10 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
放下华子我只抽RuiKe510 小时前
React 从入门到生产(四):自定义 Hook
前端·javascript·人工智能·深度学习·react.js·自然语言处理·前端框架
XinZong11 小时前
OpenClaw 实现双重心跳(Heartbeat)+ clawreach虾聊项目实现
javascript
kyriewen13 小时前
面试官让我查各部门工资最高的员工,我用AI三秒写出窗口函数,他愣了
后端·mysql·面试
还有多久拿退休金13 小时前
一张栈的图,治好你面试答不出 script 阻塞的病
前端·javascript
zithern_juejin13 小时前
原型与原型链
javascript
罗超驿13 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
做人求其滴14 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
小江的记录本14 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
ricardo197315 小时前
# Tree Shaking 深度解析:为什么你的代码没被摇掉?
前端·面试