实习日志(2)

2021.07.12 星期一

        新的星期开始,休息过两天之后,斗志满满。

        今天先接触了递归,但由于之前学过,所以就一带而过了,在有些计算的时候需要考虑最优良的算法,这会使计算速度大大提升。

        接着又学习了词法环境,变量就是特殊内部对象的属性,与当前正在执行的代码块有关,操作变量实际上是操作该对象的属性。

        闭包就是指内部函数都可以访问其所在外部函数中被声明的变量和参数。这个应该是要记住,以后面试可能会被问到。

        还有函数自定义的属性可以存储在函数中,它跟闭包不同的是,如果定义的实在最外层的变量中,那么外部就不能访问它,而如果由函数定义,那么可以访问。

        今天重点理解并学习一些函数的进阶内容,但有些还不是很能理解明白,比如装饰器模式和转发,等晚上或者明天早上还需要在理解一下。

        下面是今天写的一些demo。

https://plnkr.co/edit/SVJLFs6gPw0C3lQi?preview

2021.07.13 星期二

        今天早上一来,就先把装饰器模式认真得又看了一遍,大致就是函数调用装饰器,保存到缓存其中,在下一次有相同的去调用时,不需要花多时间去计算处理。

        函数绑定可以用来绑定对象方法的this,则可以把他们放到其他地方使用,也可以绑定参数。

        在继承中,每个对象都有默认的prototype,其中有一个属性constructor,它的值就是对应自己对象本身,可通过constructor创建一个新对象,和之前的对象具有相同的构造器。所有的函数,对象等等,这些实质也都是从对象继承过来的。

        下午我们领导跟我们实习生开了个会,主要相互熟悉一下对方,晚上跟我们进行了数据库方面的培训。

        以下是今天写的demo。https://plnkr.co/edit/5PnuO9YsIyzMLUfE?preview     

        其实每天写的大体都是我不怎么熟练的或者我觉得需要在巩固强化的或者我觉得重要的一些知识点,每天把这些弄明白进步一定会很大。

2021.07.14 星期三

        今天先继续学习了JavaScript里面的类,大体和java,C++里面的类似,写了几个demo,没有遇到什么问题,之后又学习了JavaScript里面的出错处理,它可以自定义Error,并且扩展error,等以后写项目的时候,可能根据需要一个自己的error,并形成一个层次结构。

        之后开始继续学习排序算法,之前学习这些排序算法只是稍微带一带而过,从今天开始,系统认真学习算法。快速排序算法就是在一组数组中,找一个基准数,然后其他的数和他进行比较,如果比他小的数就放在它的左边,大于或等于放在右边,等比较完成之后,继续对左边和右边进行类似排序,最后返回。

        在写快速排序的时候,看到别人写的这一句:var pivot = arr.splice(pivotIndex, 1)[0]。 最后这个【0】 不明白什么意思,又去回忆了一下splice函数 发现没有这个参数,之后我自己写的时候把这个去掉也可以运行。我猜测应该是设置pivot数组位置吧。

        在写另一种用双指针快速排序的时候,指针指的并不是值大小,而是指数组每个值的位置,这才一直没有弄明白。

        冒泡排序就是先遍历每一个数,之后将前一个数和后一个数进行比较,然后交换位置,遍历完成即是所得数组。

        选择排序就是先把第一个数当作最小值,然后循环比较,如果有比他小的,就把最小的放在第一位,第二小的放在第二位...

        插入排序就是取arr[i],将arr[i]和前一位比较,如果前一位大,则向前移动一位,再跟前一位比较,如果大,则也向前移一位,在前面一个如果不大于arr[i],则本次循环结束,进行下一个循环。

        今天系统得去看算法时,发现算法没有那么简单,之前知识大概看了看文字描述,真正写代码的时候,有的并不能写出来,说明还不是真正理解,还是要多看看教学等,明天一天要培训公司规章制度,计划晚上继续看JavaScript,快速排序算法,堆排序。

        下面是今天的写的demo。

https://plnkr.co/edit/b3K1zeVZrSriPMDA

2021.07.16 星期五

        昨天一天都在会议室里培训,培训完成之后就让我们考试了,结束之后回去也挺晚的了,所以自己就偷了个懒没看。今天先学习了JavaScript中的promise,当返回的是promise,才能对其.then

.catch等等,返回promise函数使用new Promise,但也可以用 async声明函数,用await替代.then

        之后接着学习了geneartor函数,它适用于可迭代对象,但好像用的并不多。

        之后又学习了归并排序算法,刚开始看归并的时候,不怎么明白,主要是归并那个递归那部分看的糊里糊涂的,然后自己通过调试,加上自己手写一步一步推算,明白是如何进行递归的:我觉得就是:取一个数组arr = [1,2,3,4,5,6] ,之后merge( merge( merge(1,2), 3 ), merge( merge(4,5), 6) )  (merge方法在下面写的demo中有)。

        归并算法其实就是将一组数组中间划分,然后左右两边在进行划分,划分到每一组数组只有一个数的时候,再进行合并:将左边数组的第一个数和右边第一个数比较,如果左边大于右边,则把右边的数压入到另一个数组里面,并将指向右边值的指针向右移一个,在进行比较,反之亦然。最后返回的数组是压入的数加上左边和右边没有比较的数。

        下面是今天写的demo。

https://plnkr.co/edit/MCsW69KG9OKRkL08

        还有剩余的几个基本的算法计划在下周学完,并及时巩固已经学习的,并且下周计划学习vue。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值