Java最新程序员写PPT的小技巧,springaop实现原理面试题

最后

无论是哪家公司,都很重视基础,大厂更加重视技术的深度和广度,面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,是不是能真的得到锻炼。

针对以上面试技术点,我在这里也做一些分享,希望能更好的帮助到大家。

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

程序员的 PPT 小技巧

居然可以用 js 写 PPT

用powerpoint或者keynote写演示文稿,对于代码、数学公式等的支持一直是个痛点。而且对于前端同学来说,一身的css功力用不上也是个痛点。对于使用markdown来写文档的同学来说,将文档转成ppt需要重新排版也是件重复性的工作量。

于是我们需要一个基于web技术的ppt框架,reveal.js在这个领域成名已久了,而且上个月还有发布新版本,维护得还蛮好,第一步我们就选它了。

  将reveal.js运行起来

首先clone一份reveal.js最新的代码:

git clone https://github.com/hakimel/reveal.js

我们照抄一份index.html,比如叫做study.html:

<!doctype html> reveal.js

Slide 1

Slide 2

在reveal.js目录下运行npm install, 然后运行npm start就可以启动一个server来查看上面的ppt网页。默认使用8000端口,如果被占用了可以通过指定port参数换一个,比如我们换成30800吧:

npm start – --port=30800

然后通过访问浏览器的127.0.0.1:30800/study.html就可以看到我们的ppt啦:

  reveal.js step by step

上面这个网页其实挺容易懂的,不用react或vue框架,也不需要配置webpack。其核心内容部分其实非常简单,就是每一页演示文稿对应一个p。

Slide 1

Slide 2

  支持markdown

reveal.js的第一个强大功能是直接可以使用markdown来写演示文稿。在我们上面默认的html模板中已经加载了RevealMarkdown插件。所以我们要做的就是在下面的模板上写markdown就好。

我们来看个例子:

推荐系统的主要算法包括:- 矩阵分解- 线性模型- 树模型- 深度学习模型

生成的幻灯片如下:

  换个主题

如果觉得黑底白字的太丑了,我们可以换个主题。

主题就是个css,在这条语句里引用:

换成dist/theme/下面其它的css主题,或者干脆自己撸一个。

比如改成:

效果变成这样:

  支持数学公式

支持数学公式的js库和插件默认并没有包含在默认模板中,我们需要将其增加进来。

我们先把数学公式库的js引进来:

然后在初始化时Reveal.initialize增加对于数学公式的配置,并且引入cdn上的mathjax库:

Reveal.initialize({hash: true, math: { mathjax:“https://cdn.jsdelivr.net/gh/mathjax/mathjax@2.7.8/MathJax.js”, config: “TeX-AMS_HTML-full”, // pass other options into MathJax.Hub.Config() TeX: { Macros: { RR: “{\bf R}” } }, },

最后,在plugins中增加RevealMath插件:

plugins: [RevealMarkdown, RevealHighlight, RevealNotes, RevealMath], });

完整的代码如下:

plugins: [RevealMarkdown, RevealHighlight, RevealNotes, RevealMath], });

插件引入之后我们就可以在幻灯片中写公式了。

可以直接在p中写:

\[\begin{aligned} \ MAE(X,h)=\frac{1}{m} \sum_{i=1}^m|h(x^i)-y^{(i)}| \ \end{aligned} \]

也可以嵌入到markdown中:

$MAE(X,h)=\frac{1}{m} \sum_{i=1}^m|h(x^i)-y^{(i)}|$

出来的效果是这样的:

  代码高亮

代码高亮默认是支持的,我们可以在markdown里面用```来使用:

显示出来的效果如下:

也可以直接使用html的pre和code标签来显示:

                    model.compile({                optimizer: tf.train.sgd(0.000001),                loss: 'meanSquaredError'            });

return model.fitDataset(flattenedDataset, { epochs: 10, callbacks: { onEpochEnd: async (epoch, logs) => { console.log(epoch + ‘:’ + logs.loss); } } });

显示的效果如下:

总目录展示

该笔记共八个节点(由浅入深),分为三大模块。

高性能。 秒杀涉及大量的并发读和并发写,因此支持高并发访问这点非常关键。该笔记将从设计数据的动静分离方案、热点的发现与隔离、请求的削峰与分层过滤、服务端的极致优化这4个方面重点介绍。

一致性。 秒杀中商品减库存的实现方式同样关键。可想而知,有限数量的商品在同一时刻被很多倍的请求同时来减库存,减库存又分为“拍下减库存”“付款减库存”以及预扣等几种,在大并发更新的过程中都要保证数据的准确性,其难度可想而知。因此,将用一个节点来专门讲解如何设计秒杀减库存方案。

高可用。 虽然介绍了很多极致的优化思路,但现实中总难免出现一些我们考虑不到的情况,所以要保证系统的高可用和正确性,还要设计一个PlanB来兜底,以便在最坏情况发生时仍然能够从容应对。笔记的最后,将带你思考可以从哪些环节来设计兜底方案。


篇幅有限,无法一个模块一个模块详细的展示(这些要点都收集在了这份《高并发秒杀顶级教程》里),麻烦各位转发一下(可以帮助更多的人看到哟!)

由于内容太多,这里只截取部分的内容。

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

这些要点都收集在了这份《高并发秒杀顶级教程》里),麻烦各位转发一下(可以帮助更多的人看到哟!)

[外链图片转存中…(img-BA5GDotJ-1715440488480)]

[外链图片转存中…(img-TiGnoCYY-1715440488480)]

由于内容太多,这里只截取部分的内容。

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值