原文地址:https://geekplux.com/2020/01/06/2019-summary
2019 过的比 2018 年更快一些,不知道是因为经历的少了还是因为年纪大了,翻看年初的朋友圈真是言犹在耳。很多事情求而不得又阴差阳错,如果用一句常被人道的诗来形容我的 2019,那便是:柳暗花明又一村。
先从喜闻乐见的旅行说起。以前觉得漫无目的的旅行就是浪费时间,今年觉得只有漫无目的地走才能有偶遇的惊喜。经常是瞧到一处景,踱过一座桥,或伫足片刻,或按下快门,或呆坐一下午。总是时隔很久才发现,原来那个阳光明媚的下午竟然不经意间打卡了某个网红景点/餐厅。没有目的的感觉,真好。
2019 年的第一天,彼时我在春城昆明。当时和女友及好友一行四人在昆明呆了四天。石林吃马肉,滇池喂海鸥。云南美食的口味较重,略辣,在朋友的盛情款待下,吃了正宗的米线与两个印象最深的食物:大救驾和豆粉。
这次旅行我带了唯一的拍照设备 OSMO pocket ,大疆刚发布我就买了,小且轻,装兜里没感觉,开机迅速,可拿出来直接拍,优秀的防抖治愈了我年迈的双手。当时拍了很多海鸥吃食的慢动作视频,写到这的时候翻出来看了看,真回味无穷。自从有了 OSMO pocket,我的硬盘愈发吃紧,之后可能得配一台 NAS 才能存下这些视频格式的记忆碎片。
踏春之际,探访江西。印象最深的是婺源漫山遍野的油菜花中间点缀着一些徽派建筑。最后一天登了久仰大名的滕王阁,不大,上去之后可以俯瞰赣江源远流长,我想它的气场大概都是由《滕王阁序》支撑起来的罢。
![](https://geekpluxblog....
Continue to read]]>原文地址: https://geekplux.com/2021/01/05/2020-summary
往年的总结,总是很多可讲,今年的却不知从何下笔。2020年是不平静的一年,是跌宕起伏的一年。疫情就像一场浩劫,压缩了我的空间和时间,回头看年初的照片,好似还在昨天,回顾一年做了什么,却怎么也想不起来,好像没有活过,好像只过了一天。如果不是相册里的照片,和我琐碎的日记,我真的怀疑这一年缩水了。
前两天用 1SE 这个 APP,生成了一段我的 2020 review vlog,它自动把我每天拍的视频抽 1 秒出来,然后按日期再组合,竟还有点意思。我加了个配乐发布到了 B站 和 YouTube,有兴趣的同学可以前去观看。
2020 年,我的开局很美好。年初决定把家里人接到香港过年,想圆我自己带外婆旅游的梦想。外婆离不开轮椅,第一次坐飞机就是境外,可能有些兴奋也有些疲惫。我自然也是兴高采烈,带着他们逛了我工作的地方、中环、尖沙咀、铜锣湾等地方。因为外婆行动不便,母亲甚是疲累,也因为我对香港还不熟悉,所以就没有去太多的地方。在香港的那几日,新闻里已经开始报道内地疫情的爆发,我们当时出门都戴上了口罩。运气好的是,我 27 号刚从机场送走家里人,紧接着香港就开始陆续封关。
和内地的朋友们一样,年假结束后,我也开始了在家办公的日子。本来规律的上下班...
Continue to read]]>2023 是我既 2019 之后的又一次重启人生之旅。上一次是我单打独斗,这一次变成了拖家带口。疫情的后两年,我没有写年终总结,关注我已久的朋友可能会觉得断档了,但这也确实是如现实生活所演,地理空间的隔断让生活也变得局促。我到底是也没闲着,偷摸着当了人夫也作了人父,“时间就像一头野驴”,横冲直撞到我自己都不敢相信。
就先从隔离说起吧,我有幸作为最后一批入境隔离的同学,在隔离酒店度过了我 2022 年最后的几天。我至今也没想明白,在香港呆了三年都没阳过的我,是如何在入住隔离酒店三天内就喜提红码。幸亏娃的身体很棒,高烧只持续了一两天,没有让我们担心太久。本来龟腚:“必须同房间内所有人健康码转绿,才能结束隔离”,但幸运的是,在隔离期间遭遇大赦,于是隔离期满就被放出来了,好在没有影响之后的行程。
其实这次回去,是我的探亲访友之旅,我们的行程安排的很满,因为马上就要远渡重洋了,所以想在走之前把所有的亲朋好友都见一遍。我只请了一个月的假,几乎每周都要转场到另一个城市。从光怪陆离的香港职场,一下回到内地亲朋好友安排的大鱼大肉中,实在是乐不思蜀。第一次在山东过年,顿顿白酒也是让我领略了什么是好客山东。
亲情这个词,单拎出来讲显得矫情,但冠以三年的间隔就显得弥足珍贵。
假期结束我就马不停蹄回到了工作,猛赶了几天工作量就是为了把之后的时间都匀出来。因为这个月我们要收拾行李、搬家、很多 p...
Continue to read]]>帖子里说明了情况,小哥两年前被诊断出患有 Usher综合症,可能导致聋哑、眼部病变至完全失明等。他提出了几个真诚的问题:询问是否还能继续做前端程序员,有没有什么更适合视障人士的工种,有什么趁手的工具和哪些公司在招聘像他这样的程序员。
下面的评论中,很多人给出了建议和鼓励,我在此列举一下:
如果你去搜索“为什么记账”,大概会有无数条理由。大多数会提到:记录自己的开支、寻找可削减的开支等。但我认为记账的功效不止于此,它其实是量化自己的一步,也是自身财务管理的一步。如果你想要投资炒股,那记账更是你理解公司财报的重要一步。
如果说金融业的本质是合理资源配置(通俗来说就是“让钱去该去的地方”)的话,那记账就是自己财富资源配置的基础。
先简单说说我的记账史:我大三开始记账,一开始用一款叫 Toshl 的 APP,多端同步、界面大方(现在这家公司仍活的挺好,登录上还能看到我几年前的账单)。当时它没有自动同步功能,我靠纯手动记账坚持了大概一年半。直到我的信用卡多起来,可以自动同步信用卡账单的网易有钱进入我的视线,我在安全和便捷的博弈中倾向了便捷。靠网易有钱一直坚持记账了两年多。这期间不仅记余额、日常花销,还包括基金、股票的仓位等,让我对资产负债表慢慢有了概念。
到后来我遇到 Beancount,发现这才是适合我这种强迫症的终极大杀器。同时我也接触到了复式记账这种更科学的记账方式,对资产=负债+权益也有了充分的理解。
珠玉在前,关于什么是 beancount、什么是资产、为什么用 beancount 记账、为什么要采用复式记账等等,都在 Beancount複式記賬、Beancount —— 命令行复式簿记等文章中有详细介绍,我这里简单概括一下:
复式记账就是保证每笔账都要有至少两个(复数个)账户,且这些账户的和为零的记账方式。
简单举个例子:我们去便利店买了一瓶可乐,那么如果按普通的记账方式,账单上的记录...
Continue to read]]>原文地址:https://geekplux.com/2019/01/05/2018-summary
2018 年对我来说是平淡无奇的一年,没什么让自己满意的成绩,有种辜负了时光的感觉。以前的总结都是以人生阶段为单位的:
不曾想,学生生涯又结束了一次,以后打算以年为单位去总结,絮叨一下今是昨非。
整个 18 年,我以忙乱的搬家为始,又以慌乱的搬家为终。依稀记得 2017 年 12 月 31 号晚上我看着李亚鹏版的《笑傲江湖》跨年,一直颓废到第二天晚上,同学们都回家了,于是百无聊赖的我一个人出去吃了顿火锅,非常有仪式感地度过了元旦。2 号一大早我就出发,去云栖小镇开启找房看房之路。一天时间敲定租哪,又一天时间搬家,脚步匆忙,都没来得及和实验室的小伙伴道别就直接搬到了工作所在地,紧接着我就入职了阿里云。
要说拿到 offer 是在去年的秋招,当时我投了两家小公司的前端岗位练手,同时找师兄师姐内推了腾讯阿里和网易。没敢投国外大公司,主要是对自己英语和算法不自信。当时的想法也很简单,如果我进不了这三家公司,那我的研究生就是彻彻底底的败局。读研之前的工作对于当时的我来说已经算不错了,如果一直工作的话,三年的时间我相信我也可以跳槽进这些大厂。而我选择了另一条读研之路,如果连这些大厂都没进去,就更别妄图抹平其他沉没成本了。
说实话我很讨厌面试,参加过的所有面试都没有花特别多的时间去准备,一般都是去面试...
Continue to read]]>原文地址:https://geekplux.com/2019/04/02/advice-for-who-wanna-switch-to-programmer
最开始想写一篇《现在转行作程序员还来得及吗》,因为有不少朋友问我这个问题,但写着写着发现我一直在劝退,索性改了题目。
**本文针对的是那些想要转行找到工作的同学,而不是纯粹兴趣想学编程的同学*。
所以现在转行到底来不来得及?我觉得:来得及,但风险很大。有的朋友动力足,现在已经转行成功入职 BAT,有的半工半学,还在挣扎中;有的去了培训班,马上毕业了;有的问完继续走原路……但绝大部分都失败了。
转行做程序员的好处我相信你已经充分了解,要不然也不会有转行的想法,所以我就不赘述了,这里主要说几点风险(前方劝退,谨慎阅读)。
编程难么?说实话还是挺难的,这里我是针对大部分没有基础的人来说的,不排除有天才、大神能无师自通。很多人对编程的印象来自于电影,即使现实中有程序员朋友,你也很难 get 到他每天到底在电脑前干啥。为什么用键盘输入一句话,电脑就开始自动帮你干活了,这些你没有自己写代码之前,是没有体感的。隔行如隔山,就跟我读别的行业的文章跟天书一样,想转行,是需要付出很多的。
已经有水泥搅拌机了,你还需要学怎么用铁锹么?
没错,现在的编程门槛越来越低了:以前建个网站可能要 LAMP 一条龙,现在只需要拖拖拽拽一键生成;美国倡导全民编程,App Store 里也有很多少儿编程教学 App,按部就班就能开发属于自己的程序,一切看起来 so easy。但是,掌握越是容易的东西,你的竞争力就越低,大家都会的东西为什么还要给你高薪。“世之奇伟瑰怪非常之观,常在于险远,而人之所罕至焉“。
所以“学会”编程,和找到工...
Continue to read]]>绝大部分人说官方文档和范例是最好的教程,如果你英语好,且有 Java 和 XML 基础,那按照官方的Training一路下来就算入门了。
如果英语不好,可以看一些视频入门,如 Mars 的《Android 视频教程》的。最起码得先把开发平台搭建起来吧。再结合视频做一些小练习,最基础的布局先练好,不要急。
当然,看视频的话虽然通俗易懂,但是进度可能比较慢(即使我视频调至 2 倍速看),所以必须结合看书。但是,市面上的书大部分都跟不上 Android 最新的脚步。 不过还是推荐两本:
本文作者 GeekPlux,首发于前端外刊评论-Web 前端中的增强现实(AR)开发技术,博客地址:http://geekplux.com/2018/01/18/augmented-reality-development-tech-in-web-frontend 。注明作者和地址即可转载。
增强现实(以下简称 AR)浪潮正滚滚而来,Web 浏览器作为人们最唾手可得的人机交互终端,正在大力发展 AR 技术。很多 Web 前端工程师也在寻求职业转型,于是我把我近半年的相关调研结果在此汇结成文。本文力求把目前前端方向的 AR 技术都罗列一遍,细节不赘述(_保证文章篇幅不过长_),只做概括和科普(_因此文章中的链接很多_),零零散散写了一个多月(拖延症),欢迎已经在从事该领域或研究的道友前来纠正补充。
AR 可以简单的理解为一种实时将虚拟图像叠加在现实场景中的技术,且能交互[1]。我个人觉得 AR 比 VR 要有前景,主要因为:
AR 的优势在于把目之所及的现实场景变成了背景,并将现实世界和数字世界无缝连接。
当然这个“无缝”目前还谈不上,不过一直在进步。在谈 Web 前端如何做 AR 前,有必要先了解一下 AR 实现的 2 种主要方式和其关键技术:
AR 的主要实现方式有 2 种[2][3]:光学透视式 (Optical see-...
Continue to read]]>本系列「数据可视化基础」文章共三篇,介绍可视化中最基础、最重要的一些概念、理论。这篇为第二篇,主要介绍数据模型,另两篇则主讲可视化流程和视觉编码,建议从可视化流程看起。 原文地址:http://geekplux.com/2017/01/02/basics-of-data-visualization-data-model
数据说白了就是一组可定性或可量化的值。随着计算机存储能力的大幅提高,人们对于数据的关注与日俱增,「大数据」一词近几年来也被人们频频提及。而数据可视化的主要任务是将数据转换为易于感知的图形。因此,为了更准确更形象的表达数据,我们需要了解一些数据相关的概念。
为什么数据能代表我们的世界?要回答这个问题,我们得先了解数据和概念两个模型。
数据模型是一组数字或符号的组合,它包含数据的定义、类型等,可以进行各类数学操作等。概念模型描述的是事物的语义或状态行为等。
现实 => 概念 => 数据
现实世界可以用概念模型来描述,而概念模型又可以用数据模型来描述。经过两层抽象,数据便可以描述我们的现实生活中的方方面面。
一个东西具体归为哪一类,取决于我们用什么标准划分,数据亦然。
从数据在计算机中...
Continue to read]]>本系列「数据可视化基础」文章共三篇,介绍可视化中最基础、最重要的一些概念、理论。这篇为第一篇,主要介绍可视化流程,另两篇则主讲数据模型和视觉编码。 原文地址:http://geekplux.com/2017/01/01/basics-of-data-visualization-the-process-model
很多人认为数据可视化非常简单,无非是输入几组数据,生成简单的条形图、直线图等等。然而,这未免有点管中窥豹。其实数据可视化大致可分为信息可视化、科学可视化和可视化分析三大类,刚才提到的简单图表只是信息可视化中最常见的几种。一旦数据量增大,可视化目标改变,可视化系统的复杂度可能就会超出我们的想象。本文中涉及到的可视化流程模型适用于信息可视化和科学可视化。可视化分析的流程模型略有不同,本文暂时不进行讨论。
做任何事都有一个流程,可视化也不例外。
一图以蔽之。可...
Continue to read]]>本系列「数据可视化基础」文章共三篇,介绍可视化中最基础、最重要的一些概念、理论。这篇为第三篇,主要介绍视觉编码,另两篇则主讲可视化流程和数据模型,建议从可视化流程看起。 原文地址:http://geekplux.com/2017/01/03/basics-of-data-visualization-visual-encoding-principles
终于来到了最后一篇,前两篇的铺垫可能有点长,但是不种苗浇水怎能开枝散叶。可视化编码是可视化中的核心内容,本文会对其进行详细的讲解,尤其是视觉编码与视觉通道两个概念,如果其中遇到晦涩之处,不要心急,可囫囵吞枣直接往下看。
很多人可能看到题目的时候就有这个疑问,到底什么是视觉编码。其实视觉编码很简单,用一句话就能概括:
视觉编码描述的是将数据映射到最终可视化结果上的过程。
这里的可视化结果可能是图片,也可能是一张网页等等。
编码二字,如果说编是指设计、映射的过程,那么码呢?码其实指的是一些图形符号。
在介绍各类图形符号之前,我们先谈谈:图形能告诉我们什么。
![](https://gee...
Continue to read]]>写这个标题完全是我一时兴起,因为我今天突然想到一个问题: 程序员这个职业给我们最大的好处是什么 ?
我能想到的答案有很多。比如
以上等等。但最大的好处,莫过于让我们相信了 没有解决不了的问题 。如果说以上列举的几点给了程序猿们不断进步的武器,那这最后一点则是在程序猿心中撒了一颗种子,让他们逐渐强大。这点我和其他程序员交流过,大家都深有同感(但只有我不要脸的写出来了)。
在我图样图森破的时候,但凡遇到完全没有头绪的难题,我总会觉得这根本没什么解决方案。但是 Google 之后,或是请教高手之后,我又总会感叹原来 tm 这样也可以!为什么我没有想到?为什么在还没绞尽脑汁的时候就下了「无法解决」的定论?后来每当我再遇到这类情况,就不停的告诉自己是可以搞定的,即使我暂时还没什么进展,静下心来想一想总会有突破的。
可能是因为这种心理暗示起了作用,也有可能是 Bug 见多了,还有可能是深深折服于前人留下的知识瑰宝,总之我慢慢的觉得自己无所不能。再到后来 Boss 问我「这个功能能实现吗?」我总是回答能,感觉特别难的我会加一句「可能需要点时间」。
无所不能的心态慢慢从编程转移到了生活的方方面面。我刚开始把这种视为 盲目的自信, 有时候我都感觉自己变得可怕,竟然想做很多以前想都不敢想的事情。比如我练 Ukulele 时,无名指和中指特别不灵活,怎么也按不了 G 和弦。搁我以前,肯定早就放弃了,然而这次却坚持了下来,每天练十几分钟,也不求多。大概过了两个多月,突然就可以按到 G 了。
所以这种盲目的自信挺好的,他可以让我们迎难而上。做成一些事之后又反过来增强你的这种信心,最后形成一个正循环。而且就像上面我练琴的那个例子,它还让我学会了坚持到底。后来我每当想放弃一件事的时候,我...
Continue to read]]>域名,就是你网站的网址(标识和入口),比如我的是 geekplux.com。不是说没有这一串字母就不能访问你的网站,只是用 IP 访问的话,谁愿意记那一堆数字。相比之下,还是记字母简单。
免费的域名有很多,但是免费的顶级域名真不多。据我所知,.tk
是很不错的。如果你决定要长期写下去,也想让别人独一无二的网址访问你的博客,那还是买一个吧。
域名提供商很多,国内有万网等,国外有name、GoDaddy等。不过还是推荐你购买国外厂商的,因为国内要备案,提交各种材料等审核(_国外难道没有监管机制吗?呆在天朝就是安全_),我们只是为了有个博客,没必要这么兴师动众的。我用的是 GoDaddy 的,因为可以用支付宝支付。买的时候看个人喜好,我用的是.com
的,也有人追求个性用.me
、.us
等(不信可以搜 www.fuck.me )。不推荐.info
的,以这个结尾的大部分是垃圾网站,容易被搜索引擎屏蔽,我想宅男都懂。
在 GoDaddy 选好你的域名之后,一路点 continue,到支付页面选支付宝,价钱跟你域名的好坏有关了(BTW,我在支付前特地 Google 了一下 GoDaddy 有没有优惠,结果真搜到了 GoDaddy 的优惠码,6 折买的)。。。接下来要将你的域名和 IP 绑定起来,这里涉及到一个叫DNS的东西。
DNS 可以理解成一个专门破译密码的侦探,把你的域名解析成 IP 地址,所以只要把你刚买的域名在 DNS 里设置成指向你的 IP,别人就能通过域名访问你的网站了。DNS 具体的工作方式太复杂,我是小白,讲不清楚。
GoDaddy 默认提供了 DNS 服务,但是很不稳定,具体原因。。。这个。。。在...
Continue to read]]>生命在于折腾
当时我还是一个沉迷于如何把 QQ 空间打扮的更好看的人,不过偶尔也写几篇贻笑大方的文章。所以 QQ 空间是我的第一代博客,后来大学毕业决定告别社交网络,就把所有文章备份,然后把它彻底关闭了。
大约是大二,读到了一篇《为什么你应该(从现在开始就)写博客》,随即又准备起来,当时瞄准了一个工具 Farbox,是基于 Dropbox 的,只要把文章写好,托进 Dropbox 里,博客就自动更新了。它还提供了二级域名,这样其他人就能很方便的通过域名访问你的博客。
当时 dropbox 还没被封,是最好用的网盘,虽然上面的步骤看起来简单,但我还是折腾了很久,而且最大的收获是学会了 markdown,了解了什么是标记语言。随后我也写了两篇博客记录了一下:写博客就用 FarBox, 如何绑定独立域名,不知道现在 Farbox 还能不能这么用。
我慢慢觉得 Farbox 太小白了,不够 Geek,于是我又萌生折腾的想法。我先是 Google 了一大圈,然后去知乎提了个问题:[如何拥有一个完全免费的博客?](https://www.zhihu....
Continue to read]]>我的出发点是这样的:现在使用手机查看公众平台订阅内容的分为两种,一种WiFi党,一种流量党。而我的推送有时候一篇内容会夹杂着大量的图片,WiFi的当然无所谓,流量党的童鞋就苦了,可能为了看一篇文章要付出几M的流量。如果换成「文字+关键字回复」的模式就可以在推送时加上必要的说明,比如图多杀流量、篇幅较长、重口味慎入等等。
但是,用户反馈中大部分认为没有之前的体验好。有的说WiFi已经普及了,有的说文字模式他必须全部读完那一坨文字,他更喜欢图文模式的一目了然,还有的说我纯粹是多虑了(貌似确实-_-!)。。。但这会不会是反对的人更倾向于反馈感受,而喜欢的人可能就默默接受,觉得没必要反馈了。。。所以我觉得单单从今天的用户反馈来说是无法判断到底哪个模式好的,况且还有部分人说他就喜欢文字推送,清爽!
从我自己的角度看,图文模式整体美观,排版清晰,唯一的缺点是稍微费流量,当然还造成了像我这种有强迫症每条必点、不点不爽的痛苦。而文字模式虽简单直接,但排版不太好。用户惰性又相当高,很多用户不愿意去主动选择自己所需的内容,更倾向于被动接受。即使是愿意选择,也可能因为要多一个「回复」的操作步骤而错过了内容。
那么从整体上看,应该是图文模式能吸引更多的流量。互联网里掌握了流量就掌握了一切。。。好吧,一次简单的尝试果然会收获不同的领悟,得记录下来。
Continue to read]]>如果你装的是 VS2010,则打开 cocos2d-win32.vc2010.sln;如果你装的是 VS2012,则打开 cocos2d-win32.vc2012.sln,如上图红色框表示的。此时会自动打开 VS2012(或 VS2010),稍等片刻后你会看到 Cocos2d-x 自带的例子都已经自动加载到 VS 的工程目录下了。如下图:
原文地址:https://geekplux.com/2014/05/15/coffeescript_note
最近读了《CoffeeScript程序设计》的前半部分「核心 CoffeeScript」。对 CoffeeScript 也是有了初步的了解,本文只是我的随手笔记,并没有非常系统的总结 CoffeeScript 语法,想学习语法的同学可以看以下两份中文材料:
CoffeeScript 移除了所有的大括号和分号。
JS 会自动在行尾添加;
,但它又没有纯粹的设计为一款不需要加分号的语言,所以有时候会引起一些蛋疼的Bug。而 CoffeeScript 会在编译出的 JS 代码里每行都加;
,很方便。
CoffeeScript 和 Python、Ruby 一样,采用强制缩进(Coffee的很多地方与 ruby 类似),这种简洁,可读性又很强的代码,让人大爱。
JS 中的变量作用域一直让人诟病。
CoffeeScript 把编译生成的 JS 封装在一个匿名函数中:
(function(){
// 这里是编译生成的代码
}).call(this);
这样就巧妙避免了全局作用域的污染。同时,CoffeeScript 始终在编译生成的 JS ...
Continue to read]]>这份指南是社群驱动的,非常鼓励大家来贡献内容。
请注意这还是一份正在完善的指南:仍有很多地方可以改进,有些已制定的准则也不一定是社区惯用的(基于此,在适当的情况下,这些有待斟酌的准则将有可能被修改或删除。)
本指南中的很多细节受到了几份现有的风格指南和其他资源的启发。特别是:
原文地址:https://geekplux.com/2014/03/14/collapsing_margins
昨天在写 CSS 时遇到一个小问题,困扰了我好长时间,最后 Google 之,发现早有前人踩过此坑。为免以后再掉进坑,记下来比较好。
昨天遇到的问题是这样的。我设置了一对父子元素如下:
<div class="parent">Parent
<div class="children">Children
</div>
</div>
<div class="divider"></div>
它们的样式如下:
.parent {
margin-bottom: 10px;
width: 80px;
height: 20px;
background-color: yellow;
}
.children {
margin-bottom: 20px;
width: 80px;
height: 20px;
background-color: red;
}
.divider {
height: 1px;
background-color: black;
}
产生的效果如图所示:
![][1]
为什么分割线跑到了 Children 里面?这两个父子元素都设置了 margin-bottom
,加起来应该是 30px,为什么现在成了 20px?种种疑问在我脑中盘旋。刚开始以为是万恶的 position
,但是我把所有能想到的属性排列组合都设置了一遍,发现还是不行。果断 Google,才知道这个问题由来已久……
关于 collapsing-margin,有 [W3C 的官方介绍][2]:
Continue to read]]>In CSS, the adjoining m...
我第一次认识到自己色盲大概是小学体检的时候,医生用看怪物的眼神让我去辨认了一张又一张的色盲测试图。眼神从奇怪到嘲笑,从期待我说对到期待我说错,最后周围的人都在笑,包括老师和同学。我倒没在意这突如其来的恶意,因为我更在意为什么别人能看出图里的图案我却看不出来。后来回家求证之后,知道自己是遗传所得,也就释然了。我特意去查过色盲的定义,我的严重程度应该算是色盲,不是色弱。
但是各位,这并不代表我的世界不是彩色的……不要想象得太夸张。
其实在日常的生活中, 99% 的情况下我是不会意识到眼前的这个颜色是不对的,除非别人特意问我。我应该只是红绿色盲,蓝色系的我是非常敏感的。而且即使是红绿,饱和度够的话我也还是分得清的,不是说看到就是完全一个颜色……
我唯一有印象的能和别人体会到差异的,大概就是去景区的时候,别人感慨这个花的某某色真好看啊,我会反应一下,竟然不是粉色是紫色?平时买衣服是能分清的,如果模棱两可就去问问售货员,基本上差不太多,不会说把纯绿认成纯红。
红绿灯是完全分得清的,我看到大概是红灰灯(接近红白灯),因为那个红色我觉得很亮,绿色觉得很暗。炒股看 K 线图是真的分不清,完全看不出涨跌,但如果把背景色调成暗色,就立马分得清了……多谢开发者提供 Dark 模式或色盲模式,要不然也就告别投资了(挥手)……
每次被别人发现我认错了颜色,我都会被连续问很多次“这个是什么颜色”、“那个是什么颜色”,有的人是纯粹好奇,有的人明显的恶意。其实我何尝不知道对方是在期待我说错然后嘲笑我一番,但我心比较大,就配合配合,满足别人小小的心理,对我也无甚损失。
现在有很多矫正色盲的眼镜,只要带上之后,就可以看到正常人眼中的世界。我曾经带上过一副,发现……大同小异,说实话和我平时看到的也差不多……
应该是只有遇上类似“色盲测试图”中的情况才是真正的视觉紊乱的时候...
Continue to read]]>原文地址:https://geekplux.com/2015/07/04/communicating-between-views-in-backbone
掌握一个 MVC 框架,最关键的一节就是掌握如何在各个 View 之间通信。之前用 Angular 时,觉得基于事件的通信方式 ($on, $emit, $boardcast) 或者 基于 service 的方式都非常好用。转战 Backbone 之后,由于对 Backbone 的事件机制理解不够且使用非常灵活,一直没找到一个好的通信方式。直到看见这篇文章,作者通过一个简单的例子,层层深入,把 Backbone View 之间通信的三种方式讲的清晰明了。译文如下(已拿到授权):
我正在开发的这个网页主要有两部分,分别是 document 和 sidebar。
如上图所示,我设立了三个视图 (view) :
ApplicationView
- 作为最外层视图来包含下级视图
DocumentView
- 展示正在编辑或浏览的内容
SidebarView
- 展示一些和 document 相关的信息
DocumentView
和 SidebarView
作为 ApplicationView
的子视图,所以整体的视图结构如下图所示:
![Backbone View Structure](https://geekpluxblog.oss-cn-hongkong.aliyuncs.com/backbone/backbone-view-st...
Continue to read]]>要想创建一个 Cocos2d-x 项目就必须有它的模板,如果你使用过 Cocos2d-x2.1.4 以前的版本就知道其官方自带有模板安装文件,所以你可以下载 2.1.4 以前的版本(如 cocos2d-x 2.1.3),将 cocos2d-x 2.1.3\template 目录下的msvc
文件夹复制到 cocos2d-x 2.2.0\template 下,再复制 cocos2d-x 2.1.3 目录下的文件install-templates-msvc.bat
到 cocos2d-x 2.2.0 下,点击运行,结束后你就可以在 VS2012 的新建项目中发现有 Cocos2d-x 模板了。
但是新版的已经没有了,官方推荐用脚本新建项目。所以我们还是参照官方文档用最新的方法吧。一个脚本生成所有平台的项目文件,非常方便!
C:\Python27\
PYTHON_HOME
的系统变量,值为你 Python 的安装目录,如图:我自己开的是一辆 Model 3 Rear-Wheel Drive,这是最便宜的车型,我选择它的原因会在结尾提到,以下我先直接列一个表,其中 Model Y 的成本我是估算的。
成本类别 | Model 3 | Model Y |
---|---|---|
初始购车价格 | $38990 | $43990 |
税收激励 | 最高 $7500 | 最高 $7500 |
充电设备 | $200 | $200 |
充电成本 | $500/年 | $500/年 |
保险费用 | $3600/年 | $4000/年 |
维护成本 | $400/年 | $400/年 |
*更新:保险我是按我自己和朋友的实际支出算的,我俩都没太长驾龄,且在交通不好的州
接下来我逐一拆解:
表中所列的是当前车价,但 Tesla 的车价调整十分频繁,每个月都不一样(这里我悄悄吐槽一句,自从买了之后车价就一直跌,被马斯克背刺的好惨)。
我是全款购买的,如果是走车贷,那得再加上利息成本,现在美国车贷利率在 6% 以上(如果是信用分在 750 以下)。
其次除了车价,还得加上 Destination Fee,我理解这个就是运费,无论你在美国哪里购买,这个费用都是一样的,$1390。注册费(Registration Fee)不同的州价格不同,我所在的州是 $200,但是有些州高达 $500。
别忘了,美国还有消费税,这个也是每个州不同,我所在的州是 7.5%。表格中提到的税收激励是指联邦政府对购买新能源汽车的补贴,最高 $7500,但是这个补贴是有条件的,如果你的收入超过一定数额,就不符合条件了...各州也有所不同,case by case 吧。...
Continue to read]]>原文地址:https://geekplux.com/2014/02/20/css_written_principles
CSS 写的好可以让网页瞬间高大上,但是再高大上的网站如果效率很低也不行,尤其是在近几年「用户体验」这个词烂大街以后。前两天自己写了几个页面的 CSS,顺便拜读了很多关于 CSS 如何写的更好的文章,现在动手总结一下。
CSS 中我个人觉得权重是个很需要掌握的概念。它决定哪一条样式将被应用在元素上,哪一条样式将被覆盖掉。众所周知,CSS 选择器,最基本的有三种:
还有一种内联样式( inline-style ),是指直接在 HTML 代码中添加 CSS 样式。以上四种的权重顺序是:内联样式(1000) > id 选择器(100) > class 选择器(10) > 标签选择器(1)。括号内分别是它们的权重值!。举个栗子:
<span style="color : #fff;" id="example" class="demo">栗子</span>
#example {color: #000;}
.dome {color: red;}
span {color: blue;}
如果只有第四句来定义样式,则这个<span>
是蓝色的,如果加上第三条语句,则变成了红色,第四句被覆盖掉了。如果用第二句,则变为黑色,第三句即被覆盖,以此类推如果用内联样式则<span>
变成白色了。
像我这样的菜鸟刚开始滥用各类选择器,往往会出现想覆盖父元素样式的时候覆盖不了的情况,熟不知要想覆盖,必须让这条语句的权重值大于父元素(具体可以参考这篇文章[你应该知道的一些事情——CSS 权重](...
Continue to read]]>原文地址:https://geekplux.com/2017/06/27/d3-force-and-webgl-integration
D3 是目前最流行的数据可视化库,WebGL 是目前 Web 端最快的绘制技术。由于性能问题的局限,将两者结合的尝试越来越多(如),本文将尝试用 D3 的力导向图 和 Three.js 和 PixiJS 结合。全文阅读完大概 5 分钟,因为你重点应该看代码。
做数据可视化时,必然会考虑性能的问题。早前数据可视化都是用 Qt 等 GUI,后来逐渐迁移到了迅猛发展的浏览器上展示,Web 的性能问题成了大多数可视化的局限,尤其是在三维可视化,或数据量特别大的时候。现在主流的 Web 可视化技术为三种:SVG、Canvas 和 WebGL,难易程度和性能如下图:
SVG 的优点很多,编辑简单,交互便捷,灵活性极高,业内成熟的可视化工具(如 d3)都是用的 SVG。但是每个 SVG 都是一个 DOM 元素,随着它的数量上来之后,交互开始慢的难以忍受。这是因为每当修改一个 DOM 对象,只要这个对象在文档里,接着在浏览器里就会发生两个动作,一个叫 Reflow(重排,就是重新排版),另一个叫 Repaint(重绘,就是重新渲染页面)。这两个动作不一定都会...
Continue to read]]>其实现在手机相机如此发达,我们完全可以坐在桌前动动手指就完成这一系列操作。想起当年自己抱着毕业证、职业资格证等一堆重要文件一张张扫描就流下了没有技术的泪水。所以本文来教你如何告别扫描仪。
Google 出了一款神奇的 APP,叫 PhotoScan,iOS 和 Android 都有。打开 APP 对准你要扫描的照片或文件,会出现四个圆点和一个位于中心的空心圆,依次将空心圆对准四个圆点,即可完成扫描。大概 1 秒钟,扫描完的图片就会出现在你的手机相册里了。下面左图我扫描的示例,我太懒了,就不录制动图了,大家还是亲手实验一下吧,操作十分简单。右图是我扫描得到的图片效果,是不是很棒!
*补充:我发现微软也有自己的扫描 APP,也很好用,叫 OfficeLens *
现在 OCR 应用太多了(OCR:Optical Character Recognition,字面意思是光学字符识别,说人话就是把图片里的文字识别提取出来),其实底层算法差不多,就看哪个软件优化的好了。我试过的软件有白描、CamScanner等、但其实 iOS 自带的 Notes 就提供了扫描文本的功能,本着极简的原则,我把第三方应用都卸载了,用 Notes 完全满足了我的需求。
![](https://geekpluxblog.oss-cn-hongkong.aliyuncs.com/scan/222.png?...
Continue to read]]>人身上不知道为什么有这些奇怪的本能。还有一个最让我讨厌的本性就是“围城心理”。城里的人想出去,城外的人想进来。得不到的永远是最好的,得到了的又不珍惜。我虽然讨厌这个心理,但有时候还是老犯这个错误,江山易改,本性难移。我还慢慢的发现当人们犯这个错误的时候是不自知的,即使他内心也知道这是个错误。这时候就需要有朋友来点醒他,我很庆幸自己这样的朋友很多。
而且在我看来,就因为得不到,人就会强制喜欢上他得不到的。仿佛那是个没缺点的事物,然后盲目,虚荣,贪婪等等心理促使你不断的去追求它,等真正得到的那一天,你才发现这根本不是你当初想要的东西,差距太大了。
所以有时候反过来想想自己现在追求的东西,是不是因为双眼已经被蒙蔽了。。。人们并不知道自己现在是不是已经处于这个状态,以致于有时还得做自己厌恶的事。比如面对自己看不顺眼的人,非得使劲把自己伪装的让人家看顺眼,就算是敷衍也得敷衍的漂亮点,因为人家说灭你就直接灭了,貌似连灰都不剩。再比如跟自己不熟的人打交道,非要装作的很熟,貌似这样别人才能答应你可能本来就是合理的请求。有必要吗?心里觉得没必要,但是现实非要逼的你说有必要。中国社会是人情社会,人的力量比纸的力量大,爸的力量比法的力量大,我爸是李刚,你能拿法律惩罚我?搞笑!
当看完上一段,可能某些人又会对号入座,亲爱的,我真的不是说你,要不然你再仔细看看第一自然段?这...
Continue to read]]>原文地址:https://geekplux.com/2018/01/07/experience-of-gsoc-google-summer-of-code
Google Summer of Code (简称 GSoC)中文我叫它「谷歌编程夏令营」,是一年一度谷歌组织的类似暑期实习的编程活动。2018 年的申请马上就要开始了,在此我分享一下我参加 2017 年 GSoC 的体验。
这个问题可以参考Google 编程之夏(GSoC):海量优质项目,丰厚报酬,你竟然还不知道?这篇文章,里面介绍的非常详细,还客观的论述了为什么 GSoC 值得参加。不过在此我还是简单科普一下:
简言之,GSoC 是一年一度谷歌组织的、全球性的学生编程活动。学生利用暑假时间给开源社区贡献代码,谷歌支付报酬给学生。
将 GSoC 的特点提炼一下就是:
我相信这些点已经足够吸引一个在校学生了。
原文地址:https://geekplux.com/2014/08/02/farewell_social_network
我猜 QQ 空间最初应该是作为和新浪博客竞争才出现的,当时我还在初中,不会写什么 Blog,所以空间出来正迎合了我们这些学生的需求。随后「非主流」、「火星文」开始火,又是抓住了青春期学生的叛逆心理。不过我当时对非主流不是太感冒,一直很用心的经营着空间,犹记得当年幼稚的我还写了篇文章宣称空间是我的心灵归宿(正如现在矫情的我写这篇应该退出社交网络的文章)。所以从初中开始我的喜怒哀乐全在空间里,文章写了上百篇,照片更是几千张。
尽管后来开始沉迷微博、豆瓣、知乎等,空间一直是我割舍不下的一块,因为那里有旧友,有牵绊,这是一份长久以来捆绑着我的数据库。然而,随着认知的渐渐成熟,我越来越觉得人应该远离社交网络,不止是空间。理由也是在一次次和所谓羁绊的牵扯过程中感悟出来的:
刚开始我天真的以为社交网络是用来分享的,后来发现并不是。社交网络沦为了一个表演的舞台,每个人在上面表演,把想展示给别人的一面展示出来。发表一段状态,分享一篇文章或视频,并不是共享他的感受,也不是觉得这段信息真的有价值,而是在传递一种他自以为很重要的自我展示的信息,翻看朋友圈或其他的 timeline,随便找一条仔细分析一下就会发现他并不是在描述他的感受,而是在展现一些信息,或者直接说是炫耀。自从「逼格」一词横空出现,更是很好的定义了这种社交网站的分享行为其实就是为了彰显逼格。收到的评论,互相的交流根本无足轻重,因为这本身就不是输入,而是变相地输出。人们渐渐的带上了面具,因为社交网站上的你,并不是真正的你,而是你想让别人看到的你。
每个社交网络都有它的特点。微博烹饪着毫无营养的段子只供一乐;豆瓣是文艺青年的温床;空间:不转不是中国人……在很久很久以前,社交网络分享...
Continue to read]]>每走一个人,大家都感慨一个时代的终结。但不管是谁给我的震撼,都没有金庸先生这次这般得猛烈,毕竟整个童年和青春都是他。
论起是如何接触金庸小说和武侠世界的,首先要感谢 TVB,如果不是 TVB 在 90 年代一部部制作精良的金庸小说改编电视剧,可能我是不会知道金庸是谁的。后来直到高中,我拥有了人生中第一个 mp4,便从此一头扎进了金庸先生的书海里。惭愧的是,一直看的都是各种电子书的盗版,没有真正去实体店买过正版书。
一路看到大学,从早看到晚,废寝忘食。看一通宵的时候也是有的,即使是看过的片段,比如萧峰三兄弟少林寺大战,比如苗人凤和胡一刀大战……第二天早上的课也不去了,中午的饭让室友带回来,整天就把着手机,完全忘了时间。这种无忧无虑的生活过了大学之后就再没有了。
飞雪连天射白鹿笑书神侠倚碧鸳,我只看了 9 本,其中《天龙八部》和《笑傲江湖》看的是最多的,也是最喜欢的。《雪山飞狐》的结尾太突然,《射雕》又太伟光正,《神雕》我更喜欢古天乐塑造的形象,而不是书中太古灵精怪的样子。最喜欢的人物,是令狐冲,“一见尼姑,逢赌必输”,喜欢独孤九剑“行云流水,任意所至”,令狐冲的性格也最适合练此剑法了。
“什么狗屁规矩,一窍不通”
喜欢一个角色,大抵是因为找到了自己的一些影子,我喜欢这种肆意恩仇,不顾一切的感觉。我那时候年纪还小,却也总感慨人生在世,匆匆一瞥,不应该被各种教条规矩限定自己,想做什么就做。金庸先生的小说给了我很多人生的启示,里面很多句子,看一遍就记住了,不用细想,也不用强背。而后随着年龄的增长,虽然不身处书中仗剑执酒的江湖,却也在这社会中随波逐流,慢慢对书中人物的决断,性格,甚至说出的一些话有了更多的品味。我想金庸先生有的书我现在读起来还不畅快,估计就是因为我的阅历还不够吧,连他老人家自己随着年纪愈大也慢慢觉得书中情节有待斟酌。
我常和朋友说,读金庸以正三观。武侠带给我的太多:兄弟义气,江湖道义,红...
Continue to read]]>我自认为自己算是一个交友广泛的人,因为我一向保持开放。非黑即白在我的世界观里是不存在的,若要分析一件事或一个人,我总是会拆成独立的因素。我相信每个人都有自己对交友的理解,这篇文章,我想写写自己对友谊、对人、对友情岁月的认识。这无疑是个复杂的命题,但我想在未来某个时间节点,也许是十年后,回顾这篇文章时看到当时的自己。
首先,人是极其复杂的、是多元的、是发展的。其次,我只看于我有影响的部分。
我从不把人归类,也尽可能不靠标签识人。
小时候看电视总是天真地问父母主角到底是好人坏人,但现在已经不会再问这种幼稚的问题了,有单纯的好人吗?有纯粹的坏人吗?《我不是药神》中,程勇(徐峥饰)为了敛财走私仿制药,却救了很多病患,是好是坏?药企售卖高价特效药,但没有足够利润如何支撑它研发更多新药来攻克更多疾病?就连药贩子张长林,最后被捕也没把程勇供出,这又是好是坏?
人有多面,不同角度看过去可能是不同的样子。秦始皇焚书坑儒却也统一天下,隋炀帝劳民伤财却也开通运河。视角拉回现代,某教授学术精尖却猥亵学生,你不能否定他学术贡献,也不能肯定他私德有亏,他就是两者兼而有之的个体,不可能割裂取舍。“人是一切社会关系的总和”,我们不能离开具体的事件来分析人,也不能离开其社会关系来理解人。
另外,很多人无意之中喜欢用标签来识人,这个我也常犯,但事后常常会反思自己。一个四川人能吃辣,就是全部的四川人能吃辣吗?一个程序员木讷寡言,就全部程序员都是呆子吗?拿刚才的教授例子来说,你能说全国上下的教授都是这么猥琐吗?显然不能。**个体永远是独立于群体的,不能将一个群体的概率在单个人身上设为100%**。
*发生在我自己身上,比较极端但最让我印象深刻的例子:之前...
Continue to read]]>原文地址:https://geekplux.com/2014/02/02/goodbye_my_university
不知为何,现在写文章,第一句总想感叹一下时光流逝的速度,可能确实是年纪渐长……转眼已大四,伫立在象牙塔和江湖的十字路口,也是时候总结一下了。大学四年,不得不说是我成长最快的四年,也让我充分认识了上大学的必要性。第一次这么长时间跨度的总结,注定是篇长文。
环境对一个人的影响程度因人而异,但对我尤甚,因为我自制力太差。虽然当初我在走进校园大门的时已经做好了心理准备,但学校的堕落程度还是一次次刷新了我的底线。确实,在一个糟糕的环境里,合群 = 浪费时间。这并不是鼓励不合群,而是要学会择其善者而从之。在大一,加入学生会就是一个改变小环境的机会。在学生会两年的时间里,我认识了众多有想法的朋友。每个人都有值得我学习的地方,每次经历都让我懂得很多道理。在升为部长之后更是事事亲力亲为,希望以身作则(事必躬亲绝对是最渣的管理方式-_-||)。而当班长,也是希望能严于律己,推己及人。当时我还想和班里的每位同学都搞好关系,真是too young too simple。李开复曾说:
用胸怀接受不能改变的事,用勇气改变可以改变的事,用智慧分辨两者的不同
这句话,是我在大学前的暑假读到的,通俗易懂,着实是上好的鸡汤。听了导师的话,我大一大二没事就往图书馆跑,毕竟人丑就要多读书啊。一直到了大二末,我偶然得知学校有实验室这块宝地,于是心向往之。在ZW学姐(衷心感谢)的帮助下,我终于厚着脸皮混进了实验室。刚进去的两个月,绝对是我大学获取知识最密集的两个月;也是最孤独的两个月;还是最不浮躁的两个月。宿舍沦为了我睡觉的地方,翘课的频率呈指数增长,班里的同学也渐渐觉得我神出鬼没。这成了我大学生活的分水岭,后半段的大学我都是在实验室度过的。那段时间耳边总回响一句话「*如果不...
Continue to read]]>坐公交“环游城市”是很多人消遣解压的方式。我推荐的这几条似乎都经过西湖,西湖很大,如果慢慢地走,细细地游,估计得要三整天,但它真的太美了,我去了那么多次还是不能自拔。
7 路是西湖北面的一条公交线路,从杭州城站火车站一路到灵隐,你可以选择中途下车,也可以一直坐着,但我推荐还是下来走走吧,因为 7 路走的那条北山街非常的堵(游客多,热门路线)。
在钱塘门外站下车是风波亭,传说当年岳飞将军死的地方,葛岭站下车,往东走两步是蒋经国故居和著名的断桥,沿着断桥走是白堤,一直通到平湖秋月,再往前走是省博物馆、行宫和西泠印社,可以进去转转。
如果在 7 路的岳坟站下车,则往北是岳王庙,往东是曲院风荷和苏堤,往西是杨公堤。沿着苏堤(苏东坡当杭州市长的时候建造)一直走过去就是著名的雷峰塔了,听着很近,其实整个苏堤走下来估计有 2 公里。雷峰塔对面是南屏晚钟,我身为中老年歌曲爱好者,每次走过,心里都会响起:
南屏晚钟 随风飘送 它好象是敲呀敲在我心坎中 南屏晚钟 随风飘送 它好象是催呀催醒我相思梦
![](https://geekpluxblog.oss-cn-hongkong.aliyuncs.com/hangzhou/2.jpeg?x-oss-process=styl...
Continue to read]]>幸福是一种只能让我们不断追寻的东西,而却无法真正拥有。那些自称幸福的人,真的得到自己想要的了吗?而事实上得不到的才是我们想要的。
幸福不是拥有了最好的,而是美化了相对好的。每个人的境遇都相差无几,并不是上帝青睐那些有幸福感的人,一个老生常谈的例子:同样是半杯水,乐观的人会说:还有这么多。悲观的人说:只剩下这么点了。所以有幸福感的人所拥有的生活和你是一样的。而他们之所以有幸福感,只不过是进行了不切实际的自我安慰。
幸福不是一种客观事实,而是你内心的感受。那些幸福的人,或者说是善于自我安慰的人,仿佛能感到叶的无声,风的低吟,鸟的歌唱,甚至能从漫无边际的杂草中找到几朵绽开的小野花。但我们不妨掩卷沉思,这些美景的出现是不是因为他们的标准降低了。可能他本来想找的是一片山花烂漫,结果只有几朵。降低标准,自我安慰之后突然发现,几朵野花貌似更有诗意……好的,他感觉幸福了。这是真正的幸福吗?我不禁自问。我们来到世上就是为了不断的降低标准吗?就是为了长大之后嘲笑自己儿时想当科学家是多么的可笑吗?这就像佛陀告诉我们要忍,忍习惯了,我们就不会觉得痛苦。
幸福只是一种在我们一次次放弃梦想后再自我安慰的能力。
我们跌跌撞撞的一直走着,脚掌直接抵触大地的苍凉。生活在你无法接受它的时候还在继续。回忆并不是一种自信的表现,低着头托着腮,终于发现,生活要的就是一份淡然,带着面具嘻嘻哈哈,能心照不宣最好,即便流泪了,也可以谎称是迷了眼,但我可能永远不会选择沉默。时间抽打着我们,让我们更好地适应这个世界。说白了就是不断的降低标准,我们还美其名曰“成长”。成长成我们不喜欢的样子,然后回过头来问“原来的我还在吗?”
好久没写些什么,发发牢骚。
Continue to read]]>这么多卡,横跨很多家银行。每张卡的额度、年费、账单日、还款日、积分计算方法都是不一样的……稍有出错就是逾期或者被反撸年费……如履薄冰,很适合我这种强迫症晚期的人。
先来看看我的 iOS Calendar(微笑脸):
这些都是我自己手动设置的。每天早上 9 点,只要当天有账单日或还款日,我就会收到通知,有时候一下子收到两三条(微笑脸)。这里多说一句,理想的情况是每天一两条,即每天还一张卡。
尽管很多银行的 APP 有提醒,短信有提醒,邮件有提醒,公众号有提醒,但我还是再加了一道防火线,在以上这些东西全部失灵的时候,我 iOS 自带的 Calendar 还是会提醒我。接下来我会介绍如何结合 iOS 自带的 Reminder 使用。
因为每张卡的使用情况是并行的,卡少的时候还能用脑子算清楚,卡多就乱成一锅粥了。所以这时候就要祭出神器 Excel 了,利用 Excel 的函数,可以自动计算出哪天该还款,还多少,然后设置到 Reminder 里面,定好闹钟,这样等真正该还钱的时候,你手机就会狂震催你还钱……
收到闹钟通知的时候,立马打开还款的 APP 把欠款还掉,千万不要迟疑或稍等,因为有可能等一等就忘掉了,一旦错过还款日就是逾期。
Excel 的模版我分享到 Google Sheets 了,有意的自取: [template_of_creditcard_man...
Continue to read]]>说来惭愧,我学习编程的路径可谓艰辛,用了三四年才初窥门径。我不像很多程序员有天纵之才,也不像一些朋友很早就接触编程,无论是起步时间还是学习速度,我都落下很多,但这并不影响我最后掌握了这项技能。
所以这篇文章我想讲讲我——作为一个普通人——学习编程的经验,主要是三次“开窍”的心路历程。
在我的理解中,编程是一项技能,和骑车游泳无差。学会编程,只意味着能用代码把想法变成现实,不是掌握什么高深的算法,也不是入职什么大型公司。比如有的会计朋友,学了点 VBA 使自己在 Excel 中数据处理效率更高,我认为就算是学会编程了,再比如一些公众号作者学会用 AI 生成营销文,输入几个关键字就能自动生成一篇毫无营养但能卖钱的文章,也是算学会了。所以学不学会取决于你的目标,如果你是把将来从事程序员这个职业当作学会编程的目标,那么拿到任意技术 offer 就算学会了,不必妄自菲薄。
我是直到大二才懵懵懂懂开始学习编程,不像我的一些朋友,小学就接触编程。尽管我家里有电脑比较早,但一直都沉迷游戏。高中时用 PhotoShop 和一些视频剪辑软件居多,却从未想过编程,因为我完全没有编程这个概念。就像你想学一个东西,却不知道从何搜起一样。“编程”这个关键字,是没有存在于我的脑海之中的,这就是我常说的“我不知道我不知道”的那部分知识。
高三填报志愿时,所有志愿的专业那栏我写的都是“计算机科学与技术”,当时虽然看了很多专业介绍,但实际上我是完全不知道这个专业是去学什么,可见我当时眼界之窄。连周边的家长们都说,这个专业没前(钱)途,“去了就是玩游戏”!
万万没想到一语中的......我本科大学的宿舍刚建好,根本...
Continue to read]]>我认为远程工作提效可以分成两个方面,一个是与人合作,一个是自身效率。
远程工作不是单打独斗,仍是需要和人打交道的,而且沟通频率可能比在公司还高。以下四点是我在多次远程工作中得出的经验教训:
如何连接远程电脑、如何登录 VPN、如何使用各类软件等等都要了解清楚并做到熟练。把工作流程全部打通,减少自己的重复劳动,也节省每次沟通前的准备时间,还保证了即使 IT 同事不在的情况下也不至于被工具卡住项目进度。远程工作时大家在线时间不是固定的,所以指望临时求助同事是对彼此都不高效的方式。
把做完的、正在做的、接下来要做的都要及时更新给其他人。事事有响应,件件有着落,不仅要口头通知,最好是形成一个自己的工作文档,把实时的进度更新上去,让其他人一目了然,也是给自己一个计划和交代。远程工作不比在公司,虽然在公司也是各干各的事,但是只要想沟通是可以直接够得着的,而远程沟通成本太高,所以应该尽量减少沟通次数,提高单次沟通的效率。
没做完就是没做完,不要硬撑着说做完了,然后暗下决心晚上加班搞定。这很容易陷入恶性循环:要面子死扛 -> 带着心理负担加班 -> 状态不好又没做完 -> 要面子死扛。技术债务有时比赌债还可怕,一不小心就还不起了。而且这种“假性完成”还会严重影响同事和团队的进度,别人以为做完了,接下来的计划都建立在你做完的基础上,而实际没做完,等之后再推倒重来就难了,说不定给各位同事都造成影响。
所以大方地承认自己没做完更好,即使是因为偷懒划水没做完,也要直接坦白。其实远程工作大家的效率不一定都是满转的,所以遇到卡壳、做不完都太正常了,直接承认,说不定对方也说“我也摸鱼了...
Continue to read]]>本文首发于「掘金专栏」,地址:https://juejin.im/post/59701b61518825412f27a0b1 。 本文写在 markvis 发布后的一周,总结了在推广个人项目方面的一些经验。阅读时长 10 分钟。原文地址:https://geekplux.com/2017/07/20/how-to-get-hundreds-stars-on-github
每个程序员都幻想过自己的代码运行在千家万户的电脑上,但如何让你的项目获得更多的关注却少有人去思考。我们把注意力放在对代码的钻研、对技术的提升,却少有人关注如何吸引别人参与你的项目。一个人的力量总是有限的,尤其是在开源社区,越多的人参与就意味着你的项目有越多的可能性。
我的业余小项目 markvis(https://markvis.js.org ) 发布一天之后,在 GitHub 收获了 200 stars,爬上了 Trending 榜前十,现在一周过去已经近 1000 stars。虽然这不算什么大的成就,但让我不得不重新思考推广的意义。
一般人对推广都有或多或少的偏见,从我的个人经验来说大概来自两个方面:
一是受「酒香不怕巷子深」的影响,总认为只要是金子就会发光的。其实不然,道理很简单,你觉...
Continue to read]]>原文地址:https://geekplux.com/2019/07/31/how-to-get-jobs-pay-80-dollars-per-hour-1
最近在家赋闲,正好有一份远程工作找上门,几番沟通下来,对方给我开出了 80 美金的时薪,算是创下了我自己时薪的新高。不过我有自己的打算,所以拒绝了长期合作,只答应临时打打短工。有朋友问我怎么能找到这样的工作,我这里就分享一下。整体其实可以分成两个问题:
我来一一回答。
首先,远程工作通常有以下几种形式:
1 和 2 还是雇员,3 和 4 已经自己当老板了,考虑的应该不是时薪的问题了 😄。(还有除这 4 种以外的其他形式,可以之后再写文章介绍)。本文讨论的范围仅限 1 和 2。首先来说说找到这种工作的渠道吧。
如雷贯耳的如 Upwork、Freelancer 和 Toptal 等等。Upwork 是由早年大火的 Elance 和 odesk 合并而成的,提供了各类按小时或按项目结算的远程工作。Freelancer 上比较杂,有很多除 IT 类的工作,而且 pay 比较低。Toptal 据称是针对比较高端的自由职业者的,我没接触过,据说还不错。
虽然现在越来越多的人参与远程工作的竞争(尤其是印度同学),但万丈高楼平地起,经历过前期积累的痛苦后面就是坦途了。我...
Continue to read]]>原文地址:https://geekplux.com/2019/07/31/how-to-get-jobs-pay-80-dollars-per-hour-2
上一篇如何找到时薪80美元的远程工作(一)主要讲了如何找到一份远程工作,这篇为续。
这里讲一些小技巧,但打铁还需自身硬,所以关键还是得提升自己的知识水平。
大部分好的远程工作机会都在国外,所以英语要好,足够日常沟通和阅读书写文档的程度就够了。这可以保证你的视野不局限在国内,真正突破地域局限,实现全球收入。想象一下你赚着美元在泰国生活的样子,真正的赚着第一世界的钱在第三世界消费。已经有很多程序员在这么做了。
俗话说“物以稀为贵”,市场上越短缺且越火的方向往往是高薪的。根据 Upwork 技能指数,2019 年 Q1 最火的技能里,耳熟能详的技术有 Hadoop, Kubernetes, Vue.js 等。
所以想拿高薪可以往两个方向走:
单位时间内产出更多的人,肯定薪酬会更高。一个项目往往有不少竞争者,那么通过 interview 或者邮件沟通下来,对方发现你同样的时间可以做出印度同学两倍的工作,那他当然愿意多花一些钱雇佣你。
所以不断磨练自己的沟通效率和做事效率吧,关于如何提高之后可...
Continue to read]]>原文地址:https://geekplux.com/2019/10/06/how-to-implement-data-visualization
题目想了半天,最后定了这个,也不知道有没有准确表达我的意思。其实本文主要想分享我做数据可视化这么久之后积累的一些经验,重点在技术实现这个层面。
在已经确定要实现一个可视化视图之前,你一定已经经历了思考和设计,拿到了一张确定的设计图或者原型图,所以这里就不赘述可视化在实现前的那些步骤了,直奔如何编程实现的主题。
拿到一张设计图之后,和做前端切图差不多,你基本上要先做规划:
以下图为例:
![visualization design demo](https://geekpluxblog.oss-cn-hongko...
Continue to read]]>原文地址:https://geekplux.com/2018/08/28/how-to-implement-sankey-diagram
Google 搜索桑基图,可以搜到一大堆定义。简而言之,桑基图是一种数据流图,展示了数据是如何从左到右流向最后的节点,每条边代表一条数据流,宽度代表数据流的大小。桑基图常用于流量分析,可以很清楚的看出数据是如何渐渐分流的。本文着重讲解如何实现,理论方面的东西各位可以自行了解。
关键点有两个:
桑基图要展现的数据流,算是图(拓扑类、网络型或关系型)数据的一种。实现一个数据可视化图,最重要的就是拆解元素。而实现一个图数据可视化,则最重要的是分清“节点”和“边”。
拆解元素之后,最重要的便是坐标的计算,这里包括点和边的坐标。而图形中,任何的元素都可以看作是点连线而成,所以元素坐标的计算实际上就成了点坐标的计算。比如桑基图中,节点是一个矩形,那么只需计算两个点(左上和右下)的坐标(x0, y0),(x1, y1)
便可确定;边是一个带形,需要计算四个端点才能确定,带形的弧度则可由简单的三次贝塞尔曲线计算得来。
由此观之,实现桑基图的核心在于计算出以上的这些点坐标。其实实现任意一种可视化都是计算点的坐标。
当数据量到一定程度的时候, 桑基图中的边会出现重叠现象,造成一定的视觉混乱。如何减少可以阅读本文第二节。
经典的图数据结构一般是邻接矩阵和邻接表,...
Continue to read]]>原文地址:https://geekplux.com/2018/03/16/how-to-picking-uniform-points-in-irregular-polygon
给定一个不规则的多边形(可能是凹多边形,可能是凸多边形),在其中要显示拓扑网络数据,要求节点不重合、不超出边界。
取凸多边形的外接矩形,在矩形中随机撒点,如果落在凸多边形外,再次随机撒点,直至落在凸多边形内。 这个方法比较暴力,可以通过计算期望来控制撒点次数,撒点次数应该符合泊松分布。
可以看作方法一的改进。切成多个三角形之后,问题转化为了如何在多个三角形内撒点。
参考:https://beta.observablehq.com/@scarysize/finding-random-points-in-a-polygon 切割库:https://github.com/mapbox/earcut
三角形是凸多边形,如何在三角形内均匀撒点可参考:[http://mathw...
Continue to read]]>文章主要讲了为什么要搭建私有网盘,以及如何用 docker + ownCloud 搭建。原文地址:https://geekplux.com/2016/10/25/how-to-setup-a-personal-cloud
前两天,360 云盘宣布将停止个人服务。一石激起千层浪,关于如何选择网盘,如何应对网盘关闭的讨论一下子又变得此起彼伏。没办法,目前的现状是,网盘很难有大的盈利空间,还面对严苛的内容审查和隐私保护,虽然于用户来说提供了便利,但于公司来说实在是一件出力不讨好的事情。
国外的网盘我一直是三家一起用,分别是 Dropbox 存储代码和一些重要或私密文件;Google Drive 存储一些大文件和私密文件;OneDrive 存储一些电子书(同步太慢了)。国内的网盘我之前只用两家,一是坚果云,放一些个人常用的小文件,包括一些文档和软件配置文件;另一个是百毒云,放一些各处转存来的大文件、自己的照片和学习资料,一方面因其空间大,另一方面因其同步流畅。然而,百毒云前段时间把我的网盘全面封掉了,丢失了很多大学时的照片(其它文件要不不重要,要不有备份),申诉无果,实属无奈。
所以我决定搭建一个只属于自己的网盘。考察了几种方案(包括买 RAID 或 NAS 等),发现已有人在这方面做了努力,提供了像 Seafile 和 ownCloud 这样的产品。接下来对比了两个软件,我决定选择用 ownCloud,主要出于以下几点考虑:
Recently, I was refactoring my blog using Next.js by a whim. There are 3 tech stacks I would use:
However, There are so many restrictions in AMP for performance issues. At the beginning of the project, I found this issue, which means you can NOT add a global CSS as Next.js documented. So this article may be a guide for how to use tailwindcss with AMP in a Next.js project.
At the first level, individuals can read and fully comprehend information but are typically scoped within a single topic or area, which makes them struggle with both depth and breadth of understanding. And their memory retention is often short-lived, which is similar to a computer's memory, where information is rapidly read and consumed but not persisted for the long term. Although these individuals ...
Continue to read]]>Cloudflare's 1.1.1.1 is a DNS resolver that provides faster internet speed and enhanced privacy for users. Instead of using the default DNS provided by your internet service provider (ISP), which can often be slow and insecure, Cloudflare's 1.1.1.1 provides a more robust and private option. It...
Continue to read]]>原文地址:https://geekplux.com/2014/07/06/learn_shuangpin
转移到双拼阵营差不多三个星期了。现在打字真的是「飞一般的感觉」。
双拼是输入法的一种,绝大多数人都只听过全拼和五笔两种输入法。如果你不清楚你现在用的是什么输入法,那么基本上可以断定你用的是全拼。至于五笔,我们虽然如雷贯耳,但没有经过专门训练的话,实在是可望而不可及。双拼提供给我们一种折中的方案,使我们的学习成本和全拼一样,打字速度却和五笔一样。那么到底什么是双拼呢?维基百科这样解释:
双拼是汉语拼音输入法的一种编码方案。相对于全拼而言,使用双拼输入汉字时只需输入一个代表声母的字母,一个代表韵母的字母,就可以打出任意一个中文单字了。
大家都知道,我们伟大的汉字大部分都可以用一个声母加一个韵母拼出来(少部分只有韵母构成,如 奥 ao、而 er、偶 ou 等),所以用双拼输入一个汉字最多按两个字母键,而全拼可能要用两个以上。举例来说,用全拼输入「天真」,可能需要「tianzhen」这么多字母,而用双拼只需要「tmvf」,字数多了之后优势更加明显。
由此可见,双拼的原理十分简单,而它学起来更简单。众所周知五笔打字速度很快,但是你从开始学起到最后熟练使用,中间需要几个月的时间,黄花菜都凉了。而双拼从学起到驾轻就熟只需要三周,输入量大的人一周都能炉火纯青。一般的学习流程是这样的:
在以上步骤开始之前,我们需要选择一种双拼方案。双拼有很多种输入方案供你选择,你不用害怕,这些方案只是键位不同而已,并没有本质的区别。你可以参考知乎的回答[「各双拼输入方案之间有明显的优劣之分吗?」][1]。大家各有所爱,我自己用的是[小鹤双拼][2]。接下来你就可以记小鹤的键位了,我当时并没有真的刻意去背,...
Continue to read]]>原文地址:https://geekplux.com/2015/12/08/learning-by-index
学习方法的重要性不必多言,相信每个人都知道。然而,并不是掌握了好的学习方法,就可以让你事半功倍,而是要找到适合自己的学习方法。索引式的学习方法就很适合我。
索引式的学习方法是我自己起的名字,我不知道在别人那里叫什么。其要义是指在学习一项技能时,先不深究其细节,而是建立索引。这就像看书时先看目录一样,把目录多看几遍,对整本书的结构有所了解之后,再去看自己想看的章节。
循序渐进,步步为营的学习方法已经不适合现在的节奏了。这我在上次的文章《入门为什么这么难》里已经提到过:掌握一项技能要迅速掌握其主干,其余的细枝末节都不去管。
学习一项技能时,你不能保证你目前所在学的东西将来会用到。就算用到,也可能没有你现在所探究的这么深入。那么我们只需要知道有这个东西,在脑中建立这部分知识的索引,等用到他的时候再去查阅资料重新学习就好。
建立索引之后,其他部分的知识可以暂时地抛诸脑后,而把精力专注在当前的节点,「集中优势兵力迅速突破」。
表面上,因其不究细节,索引式的学习方法仿佛对知识的了解都浮于表面。但事实上,对于当前在学的、要用的它都力求扎实掌握,熟练运用。
不仅如此,因为索引式的学习方法强调用时才学,这就保证你现在要学的,肯定是你即将要用到的。学完之后马上运用,相当于二次学习。实践会加深对知识的理解,就像中学时做题是概念的补充一样。
如何建立索引?首先要了解怎么样才算真正的把索引建立成功。
建立成功索引的标准是你在遇到问题时能立马浮现出这是在运用哪一块的知识。比如需要抠图的时候,应该运用P...
Continue to read]]>原文地址:https://geekplux.com/2019/05/31/learning-without-hesitate
这个题目其实也是某个深夜自己睡不着时候瞎想的,因为我发现自己近一年学的新东西太少了,究其原因大概是我陷入了一种学习的通病,我把它叫作“舍本逐末”。
舍本逐末的学习是指明明费了好大力气,却好像什么也没学到的学习方法。学习是需要付出精力的,但舍本逐末学习法的精力都花在了准备、焦虑和犹豫上。具体有三个表现:
忽然想学一个东西,但是又怕自己付出了很多时间收益不大,仿佛连学习都有了“性价比”。事实上我们在学东西之前,总是容易高估自己愿意付出的努力,而由于人的惰性,我们很有可能就浅尝辄止了,或者学一半发现自己“不适合”,就及时“止损”了。
尽管如此,我们还是会纠结,不仅纠结学习与否,甚至纠结学习的顺序,毕竟自己“很忙”,没有时间兼顾,得先挑最重要的开始。
决定开始学习以后,又开始研究起了学习方法。
类似这种标题的文章最容易吸引眼球。表面上看这些文章总结了最佳的学习方式,让你能更快的掌握想学的知识,但实际让你事倍功半,甚至充满挫败感。一方面你觉得,别人只要花 10 分钟学会的东西,我为什么花了一星期。另一方面,阅读完这类文章让你有了一种你已经学会的错觉,实际上你还是什么也不会。最严重的是:看多了这类文章后,让你以为学习东西都不需要下苦的,冬练三九夏练三伏那都是死读书的把戏,你有更快更好的“捷径”。殊不知合抱之木,生于毫末,九层之台,起于垒土,人生在勤,不索何获?
舍...
Continue to read]]>Every programmer, I guess, would meet the code from others that you have never contributed to. And one of the ways to distinguish experienced programmers from beginners is to see if they can quickly dive into the legacy code and maintain, develop, and refactor it in the right way.
There is no silver bullet to approach it, I’ve also been caught in the nightmare of not being able to read the code at all. But I have some tips from my experience to guide you to master it step by step. Hope it would be helpful.
It’s very lucky if there is some detailed documentation, or if the person who wrote the code is still around. This can save you a lot of time, but of course the best way is that the previous team can help you walk through the whole codebase.
In this...
Continue to read]]>情似流水,行于当行,止于当止。而我,总是相反。
生物老师说当我们自以为被丘比特射中的时候,只不过是因为我们的大脑在分泌着多巴胺,在多巴胺的作用下,我们领略着爱的幸福,就如同吸毒或吸烟一样让人上瘾,欲罢不能,我们自以为在茫茫人海中,在经历了上辈子的五百次回眸之后我们终于遇到了对的人,其实这只不过是激素的力量。
这样说的确冷酷了一点。但是感性的我们一如既往的对爱情充满向往,哪怕那幻想的美丽泡沫被现实击碎多少次。当再次陷入恋爱之时,我们又会推翻之前的一切消极看法,认定这个人或许就是自己过尽千帆皆不是的那一个,命运终究安排我们相遇。呵呵,目光放远,万事皆悲。是啊,她的微笑,她的双眸,她的善良,她的一切与我都是那么匹配。接着,情不自己,甚至偏执的认为我们是命中注定,爱是永恒不灭。
情不知其所起,一往而深。一见钟情竟然在我一直坚定不移的相信下出现。我的生命也放佛因为有了对方才有了意义。偶然的相遇或邂逅,都被赋予了不同寻常的含义。既见君子,云胡不喜!人和人相遇的概率很简单可以算出来,她是那分子1,而分母的大小,你可想而知。虽然这概率小之又小,但是也验证了冥冥之中有一双神秘的手安排着这一切。如果把我们相遇相知相恋相隔的剧情串起来,发现,只要哪个环节差一点点,我们都不可能在一起。
爱情宿命论,无疑是一种幻觉和自我安慰。但是,我们的确遇到了一个可以让自己身心栖息的伴侣,寻求片刻的宁静或永恒。我不能想象我在她的生命中被人取代,反之亦然。我很自私。
错的时间遇到对的人……是不是对的人,根本无法判断。我一直相信,如果足够爱那个人,那个人就是the one。一段感情最终都是要分开的。只不过最好的情况是因为死亡才分开。如果你连这个都不懂,那么请不要用「生离死别」这个词。
那爱情的结果到底是什么?「不以结婚为目的的谈恋爱都是耍流氓」。各种碎片化的信息把我们渐渐洗脑。从微博上摘的只言片语,莫名戳中自己,立马向其靠拢。究其根本,这些短短的文字或许只是一厢情愿,我们应该摘掉虚伪的标签,按内心的来。
「不以恋爱为过程的结婚都是耍流氓...
Continue to read]]>体验了两天,MBP 的触控板真心好用,鼠标已被我打入冷宫。所以根据自己的习惯设置好触控板是第一步。我就改了两处:
![][1]
Finder—Preferences,把所有文件后缀名显示出来。(不显示出来木有安全感)
Mac 自带的词典非常好用,默认是三个手指轻触触控板就可以自动翻译选中的单词。而且,你可以通过以下的设置,如图:
![][2]
就可以按 Option + Esc 让 Mac 把你选中的单词读出来。
个人觉得最重要的就是这三个配置了,其它就是换了换快捷键和壁纸……当然我后来把语言换成了英文版(这后来引发了一个蛋疼的小问题,下一篇讲)。
只要你把 Mac 的快捷键记牢(参考这张图),就能飞速的使用它了,真的是飞速!
Mac 下安装软件直接把 app 文件拖到 「应用程序」文件夹下就 OK 了。卸载就直接从该文件夹下删除就行。简单的令人发指……
当初在 Win 下,我用的是 launchy 用来快速启动软件。Mac 下的 Alfred 就是此类软件的神器。在 App Store 里找到它并安装。从此启动软件再也不需要去 ...
Continue to read]]>其实这第二篇我前两天就写了一大半,我明明记得随手 Command+S 了,不过,我貌似把保存好的文件给删掉了……真是自作孽不可活,只能重新写一遍 T_T。
虽然身为一个菜鸟,但 Xcode 的大名早就如雷贯耳,毕竟是苹果亲生的,无论看起来还是用起来都非常迷人。第一次打开 App Store 就在很显著的位置看到了它,果断点了安装。结果发现有 2G 多,耐心等着下完(其实我特别想吐槽我这儿 50KB/s 的网速!)。
为什么 Xcode 必装?因为有编译的地方就有它。所以这里还要装一个 Command line tools,基本方法是打开 Xcode,找到 Preferences—Downloads—Components,在里面找到它并安装。如果你找不到,那可以在命令行输入:
xcode-select --install
这时会弹出一个选项框,问你是去下载 Xcode 还是直接安装,选择安装。
我以前并木有听过 Homebrew(毕竟第一次用 Mac),但我看几篇 Mac 教程都提到它,于是去下载来尝试一下。果然群众的眼光是雪亮的,自从用了 brew 感觉上五楼都不喘气了……有了它,可以方便的管理工具包,常用的命令有:
brew install xxx
brew uninstall xxx
brew list
brew update xxx
都是一句话,非常给力。不得不佩服 Ruby 社区的大神们,简直造福人类。
去 Homebrew 的官网是 bew.sh,找到它的安装代码:
ruby -e "$(curl -fsSL https://raw.github.com/Homebrew/homebrew/go/install)"
copy 到命令行,回车,搞定!
还有个东西叫 Homebrew-Cask,谁用谁知道。
其实目前主流的网赚方法,能被公开说的,过来过去就那么几种。我把他们分成了以下几类:
早期最广为人知的网赚,就是填调查问卷。很多平台,别人发布问卷你去填,每填一份,发布人付你一点钱,平台抽成。现在的任务则五花八门太多了,有上传照片的、写点评的、给机器学习打 label 的、听歌的、玩游戏的。是的,听一首歌和玩一会儿游戏,都有人付你钱(具体是哪些网站我就不赘述了,你可以问搜索引擎)。
很明显,这类任务型就是卖体力,多劳多得。而且任务型的薪水除了新兴平台一般都很少,所以很多人不去做了,但如果你善于规模化,那利润还是可观的。
东边日出西边雨,把东边伞拿到西边就能赚钱。搬运工型,就是把 A 平台的东西搬到 B 平台套利。
羊毛有很多种,最常见的还有信用卡积分等等。我认为它算是套利的一种,但因为利润较小,所以称为“羊毛”吧,如果利润大,估计叫羊腿了。
那薅羊毛值不值得呢,我其实很早就想清楚这个问题了。
很好理解,想要羊毛,就要花时间和脑力。脑力成本我觉得还好,因为研究规则或找到漏洞的过程还挺有意思的,我当它是一种思维锻炼。
但时间成本可就真的很贵了!你可以简单把你一个月的工资除 176 (22个工作日乘每日8小时)就知道你的时薪了。我之前有幸时薪达到过 80 美金,如果拿它来算的话,我每花 1 分钟在薅羊毛上,我就要花将近 10 块钱……成本有点高,所以大概只有很闲的时候我才去想薅羊毛这件事。
举个例子,比如上次在机场飞机延误,比较烦躁,一般这种时候我就开始研究我几张白金卡自带的飞机延误险。我花了大概 20 分钟分别阅读了它们的条款,发现有的卡要求必须是用本卡买票才能保险,有的卡不需要。紧接着我又发现我买机票刷的那张卡在延误 2 小时的情况下就可以返钱。所以我毫不犹豫把我的延误信息通过 APP 反馈给了客服,大约在半个月之后我收到了机票 80% 的钱,800 块,那么按我上一段的算法,我实际上花 30 分钟赚了 500 块。感觉你如果常飞北京可以办一张这样的卡,懂得都懂……
另一方面,我觉得薅羊毛最大的快感和好处,其实是发现规则的漏洞。我们这个世界充满了规则:学生手册、公司奖金制度、期权协议、保险条款、各式贷款、法律等等这些都是与我们利益极其相关的。利用学生手册,你可以知道如何在逃课与毕业证之间找到平衡;利用公司奖金制度,你可以知道如何表现能获得更多年终奖,利用……总之在合规的前提下你能在“规则”之中游刃有余,就可以在这些条条框框中追求自身利益的最大化。
薅羊毛正是锻炼了这个思维,越大的利益越值得你花时间去“薅”,挖空心思拔光头发,保...
Continue to read]]>起初是靠 @Frad 的启发,把 https://cal.com/geekplux 的链接发到了 Twitter 上,诚邀大家找我聊天。结果当天就有好多人约我,于是加了付费的选项,到后来又把免费的约聊改成了一周一次的频率,总算形成了一个有规律的模式。我的另一个朋友 @Randy 则是做了一个叫 AMA zing Talk 的网站,集中地展示了所有人的约聊页面。
约聊的流程其实很简单,cal.com 设计的很符合直觉,点开 https://cal.com/geekplux 就一定知道怎么操作。形式则就是视频聊天,大部分同学都和我用 zoom 畅聊。可能是因为疫情三年大家已经习惯了线上见面,所以大家都毫不拘谨。当然能有勇气直接找陌生人聊天的,应该也都不是拘谨之人。
在一次次的聊天中,我认识了不少朋友,大部分是程序员,其他则分别有创业者、学生、设计师等。大家的履历都各有千秋,聊天风格也非常迥异,所以我在最开始的一周也花了很长时间适应。后来习...
Continue to read]]>今天在 Goodreads 上闲逛,发现它竟然有 Import/Export 页面,无需写代码调 API,直接上传 CSV 文件即可,简直是懒人福音。我仔细阅读了它的导入规则,发现只要给之前爬好的每条记录加上 ISBN
就可以了,于是我就又写了个的小脚本,很快搞定了这件事。顺便说一句,写这代码时全程用 GitHub Copliot 一路提示加补全,我觉得它基本上都猜出我要干啥了,真是得顺应 AI 编程的大潮了。
上传的结果也很顺利,只有 10 本没有成功,但大多数是因为本身在豆瓣已经爬不到 ISBN 了。一些数据细节可能不完美,但可以慢慢完善。
最后附上 Goodreads 自带的 widget,可以在博客上展示自己的读书记录。
import Goodreads from '../../components/Goodreads'
按理来说,我一个不再少年的人已经经不起通宵对身形的摧残,但上周末却无意识地完成了这个壮举。第二天腰不酸腿不痛,继续狂写代码一整天。所以除却中间吃饭休息了两小时,我一口气编程大概 18 小时……这种战斗力,可能只有以前打 Dota 和赶进度才有。
一切的原因在于我最近想做一个小工具,因为它足够简单,所以我想用上最先进最难的技术,以便于我能最小成本的学习并应用到它们。其实这也算我一直以来学习技术的一种方式:有冲动做小玩意的时候,直接用自己不熟悉的技术去做,有点像把 100 米短跑变成了 110 米栏,冲动会逼着你突破舒适圈,跨越运用新技术最初的障碍栏。
通常这种新技术已经萦绕你耳边很久了,社区各种吹捧,朋友逢人就夸,GitHub上生态满天飞。耳濡目染让你手痒难耐,但它是否真如别人所说的性感,你还是得自己试一试。
我对待新技术的态度已经从当年的盲从变得谨慎,不是别人夸就好,而且就算它真的好,也得分场景。用扫地机器人去洗碗和用洗碗机去扫地,都是行不通的。而且学了就要用,如果平时都用不上的技术,了解即可,不必深究。除此之外,我通常还会让新版飞一会儿,等一两年出稳定版再学也不迟。现在前端技术百花齐放,很可能你学了一半就又有更强更新的技术出现了。
非颠覆概念的技术没必要花时间学。通常一个技术的学习难度是跟你自己的基本功和这项技术的革新程度有关。如果它没有出现颠覆原理或概念级别的创新,那就没必要单独分配时间去学,直接拿来用就可以,现学现用。如果你发现你学什么成本都很大,那你真正该做的是夯实你的基础。我举个例子,当年 React 出来的时候,是很明显会成为明星项目的技术,因为提出了 vitural DOM 和 if(state) = UI 等概念(当然这些概念在 GUI 领域也很久了,但在前端第一次大范围应用),那么学习它就很有必要,而且重点不是学习它的语法,而是去看看它的原理。原理搞懂,所有框架在你眼里都会雷同,只是语法不一样罢了。
最后我感慨一下我开头所说的连续...
Continue to read]]>Link on medium
Throughout the last three months, I was quite fortunate to work for [Freifunk][freifunk] on [netjsongraph.js][netjsongraph.js] under the guidance of my mentor Federico Capoano. Thanks for this invaluable experience that I learned a lot of knowledge and use them in a practical project. Here is a summary of the work I have done during the Google Summer of Code (GSoC) 2017.
[netjsongraph.js][netjsongraph.js] is a visualization library for NetJSON, a network topology...
Continue to read]]>原文地址:https://geekplux.com/2019/07/27/network-data-visualization
首先,图是最能描述世界的结构。几乎所有事物都能抽象成图。有一门学科叫作“复杂网络”是专门用图这种数据结构来研究世界规律的。图一直是炙手可热的研究方向,国内复杂网络的研究不仅热门,也颇有成就。在图分析领域,已经沉淀了很多分析方法、研究模式,我们光是把这些现成的算法筛选,进而应用到我们的业务中已经很有价值了,更别说我们可以根据我们的需求去拓展图分析的边界。
用户进入一个网站之后,不停的跳转,然后每个页面是一个节点,每次跳转是一条边。我能不能比较多个用户跳转图的相似性,先把他们分类,然后再比较他们的偏好不同。搞清楚用户到底是为什么点击到了这个产品,这个链路的特点是什么,等等。
既然图可视化需求这么多,我觉得应该把数据作为核心,数据和视图分离,抽象出一个单独的模块用来维护、处理、计算图数据结构。比如基本的节点查找、路径查找、最小生成树算法等等。
这个库的作用只用来计算,输出统一结构的图数据,我们甚至可以将图数据定义标准化,这样在其他图可视化或应用到图数据结构的场景中就能通用。
Continue to read]]>类似的轮子已经有了,我所用过最强大的是 [networkx](https://gi...
我个人觉得到一个陌生的地方,初期主要就五件事:
这是我多年辗转混迹多个城市积累的经验。其中最重要的是身份,但接下来我会按照准备的时间顺序来展开讲讲,因为有些事是可以在出境之前就准备的。
出去之后住哪肯定是可以最早谋划的。和香港租房买房全靠中介不同,我的体验是美国找房基本上全靠自己,有以下几个渠道:
我个人推荐 Zillow。Z...
Continue to read]]>接着前两篇 《操作系统总结——引论》,《操作系统总结——处理机管理》,至此操作系统最主要的两个功能就总结完了(也是我们期末考试的重点^.^)。剩下的其他功能就暂不总结了,还有一周考试,抓紧看《计算机网络》《计算机组成原理》《软件工程》(三门都是高学分)了。以上四门科目,是计算机科学中的基础,也是重点,但是都比较偏理论,怎么才能把理论和实践结合起来学习呢?我感觉这样学习会更有效果。
图片极其不清楚,相册里也有,下载下来看吧
Continue to read]]>图片极其不清楚,相册里也有,下载下来看吧,明天再总结“存储器管理”吧。
Continue to read]]>原文地址:https://geekplux.com/2019/12/17/passive-investing-stock-market-bubble-etf
声明:本文只是一家之言,不代表任何机构,亦不构成投资建议
定投指数基金等方式在最近两年被大肆吹捧,它的实际收益表现也确实跑赢了很多股票玩家。我自己本人是很赞同定投指数基金的,当年读完《聪明的投资者》之后,就觉得炒股不如买指数,而且我亲自实践,已经定投 1300 多天。
但本文妄从另一个层面谈一谈投资被动型指数基金的风险。论点已在标题中指出, 文章将分三部分论述:1是谁提出这个论点;2论据;3本文作者的观点,希望你看得下去。
我不知道你有没有看过影片《大空头》,该片改编...
Continue to read]]>原文地址:https://geekplux.com/2015/09/24/password-management
最近 Xcode Ghost 席卷三大平台,有预谋有组织有纪律。很多人看到这个消息纷纷修改常用密码,但我觉得密码管理其实功在平时,一个好的密码可以大幅提升你账户的安全系数。
而且,现在基本上每个网站都需要注册才能享用全部服务,我自己注册了上百个网站,意味着我有上百个账号密码需要记,用脑子记根本记不住(没办法,记忆力差)。后来我慢慢摸索出自己的一套策略用来管理密码,感觉实用且不算复杂。
那么密码设计出来,要存到哪里去呢?
生活节奏的加快让我们不得不想办法提升自己的效率。制定一个详尽的计划是大家普遍使用的一种方式。
早在初中的思想政治课上,我们就已经深刻的认识到制定计划的重要性了,比如:目标明确、科学安排时间、提升效率、磨练意志、养成良好的习惯等等……之前还看过褪墨上的一篇文章制定计划的好处,文章里说:
计划对于人生来说相当重要,如果你在计划上失败了,那你注定会在执行上失败。没有计划的人生杂乱无章,看似忙碌却是空缺的。
但是我认为有 更深刻 的原因促使我们去制定它。
不知道从哪一天起,电视剧中插播的广告旁边多了一行字“距广告结束还有xx秒“,这句话的出现让我对广告的时间有了一个大概的掌握,我可以切到其他台去浏览一下,或者是用这段时间去上个厕所、倒杯水。如果没有这行字,我一般会有两种感受:
这里的原因在于,没有那句话提示的话,我们无法判断这个等待什么时候才是尽头,如果有进度不断更新的提示,我们对整个过程的耗时感受会远低于实际值(相反,盲目的等待会让我们觉得时间更漫长),这样我们对完成的时间也就有了一个粗略的估计。
做事情也是同样的道理,善于计划的人,把要做的事情划分成一个个小目标(目标分级),再将目标划分成每段时间的 TO DO 列表(逐步完成)。比如网上流行的 GTD ,个人理解就是任务分割、任务提示,使你对目标的完成进度有一个估计。然而,在完成一件事情的时候,我们总会遇到很多困难,碰壁多次之后我们不得不选择放弃。**其...
Continue to read]]>原文地址:https://geekplux.com/2015/01/05/play-ukulele 知乎回答:https://www.zhihu.com/question/23935947/answer/909827986
每个人都幻想过自己拥有一身的艺术细菌,可以像各种钢琴王子一样在琴键上挥洒自如。但是由于某些不可抗力,从小到大一直没学什么乐器,或者是学了也没坚持下来。最尴尬的是选了一种鸡肋乐器,学有所成却不接地气,比如二胡(我真不是黑,因为我也学过那么两年),总不能在同学聚会激战正酣的时候拿出来即兴演奏吧……还是老老实实戴个圆框墨镜到地铁口来一曲二泉映月……
人生苦短,为了圆我们的音(zhuang)乐(bi)梦,Ukulele 可以说是应运而生。本文将从 what、why、how 三方面介绍如何快速玩转 Ukulele,争取把我在学习过程中遇到的坑都写出来供大家参考。
Ukulele 翻译为夏威夷吉他、四弦琴,音译为乌克丽丽、悠可力力、尤克里里、优可乐乐,简称 Uku、Uke……没错,这么多名字都是在说一个玩意。不要纠结到底中文叫那个名字合适,你直接用 Ukulele 一词以蔽之。
它是一种弦乐器,正常情况下长这样:
![正常的 Ukulele(图片来自网络)][1]
不正常情况下长这样:
![不正常的 Ukulele(图片来自网络)][2]
还有各种奇形怪状的,都非常可爱。从图上可以看出它整体和吉他非常类似,唯一的不同是少了两根弦,这就大大降低了学习成本!而且它音色清脆入耳,弹起来节奏活泼畅快,可以说是居家旅行必备之良品。如果对它的起源或背景感兴趣,可以去[百度百科-乌克丽丽][3]了解一下。
引用就是某一对象(变量)的一个别名。举个例子更容易理解:
int m;
int &n = m;
这段程序中,n
是m
的一个引用(reference),m
是被引用物(referent)。
n
相当于m
的别名(绰号),对n
的任何操作就是对m
的操作。
n
既不是m
的拷贝,也不是指向m
的指针,其实n
就是m
它自己。
指针用于指向对象(变量)。指针提供对其所指对象的间接访问。指针用于指向单个对象。
(这三句摘自《C++ Primer, Fourth Edition》)。再举个例子:
int m;
int *n = &m;
第二条语句定义了一个指向int
型的指针n
,并初始化n
使其指向int
型的变量m
。
*n
中的 *
操作符表明n
是一个指针变量(**n
本质上也是一个变量,只不过这个变量的存储内容是 地址)。
&m
中的 &
符号是取地址操作符**,当此操作符用于一个对象上时,返回的是该对象的存储地址。
这句话从内存分配的角度很好理解,程序会为指针变量分配内存区域,而引用不分配内存区域。
指针在逻辑上是独立的,它可以被改变,包括其所指向的地址的改变和其指向的地址中所存放的数据的改变。 引用在逻辑上不独立,具有依附性,所以引用必须在一开始就被初始化,而且引用一旦和某个对象绑定后就不能再改变(从一而终)。
即指针可...
Continue to read]]>如果是走深圳湾口岸,你会在过关之前就被随机分配到深圳的某个区隔离(我当时分配到了福田区,有朋友分配到了光明区,对比下来,光明区吃的给的多,福田区人文关怀比较多)。之后如果你体温正常就会送上大巴,座位随便坐,中间可能会换乘另一辆,但这具体看你被分配到哪个区。酒店也是随机分配,你在大巴上是全程不知道你要去哪的,到了酒店门口你下车才知道这就是你未来要呆14天的地方。
如果是坐飞机到上海或北京,应该是同样的流程。
下图为福田...
Continue to read]]>原文地址:https://geekplux.com/2019/03/18/schedule-algorithm-and-life
电脑就是人脑的复刻,这是我大学时学《操作系统》这门课时的感受。最近在复习调度算法,又重拾了这种感觉,他俩太像了,电脑就是模仿人脑的机制制造出来的,但现在我们可以反过来从它身上学习一些优秀的算法,反哺自身(可能早已遗忘的)做事方法。
调度,你就理解成安排吧,大家应该都懂,懂的同学,这一节就直接跳过吧。
我来举个常见的栗子——电梯。据说每个程序员坐电梯的时候都会想电梯调度算法,我也不例外……
最简单的调度方法是什么呢?当然是“谁先按的谁先坐”,这个在计算机里叫先来先服务(FCFS-First Come First Serve)算法,不管你是在几楼按的电梯,电梯都是按顺序去接人、送人。你可以想象一下,一个人在 1 楼按了去 20 楼,然后第 2 个人在 2 楼按了去 5 楼,第 3 个人在 21 楼按了要去 1 楼。这时候电梯它首先会跑去 1 楼把第 1 个人送到 20 楼,再跑去 2 楼把第 2 个人送到 5 楼,最后再跑去 21 楼把第 3 个人送到 1楼。
是不是很蠢?它明明可以在送完第 1 个人之后去 21 楼接上第 3 个人,把他送到 1 楼后再去 2 楼接第 2 个人,这一下子能省多少电费啊!😳
所以有了第二种调度算法:最短寻找楼层时间优先(SSTF-Shortest Seek Time First) 算法,用人话说就是优先停到最近的楼层。...
Continue to read]]>Before you start, you need to create an Umami database on PlanetScale. This will store your site's analytics data that Umami will collect.
The creation process may take a few moments. Upon completion, you will be able to see your new 'umami-db' listed on your PlanetScale dashboard.
![](/images/umami/planetscale.pn...
Continue to read]]>原文地址:https://geekplux.com/2014/04/25/several_core_concepts_of_css
本文将讲述 CSS 中最核心的几个概念,包括:盒模型、position、float等。这些是 CSS 的基础,也是最常用的几个属性,它们之间看似独立却又相辅相成。为了掌握它们,有必要写出来探讨一下,如有错误欢迎指正。
HTML 的元素可以分为两种:
两者的区别在于以下三点:
最常见块级元素应该是 <div>
吧,内联元素有 <span>
<a>
<img>
等等,完整的元素列表可以谷歌一下。
具体来说一下吧,
.example {
width: 100px;
height: 100px;
}
我们为 <div>
设置上面的样式,是有效果的,因为其是块级元素,而对 <span>
设置上面的样式是没用的。要想让 <span>
也可以改变宽高,可以通过设置 display: block;
来达到效果。当 display 的值设为 block 时,元素将以块级形式呈现;当 display 值设为 inline 时,元素将以内联形式呈现。
若既想让元素在行内显示,又能设置宽高,可以设置:
```css display: inline-...
Continue to read]]>原文地址:https://geekplux.com/2014/04/06/simple_guide_to_responsive_design
我们想让我们的网站通过响应用户的行为、设备的屏幕大小和屏幕方向,从而在所有设备上都能用。
截止2013年,有成千上万种不同的设备在浏览网页,所以我们不可能设计出适应所有屏幕大小的网页。相反,我们必须得采用一种更加流畅的方式去设计。
最近一个比较火的词叫移动优先。它的意思是,先为移动端设计样式,然后再根据需求去优化更大屏幕的样式。换句话说,假如你把移动端样式当成网站的默认样式,且以后不用去优化它,一步到位。那就更省事了!
“假定默认使用一个灵活但简单的布局,你的确可以适配各种浏览器,但这还不算是完全做到了响应式布局。所以当我们谈论「移动优先」,实际上是在说「渐进增强」。” —Ethan Marcotte
现在来介绍一种特别的布局方式。 通过 min-width 来界定不同屏幕该如何布局。它能就近检测出不同设备的屏幕大小(即 media queries,可直译为媒体查询),比在样式表末尾或一个单独文件中处理更简单。
```css /* Small screens (default) */ html { font-size: 100%; }
/* Medium screens (640px) */ @media (min-width: 40rem) { html { font-size: 112%; } }
/* Large screens (1024px) */ @media (min-width: 64rem) { html { font-size: 120%; } ...
Continue to read]]>本文首发于:GraphiCon 知乎专栏-文本数据可视化(上)——从 Wordle 谈起。原文地址:https://geekplux.com/2017/04/12/text-data-visualization-wordle
看到题目,你可能一脸懵逼,什么是 wordle?下面这幅图就是:
是不是很熟悉?大到宣传海报,小到个人名片,Wordle 如今随处可见。它可以轻松的展示出一段文字的关键词,让我们对这段话的内容一目了然。其实这属于数据可视化中的文本内容可视化,常用于社交网络中的内容分析,_还记得前几年微博有有个插件(现在似乎找不到了),用户可以一键生成自己的微博关键词,当时引起了大量转发,因为很多用户的关键词出乎意料,让自己都大吃一惊_。本文就从最简单的 Wordle 说起,说说文本内容可视化,以窥数据可视化一隅。
其实要回答这个问题就要回答为什么要做数据可视化。我们先看下面这段话:
GraphiCon 取 GraphicsCon 图形控之意(类比 lolicon)。 我们会把我们觉得有趣的,好玩的,有用的图形学相关的技术,知识,想法,资讯放到 GraphiCon 这个小空间里。 GraphiCon 的 po 主们虽然遍布天涯海角,在从事着不同的事,但都是痴迷计算机图形学的小伙伴们。 只要你也对计算机图形学感兴趣,或者喜欢好玩有趣狂拽酷炫的图形项目,那么你也是 GraphiCon!
一眼扫过去,你可能能轻松地注意到 GraphiCon 出现了 4 次。而还有个关键词「图形」,虽然出现了 5 次,但显然没有 GraphiCon 醒目。平...
Continue to read]]>本文首发于:GraphiCon 知乎专栏-文本数据可视化(下)——一图胜千言。原文地址:https://geekplux.com/2017/06/26/text-data-visualization
文字是传递信息最常用的载体。在当前这个信息爆炸的时代,人们接收信息的速度已经小于信息产生的速度,尤其是文本信息。当大段大段的文字摆在面前,已经很少有耐心去认真把它读完,经常是先找文中的图片来看。这一方面说明人们对图形的接受程度比枯燥的文字要高很多,另一方面说明人们急需一种更高效的信息接收方式,文本可视化正是解药良方。「一图胜千言」我们从小就有体会,教材里的解释图、自己笔记里总结的知识结构图,一直到现在经常用的思维导图等,其实都是简单、实用的文本可视化。本文将简单介绍文本可视化的基础概念,然后重点通过各类文本可视化的案例来阐述可视化之美(多图,不过为了学到知识这点流量不算什么)。
虽然一般这种讲必要性的段落很多人都略过不看,虽然文本可视化的必要性大家用脚趾头估计都能想到,但我还是稍微说一说吧。文本可视化的作用有以下四点:
简单来说就是让你更加直观迅速的获取、分析信息(所有可视化的作用都是这个)。举个例子,针对一篇文章,文本可视化能更快的告诉我们文章在讲什么;针对社交网络上的发言,文本可视化可以帮我们信息归类,情感分析;针对一个大新闻,文本可视化可以帮我们捋顺事情发展的脉络、每个人物的关系等等;针对一系列的文档,我们可以通过文本可视化来找到它们之间的联系等等。
一般来说,情报分析人员、网络内容分析人员、情感分析或文学研究者等相...
Continue to read]]>开门见山,目前我获取信息的渠道:
顺序按使用频率排序。其中除 Podcast、YouTube 和线下见面聊天外,其他四项在之前那篇均有提到。每项我会在下文中稍加阐述,并在最后分享出我 newsletter 和 RSS 的订阅列表。
邮件列表无疑是我当前获取信息最多的渠道,这一是因为我对邮箱使用的愈加频繁与熟练,二是得益于近几年 newsletter 的大爆发。我在前作中提到的那些 newsletter,大部分是链接推荐型,它们不是长篇大论的文章,而是一个个链接配上简短说明,所以我把它们当作别人已经帮我筛选过一遍的信息索引。但是在疫情之后,我订阅了大量杂志型和周报型的 newsletter。前者几乎每篇都是长篇大论,但精品率高,毕竟收费也高(微笑);后者则大部分都是流水账,每周发一篇自己这周做了什么,特别像周报。前者阅读起来费力,因为可能出自专业作者之手,语言水平略高,信息量较大,认真读完一篇都特别耗时;后者则读起来轻松愉快,有点像交了一个朋友,每周跟你 upd...
Continue to read]]>原文地址:https://geekplux.com/2018/06/01/the-summary-of-graduate-career
距离上次的总结,已经时隔两年,其实早就想花时间认真总结一下自己的研究生生涯。虽然断断续续写了很久,但一直没有一个身心皆静的时间来梳理。今天得空,坐在西湖边的长椅上,思绪纷飞,将其整理成文。时间跨度比较大,不免有些啰嗦,其中每一个小标题都能写篇小议论文了。
如果说高中奠定了我的兴趣,大学塑造了我的三观,那么我对研究生学习的 期待 是能让我找到一个 想深入且值得研究的方向,像一片肥沃的土壤能让我这颗小苗扎根于此。两年半的青年时光,是个很大的成本,比起那些没有工作就直接升入研究生的同学,我内心多了些许压力。所幸我没有太荒废,毕业之时细数躺在 wunderlist 里的几个小目标,也实现的七七八八,对于我这个善于自我满足的人来说已经很满意了。
我的研究生时光可以分为两个阶段,前半程在杭师大,浑浑噩噩,后半程在浙大,马不停蹄。
研一的一年,学校里是有课程的。工作过的我,对自己需要学什么非常明确,所以刚开始我觉得学校里的课程正好能加深我对软件工程的理解,蛮不错的。但看后来的实际情况,很多地方不尽如人意,甚至让人失望。这些情况我在入学之前都预想过,自己的选择也没必要后悔,但有时还是忍不住抱怨,退学的念头几乎是每周出现两三次。
无奈,毕竟是一所很一般的大学,我也不能强求什么。当初父母的建议历历在目,上司的劝导声声在耳,为了不让自己放弃工作而读研的决定显得愚蠢,我只好另找机会另辟蹊径。无论是本科还是硕士生涯,我要感谢这些当初劝我不要去的人,是你们的劝诫时刻警醒着我,让我不要就此沉沦。哈哈,开个玩笑,其实是我自己一直坚信一句话“没有绝对正确的选择,只有让选择变得正确” ,我觉得一定有一条出路既能抹平我内心的失望,又能让自己有所...
Continue to read]]>原文地址:https://geekplux.com/2017/01/14/the-ways-to-get-information
互联网迅猛的浪潮抹平了信息的鸿沟,却也让优质的信息变得如沧海一粟。人们常言「信息不对等」,往往在感慨有价值的信息总是被人捷足先登。正因这些信息如此重要,催生了一代又一代、各式各样的信息获取工具。
印象中,最早的信息聚合网站,应该是叫「黄页」,已经有 100 多年的历史,马云早期的创业项目就叫「中国黄页」。后来家里的 IE 首页变成了一些门户网站,这时候获取信息主要靠手动点击链接到各大网站。再之后,我接触到了 Google Reader,认识了 RSS,从此开启了一扇新的大门。
之前获取信息的方式是自己主动探索,而现在只需要维护好自己的 RSS 订阅列表,就会有感兴趣的信息源源不断地流进来。犹记得当时我的订阅列表很长,每天点开都是几百上千的未读,快速扫一遍,把感兴趣的随手添加到 pocket(因为 pocket 可以离线阅读),抽碎片时间打开 pocket 阅读,遇到好文章再收藏到 Evernote,这个阅读流一直沿用了一两年。即使后来 Google Reader 被 Google 遗弃我也坚持用 RSS,只是频率比以前低了不少。
再到后来,不少博客写手开始转战到了微信公众号,很多文章用微信直接阅读,体验也挺好,于是阅读公众号成了我当时新的阅读方式。然而好景不长,很快公众平台就被一堆营销号攻占,一些写手为了圈钱,写作质量也大幅下降。我开始慢慢取关公众号,并且意识到了一个问题:大多数的文章都是没有价值的,或者说远没有自己想象的有价值。很多文章都是东拼西凑来的,能引发思考的凤毛麟角。
别人的文章好似二手的知识,我们如果想获取...
Continue to read]]>就在刚刚,央视官媒宣布 1 月 8 日之后将取消海外入境隔离,也就意味着真正的通关了!看到很多游子额手称庆,我也不禁感慨:三年前谁也不曾想到回家之路竟如此艰辛。
我相信这三年对很多人来说都是身心煎熬。三年的时间仿佛压缩成了一瞬,原来人对时间的感知也会受到空间的影响。我是第一次深刻地理解了旅行的必要性,没有空间的变迁就无法刺激新的记忆产生,没有新的记忆也就没有“活过”的感觉。
身在香港,内地的生活我体验不到,但心情是辗转起伏多次。尽管我是一个极度乐观的悲观主义者,也挡不住每天的消极新闻。香港有个好处是中外新闻都可尽收眼底,内地的新闻自不必说,香港本地以及国外最开始的魔幻操作也是让人目不暇接。在疫情的第一年,可能整个人类都在面临无序与慌张,我们大概知道怎么面对,却不知道是否有效;我们大概知道会最终战胜,却不知道这个期限是多久。
随后进入的第二年,“仰卧起坐”式抗疫让夹在中间的香港历经波折,近在咫尺的深圳湾变成了人造的天堑。多次“即将通关”又“延缓通关”,多次期望又失望,一直到不抱希望,很多港漂到后来真的放宽限制之后还得确认好几遍到底是不是官方消息。直到 Omicron 的出现,直到各个国家开始逐步放开,我们仿佛看到了曙光。令人印象深刻的是 2021 年 10 月新加坡总理李显龙发表演讲称新加坡将从“清零”迈向共存,我当时听了两遍。
但谁也想不到第三年的剧本。香港在中外之间摇摆了两年后,终于在 2022 年 3 月迎来了大爆发。彼时的香港正如 11 月底的内地,天底下没有新鲜事。
当时香港日增几万,眼瞅着“动态清零”就要维持不下去,随即在专家权衡之后...
Continue to read]]>接外包的途径有很多,可以直接从外包平台去找,可以去论坛回帖发帖,可以有朋友牵线搭桥等等,通常最靠谱的是朋友介绍的项目。这里说的朋友,是指对你水平和技术栈都很熟悉的朋友,不是随便一个陌生人,也不是那种只知道你是程序员但是连写程序是干什么都不知道的人。
不管你是从什么渠道收到项目需求,但凡有一点犹豫,就不要接。一般收到一个需求,你肯定会自己先对其进行一个评估:
等等。作为乙方,这都需要时间去想。如果甲方需要快速答复,你可以给一个大致的回复,然后把你的顾虑都明说出来,也可以请求对方把顾虑说出来,开诚布公好做生意。评估的每个环节都很重要,如果其中有一环你心里觉得别扭,就真的不要接。你接了之后也做的不开心,本来外包就是一个苦力活,如果心情不顺,会越来越后悔自己接包的决定,最后完成度和质量就会难以保证。
我曾经因为某朋友介绍项目,项目其实不咋地,但碍于朋友面子我接下了这个包,然后就被他和不懂技术的甲方两个人坑的死死的。所以我之后再也不会“碍于情面”去做什么事,基本上丑话都说在前面,如果对方都接受,我再开始。
首先你要对自己的“身价”有一个评估。整个项目扔过来的时候,对方报价 50000,你要能判定出你做这个项目是否不止这个价。其次项目的价钱一定要在项目开始前谈拢,保证双方都满意的前提下再开始项目,而不是开发了一半了再扯皮。
这里有个小技巧是,先把这个项目按你一个人全权负责开发需要用的工时算出来,然后乘以你的时薪。我用下来,这个方法最靠谱。然后你还需要加上一些溢价,一方面避免幺蛾子的发生,另一方面对自己是一个督促和保证。*我曾因为自己报的价太低,而导...
Continue to read]]>原文地址:https://geekplux.com/2019/07/30/true-resume/
简历是求职的敲门砖,是进阶的垫脚石,其重要性不言而喻。这篇文章写一下我对简历的理解。
简历二字,可以理解成履历的简述。很多人运用漂亮的模版、既定的结构,试图勾勒出最好的自己。但真正的简历不是一张 A4 纸,也不是一份精美的 PDF,而是由表及里,渗透在网络上方方面面的你。
我参加过面试,也面试过别人,见过的简历大概分三种,除基本信息外:
综合看下来,前两种简历让我对求职者的了解仍是十分粗浅,只有第三种达到了敲门砖的目的。那么通常我会通过搜索或者约谈面试来进一步了解求职者。
刚才提到的简历我都称为通俗的简历,在当今的求职流程中是必不可少的。但真正的简历是棋在局外,双方还没落子,就应该知己知彼了。接下来我就写写具体如何打造:
说白了是建立自己的影响力。统一 ID,统一头像,给人留下一致的印象。
搭建属于自己的个人主页(或博客),让它作为你的大本营、你的信息索引,包括:
个人主页要精心维护,每个作品、每个项目的主页也都是你品味和能力的体现,如何排版、设...
Continue to read]]>岁月是把杀猪刀,把肉一片片割下来却轻的不让你察觉,当鲜血快要结痂的时候,又来一刀,让你血缓缓往出流却永远不停,「曾经」这个词估计也是为这把杀猪刀而作的吧。曾经笃信的不再相信,曾经坚持的也随风而去,不知道什么会是永恒。
以前相信爱情,现在爱情只是无聊之余的笑谈罢了,海很容易枯,石很容易烂,2012都快来了,山马上无棱,天地马上合,赶紧与君绝。
以前相信友情,现在旧人已失去联系,新人又匆匆走过。那种不需寒暄,开得起玩笑的朋友不知你身边还有几个。
以前相信历史,现在知道历史只是胜利者炫耀自己的工具。
以前相信正义,现在发现正义的背后往往隐藏着各种见不得人。
以前相信理想,现在理想只是用来推翻的。
以前相信爱国,现在都怀疑自己被洗脑洗成啥样了。
以前相信付出就会有回报,现在才知道这句话就是坑爹呢。
以前相信礼让一寸、得礼一尺,现在发现给脸不要脸的人都能环绕地球几圈了。
以前相信我为人人,人人为我,无私奉献才是好孩子,现在才知道你脑子有泡吧。
以前相信总有人俯首甘为孺子牛,现在才知道挤出来的都是三聚氰胺。
以前相信如何对待别人,别人就如何对待你,现在才知道地球已经不适合我了,我还是回火星吧。。。。
以上相信的,现在好像都是扯淡,相信与不信之间的深度,仿佛不是一个数字“二十”就能解释的。就用扯淡的态度面对惨淡的人生吧,这句话靠谱。
让我在二十岁的第一天愤青一段,也许青春已经不在了,管他呢,在或不在又有什么区别!
感谢生我养我的人,感谢记得我生日的每个人,感谢我自己活了下来。谢谢。。。
Continue to read]]>本打算常住酒店,因为来了之后我发现住酒店比租房还便宜,但由于办身份证和银行卡需要一个固定住址,所以无奈还是租了房。这边租房基本靠中介,我没纠结太久,因为房子不错就果断租了。空间和我在杭州住的差不多,窗户正对海,也算是过上了边洗澡边看海的生活。
看房的时候,中介说里面住了一家5口人,我当时有些震惊,进来看到上下铺顿觉人生不易。这边租房不带家具,所以床、桌子、衣柜、洗衣机等,我都一手操办,耗时半个多月才算安顿下来,不过我也不知疲,生活总要按部就班地来。
(楼下散步随拍)
香港公共交通发达,我坐叮叮车、公交和地铁都可以直达上班地点,无聊了我就天天换着坐……每天通勤时间大概15-25分钟,我觉得通勤是工作疲劳的催化剂,所以超过 30 分钟的通勤时间我是受不了的。
我现在是在金融公司做 Data Analyst,但实际上还是写代码,前后端+可视化,很惬意。尽管最近有一些 Big Day,但总体节奏还是很稳定,不会因为什么事而催你,也不加班。
之前觉得下班早,工作时间变短,那产出肯定不多,工期也会延长。但实际上正好相反,因为六点就要下班,所以我就好着急想多干一点,以防减少了我下班后的时间,这样反而更专注和高效。由于其他同事也是这种心态,所以大家沟通效率也很高,大概心理都想着:赶紧把这事搞定,省的你下班后发邮件打扰我。
— GeekPlux (@GeekPlux) Continue to read]]>
原文地址:https://geekplux.com/2016/02/15/two-years-after-graduated
在我们 5 岁的时候,过一年相当于经历人生的 1/5,而到了 25 岁的时候,过一年却相当于只经历了人生的 1/25。时间的重要性似乎随着我们年龄的增长而变得越来越低。主观感受上我们觉得时间走的越来越快了,而实际上却是我们对时空的认知变得扭曲了。
所以我们需要不断整理、回顾自己的人生,就像偶尔给自己留张自拍一样,说不定哪一天就忘记自己当时长什么样了。
距离我上次大学毕业总结(Goodbye,我的大学)已经过去了两年。都说 20-25 岁的年纪是人生最不怕折腾的年纪,如今我躺在床上,闭眼回想自己这过去的两年,满是任性。
本文和上次总结不同,将以时(liu)间(shui)线(zhang)的方式来叙述。两年的经历可以分为六个部分,其中五和六两个部分属于持续经历,七是一些胡思乱想。如果你觉得废话太多,可以只看黑体字部分或最后的总结。
这完全是一次没有计划,说走就走的求职之路,当时的我还没意识到「大学毕业后的第一份工作至关重要」这一点。
第一家公司我只呆了一个月。由于是靠朋友关系硬塞进去的,所以我在其中的一个月没有任务,也没有要求,扮演着一个无所事事的角色。天天看 PHP 手册的工作让我很没有成就感,加之公司氛围不怎么好,我很快决定另投简历。
人只有写简历的时候才会觉得自己有多么乏善可陈。虽然我在大学期间也实习过,但真正想找一份程序员的工作只能靠我仅有的毕设经验(一款 Android APP)。在收到的回应中,其中一个创业团队和我一见钟情。
在这过程中,我要感谢昊哥对我无微不至的照顾...
Continue to read]]>原文地址:https://geekplux.com/2014/03/21/understand_tdd
最近团队进驻了 Innospace(一个创业孵化基地),感觉一切要走上正轨的节奏。每周 Innospace 会提供一些来自业内大牛的创业和技术方面的培训指导,活动也非常多。感谢我的实习团队,让我有机会可以学到更多的东西。今天的主题是 TDD(测试驱动开发),对我来说这个东西不仅是新鲜的,还是陌生的,所以我也是认真记了记,顺便整理成文。
维基百科上是这样说的:测试驱动开发(Test-driven development)是极限编程中倡导的程序开发方法,以其倡导先写测试程序,然后编码实现其功能得名。
好吧,上面那段翻译的真是让人捉急,人家原文是这样的:
Test-driven development (TDD) is a software development process that relies on the repetition of a very short development cycle: first the developer writes an (initially failing) automated test case that defines a desired improvement or new function, then produces the minimum amount of code to pass that test, and finally refactors the new code to acceptable standards.
看完英文应该比较好理解。通俗点就是:先写测试,再写只能让测试通过的代码,然后不停的循环这两个步骤,直到重构出满足需求的代码。以每个测试来推动整个开发的进行,这样有助于编写简洁和高质量的代码,并加速开发过程。 ...
Continue to read]]>在 InfoVis 2016 上,UW 交互数据实验室 提出了一种新的交互数据可视化语法——Vega-Lite,获得了今年的 best paper,本文将根据其论文从多个角度介绍 Vega-Lite。论文地址。原文地址:https://geekplux.com/2016/11/02/vega-lite-a-grammar-of-interactive-graphics
简而言之,Vega-Lite 是一种数据可视化的高级语法,能够快速定义一些基本的交互式数据可视化。
如果你听说过 Vega,那么光看 Vega-Lite 的名字就不难想到它们的关系。Vega-Lite 就是编译成 Vega 的更高级图形语法。
如下图所示,只要右边寥寥数行代码,就能定义一个散点图:
首先,Vega-Lite 的目标是:
以前的东西做不到吗?其实也不是做不到,只是在有些方面还有很大的提升空间,Vega-Lite 就是在这个方向上很大的一步棋:
原文地址:https://geekplux.com/2015/06/06/vim-those-fit-yourself-are-the-best
Vim 被称为编辑器之神,是我用过之后才体会到的,用之前实在不敢对它做出什么评价。在大学时代,Vim 的大名就已如雷贯耳,但由于它陡峭的学习曲线,一直望而却步。等真正开始学习之后,发现并没有想象中的复杂,也没有所谓的瓶颈,只要在实际写代码中强迫自己使用就可以了,无形中就会形成习惯。最初的不适,换来的是效率的飞升。这和我当初学习双拼的感觉一样。下图是我的 Vim 界面:
我一开始也是看了很多教程,这里我就不说具体的学习方法了,因为 Google 上一搜一大堆。
我只想谈一点:很多「过来人」告诫新手,一开始使用 Vim 一定不能使用插件,要从最纯净的 Vim 开始练习。他们认为一上手就使用别人的配置,很容易被别人影响,不能领会到自己配置 Vim,这种从无到有的感觉。虽然我也很喜欢折腾的感觉,但这对于学习、入门一个工具来说有点南辕北辙,我们学习一个工具就是为了用好它,或者用它来为我们服务。为什么要我们去适应它呢?也许这不符合 Vim 的哲学,但是我觉得:
In this article, I'll briefly introduce the benefits of Webmention.io, explain how it works, and guide you through the step-by-step process of integrating it into your personal blog.
Webmention.io is built on the principles of the...
Continue to read]]>以前有人鼓吹微信群的价值超过公众号和朋友圈,因为其黏性更大,传达更直接等等,我承认它的这些特点,但不承认它的价值。
既然讨论这个命题,首先就得抛出这个「价值」的定义。我觉得一个社群有价值体现在能获取到想获取的东西(可以是知识、技能、经验、朋友、倾诉、发泄等)。这应该算是最基本的需求了吧,我相信就算是为了潜水、看别人聊天,也是符合这个定义的。
我被朋友拉进过不少微信群,自己也主动加过、建过。体验一番下来,除了人数极少的小众群之外,很少有群满足这个基本需求。其中有 90% 的群最后根本没人说话了,间歇性有人发发广告;10% 的群里只有少数几个人在聊,其他人一言不发。这和刚才提到的直接、黏性仿佛背道而驰。当然如果你是为了入群把所有人都加一遍好友,上面的话当我没说。
之所以微信群出现这种由「热恋期」到「平淡期」到最后「分手」的局面,我想大概是以下两大原因:
一个热闹的微信群,不一定人数是少量的,但最起码是彼此熟悉的,每个人没有嫌隙,能畅所欲言。而随着人数的增多,总会有一部分不熟悉的人。出于礼貌,你可能说话会彬彬有礼;出于自我保护,你可能不会表现出自己的真实观点。
所以聊天止于表面,没有深层次的交谈自然不会迸发出有趣的观点(深层次的言论容易引起争议,为了避免争论人们也会欲言又止)。聊天浮于表面自然就不会有什么有价值的讨论。
如果一个群没有明确的创建理由,入群的人可能会有种有力无处使的感觉,表面上其乐融融,其实都是自说自话。
而就算一个群有一个明确的聊天主题,可能也挡不住人数增加后的鱼龙混杂。说不定一两个人开始表情大战,其他人就会莫名加入。。。更别提红包雨这类微信特有的现象。
群里的人其实也很无奈,一部分人可能因为是好友拉进来的不太好意思退,另一部分人可能觉得说不定这个群将来会有用,只要把通知关掉就好。还有一部分人可能喜欢静静的看着你们装 X。
所以说不要...
Continue to read]]>本文首发于「GraphiCon图形控」公众号,微信号 GraphiCon,原文地址
今天在这里给大家分享一个 markdown-it 插件,能让你在markdown 中通过几行代码就生成一个可视化图表📊。
Markdown 现在被越来越多的人熟悉,它是一个标记语言,只要你在每句话之前加一些符号,编辑器就能自动排版。markdown-it 是一个 markdown 的解析器,易扩展,很多人给它写插件,比如有个插件是让它支持可爱的 emoji 表情。markvis 也是一个插件,通过两行代码就能生成条形图折线图等,如下图:
有时候写文章需要插入一些数据来增强说服力,但是单纯的数字又不直观,所以可视化图表是必须的。紧接着就会出现一个问题:如何把图表添加到文章中。通常的做法是用一些现成的工具生成图片,然后把图片贴到文章中。这样一来就非常繁琐,尤其是用markdown写作时你还得把图片先上传到一个图床中。另一方面,访客阅读文章时,图片的加载比网页元素肯定更耗时。一旦加载过慢就会给阅读造成非常不好的体验。
Markvis 相当于抓住了这个痛点,开发出了直接在 Markdown ...
Continue to read]]>本文摘自我的 2019 年终总结
在我离职阿里前跟上司沟通了很多次,有次他说:“人生 1/3 的时间都是工作,工作是生命中很重要的一部分,你不想工作,还想做什么”,没错,工作是真的很重要,我把它视为“正事”,但我对工作的认知有自己的一套准则。
如果看过我去年的总结就知道我在阿里的状态并不是很好。阿里是一家很棒的公司,给予员工的自由度、资源和对员工的培养方式都很好,但前提是你是一个会 leverage 这些的人。你不会利用这些,那阿里赋予你的优势也就毫无意义。我直到离职都没有找到一个合适的方式驱动自己,无论是每次和前辈们的聊天还是深夜中的自我反省,我都在思考我应该如何在这家公司更好地工作和成长,但长期的水土不服导致挫败感愈发严重,其实归根到底是我与公司理念的冲突。
在此我要先把范围缩小到我们所在的团队,因为在任何一家大公司,你不能单靠个人的言论去判断整体的公司环境。尤其在阿里,各团队各自为战,尽管从上至下有严谨的管理层级、尽管不同团队间互有合作,但说实话跨团队间的了解并不多,哪怕坐在同一楼层的同一排,你也可能对隔壁团队在干嘛知之甚少。通常的情况是财年初团队老板划一个大致方向,下面的所有人自发地策划今年该干什么,只要跟这个方向沾边即可。由于自由度很大、单兵作战能力又强,导致团队内部遍地开花,跨团队间又相互渗透,指不定哪天就互相蚕食。正是由于这样的做事方式,导致你的绩效,或者说你一年中产生的价值可大可小。假如老板划的方向和你的兴趣正好吻合,同时你也很擅长,那么你很容易想出一个点子为团队做贡献、为公司产价值。相反你则很难在其中倒腾出什么花样来。
我在阿里的时间里,心累远大于身累。之前有同事评价另一个很优秀的同事说:“这(某)件事交给咱们团队里任何一个人都能做,每个人都不差,但能做到这么漂亮的只有他了”...
Continue to read]]>原文地址:https://geekplux.com/2015/11/13/why-i-like-coding
我知道很大一部分的程序员,最初都是游戏爱好者。因为喜欢游戏,进而喜欢电脑,研究它,想知道怎么制作个游戏,怎么破解一个游戏等等。这部分因为喜欢一件事进而喜欢上鼓捣代码的人,算作一类。另一类就是我这种,一开始并不知道自己真正喜欢的是什么,甚至不知道什么是代码,但接触了编程之后,就停不下来的人。
虽然我在高考填志愿的时候,专业一栏都写的是「计算机科学与技术」,但我对这个专业的了解比对女性生理结构的了解还少。大一的课程终于接触到了真正的代码,我却没有因此产生浓厚的兴趣。而后来,当运行成功一个自己编写的程序时,那种头皮发麻,一股电流从背脊击穿头部的感觉,让我瞬间明白了这才是我该做一辈子的事。
编程之所以有趣,最主要的原因是它能即时反馈。你写下一行代码,立即就能知道它的对错;你写完一个程序,一运行就能知道成功与否;如果做的是界面,那就更明显了,代码一变,界面立马就变。
所以编程学起来也特别快,它能给你立马呈现出你这两个小时到底学到了什么。成就感的积攒,又会推动你进行下一步的学习,不停迭代。
人总是喜欢能更快得到回报的东西。
众所周知,程序员最讨厌八阿哥(Bug)。除非是当天任督二脉被打通,一般情况下程序员写出的代码都会有 Bug。有时候找 Bug 找的真的想撞墙,人都快崩溃了。我至今忘不了当初我上司,每次点击运行之后,大喊一声「决战吧,代码!」的样子。
但只要 Bug 一被解决,整个人都会「羽化而登仙」。。。被摧残过后的成果最令人兴奋。(不过我在这里友情提醒各位,如果你看到一个程序员眉头紧锁,千万不要去打扰他,不要问我为什么)
好的程序员「笔落惊风雨,诗成泣鬼神」,分分钟能做出一个优秀的网站、APP 或实用的小工具。虽然说要做出颠覆世界...
Continue to read]]>原文地址:https://geekplux.com/2015/10/27/why-those-who-write-great-articles-is-so-powerful
首先定义什么是好文章。我觉得 能让读者领悟自己想表达的 就叫好文章。换种说法就是 能达到自己写作目的 的文章就叫好文章。
每个人写作的目的不同,有的人抒情,有的人叙事,有的人论证,但这最终的目的都是为了 让读者理解 。即使你的目的是故弄玄虚(或者让别人猜不透自己),本质上也是让别人把你的文章解读成你想让他解读的样子。
所以,能写出好文章的人,具备两个重要的能力。
这两点看起来易如反掌,一般人也以为自己都做到了,但实际的情况是: 我说的和我脑子里想的不太一样,你理解的和我说的不太一样 。
要做到第一点,首先要对自己脑子中的想法有很好的把握,其次要对文字运用的很熟练。这样写出来的文章才结构清晰,逻辑通顺,言简意赅(说白了就是简单简单再简单)。文字的运用取决于多年来对语言的积累,对想法的把握则需要多了解自己的思维方式,锻炼思维能力……我相信你也知道,我们 9 年义务教育都在锻炼一种叫思维能力的东西。
要做到第二点,则要照顾到对方的理解能力。比如很多博士写出来的论文,读者根本看不懂,因为读者无法站在和他一样的高度去理解他的文章。继而导致他的文章不流行。而有一个人,他既能理解原作者的文章,又有很好的文字功底,把原文改写的通俗易懂再发出来。大家一看就懂,于是觉得这个人很厉害。其实很多所谓的畅销...
Continue to read]]>本文仅从作者个人感受上谈一下自己使用 Emacs 的理由和感受,通篇无干货。原文地址:https://geekplux.com/2016/12/03/why-use-emacs
Emacs 和 Vim 这两大编辑器,一直让前赴后继的工具党难以取舍。到底学哪一个?哪一个学了之后能如虎添翼?最初的我也是纠结了许久,仿佛本科时纠结到底该主学 C++ 还是主学 Java 一样。而事实上正如前辈们说的:不要纠结学哪个,反正迟早都要学。
从我个人的角度讲,我认为学习和使用 Emacs 有以下几个好处:
搜索过 Emacs 的人对前两点应该都有所耳闻,但百闻不如一见,真正使用之后才知道 Emacs 多强大。就我个人来说,除了将 Emacs 作为多种编程语言的编辑器,还用来管理自己的学习笔记、To-Do List。社区里很多道友还用它来记账、管理文献、写论文等等(*大家都用 Emacs 做什么?)。如果你对 Emacs 没兴趣,那么至少应该了解一下 Org-Mode,由于 Org-Mode 的强大,有人甚至用它来管理自己的一生(类似[《奇特的一生》](https://union-click.jd.com/jdc?e=&p=AyIGZRtSFQASAVIfXxIyFQJRElsQBRsFURprUV1KWQorAlBHU0VeBUVNR0ZbSkdETlcNVQtHRVNSUVNLXANBRA1XB14DS10c...
Continue to read]]>第一张图,是梦开始的地方。2013,还没毕业,那是我第一次去上海,也是买到人生第一台 MacBook Pro,刚开始学习前端,读的第一本书是《JavaScript DOM 编程艺术》。我很清晰地记得这张照片拍摄于我拿到 Macbook 的当天,几个实习生在这家创业公司的小房间里打工,开箱的时候我印象特别深刻,旁边来自台湾的运营实习生一直说:“恭喜你啊,zei台肯定不会是你最后一台麦布,你一定会拿它写出超棒的软体,然后到赚好多好多台”。不得不说那时候的 MacBook 质量真好,这台电脑我一直用到 2021 年都不卡,直到不小心进水烧坏了主板才报废。另外,光明的这个风味发酵乳真好喝,那时候学着同事一天喝一大桶。
第二张照片应该是 15 年,那是我第一次去办公室上班,也是第一次有外接显示器。开始使用 Vim,代码写的是 Backbone...真是恍如隔世。尽管时隔两年,但办公楼仍在南京西路,所以上海我最熟的就是南京西路到吴江路这片了。
接下来去读研了,还是 15 年,第一张图是在实验室的工位,很简陋,键盘用的是某宝上 300 块买的不知名青轴。第二张图是当时在宿舍,每天其实更喜欢呆在宿舍里,一个人静悄悄地写代码,这时候主力编辑器刚换成 Spa...
Continue to read]]>FarBox 可以理解为一个简单的博客搭建程序。一般我们搭建一个博客基本上要经历以下三个主要步骤:
说着简单,做起来对于没有基础的人来说还是有点困难。而现在 FarBox 给你提供了一个非常简单的解决方案,你只需要:
具体怎么配置,很简单,请自行 Google。配置好后,Dropbox 仿佛成了你的虚拟主机,只需把写好的文章或照片同步进 Dropbox 就可以在你的博客显示了。如果你有独立域名,还可以进行绑定(如何绑定独立域名)。
爱美之心人皆有之,怎么说也得让自己的小窝卖相好点。这个简直不用担心。首先 FarBox 给你提供了简洁的默认模板。不满意?那就看看别人的博客,看到下面有Clone Template
或者Clone Theme
等等,就说么你可以克隆他的模板,克隆完后你的博客和他一模一样,只需要设置一些自己的资料就 OK 了。只要是托管于 FarBox 的博客你都可以克隆(仅限于使用,源码不可修改...
原文地址:https://geekplux.com/2015/10/28/writing-skills
既然是小技巧,那么就不敢班门弄斧,只简单说说自己平时遵循的几条写作原则:
而且能一句话说清楚的,不要绕来绕去解释。
众所周知,我们现在看到长篇大论的文章都难以下咽。但如果在文中加几个段落标题,效果就大大不同。 同样的,在遇到排列句的时候,每句单独成行,比一整段要清晰的多。
这些措施一方面是在排版上进行改进,提升了阅读体验。更重要的一方面是这样使你的文章逻辑更加清晰。 写文章和做数学证明题一模一样。每一段都证明一个小问题,下一段的证明,依赖于上一段的结论。 所以每段有个主题,就比胡乱写强很多。
无论说话还是写作,都最忌没有重点。如果读完一篇文章,你不知道这篇文章的主旨是什么;读完一段话,你不知道这段话是在讲什么。那这篇文章就太失败了。 用粗体把重点标注出来,很容易吸引眼球。
想题目恐怕是世界上最难的事情了。其实日常生活中,很多时刻会有想写的冲动。尤其是发呆的时候,脑子里估计都写了一大段了,但一被打断,又忘得一干二净。等真正要写文章的时候,只能拔剑四顾心茫然。 所以我们 平时一旦有点小思路,就拿手机记下来 。反正手机不离身,记东西很方便。不用记太细,记些关键字也行,整个过程耗时不会超过一分...
Continue to read]]>昨晚看到自己订阅的博主有篇新文章——YouTube 观看历史分析,里面对 YouTube 优势的阐述和对视频这种信息获取方式的一些观点简直是和我不谋而合。
但最有意思的是他对自己观看记录进行了数据分析,知道了自己时间具体分配到了哪些频道。我看完几乎是没有丝毫等待,就按他的方法操练起来了。之后在他的基础上,我自己画了个 Wordle(词云),可以清晰的看出自己对某类视频的钟爱……
数据的收集、存储、分析,都已经在Yi's Blog提供,按照他的步骤可得到以下结果:
左图可以清晰的看出从 2017 年开始我在 YouTube 上花费的时间每年翻一倍,2019 年看了接近 3500 个视频……
再看右图,简直可以看出我 2019 年的作息习惯:
![](https://geekpluxblog.oss-cn...
Continue to read]]>.logseq
directory (including settings, themes, plugins, config, preferences.json) across devices and create soft links for these setting files.
Logseq, a robust platform for knowledge management and note-taking, offers users the ability to install a wide array of plugins to enhance productivity. However, these plugins and their associated settings are device-specific and do not automatically synchronize across different devices. This guide provides a detailed walkthrough on how to synchronize your Logseq plugins and settings across multiple devices.
This guide primarily focuses on synchronizing plugins and settings, excluding the actual pages, blocks, or graphs, as they usually have their own synchronization methods.
Assuming you are starting from your main machine, this guide will help you install and synchronize all your settings and plug...
Continue to read]]>原文地址:https://geekplux.com/2016/05/31/how-to-read-a-research-paper
这是一个知识过剩的时代。大量标榜为「干货」的文章每时每刻都在不断地产出,搜索引擎的便捷似乎也让我们离这些「知识」只有一步之遥。然而,随着多年在互联网上的浸淫,我发现越是容易得到的知识,价值越不大,留存的时间也越不长。所以,相对于那些东拼西凑组成的所谓干货,一本好书或一篇好的学术论文,才是知识的结晶(单从前后两者成文的时间上就可以很好的证明这点)。
关于「如何阅读一本书」的讨论,已经盈千累万,而关于「如何阅读一篇学术论文」的似乎还凤毛麟角。所以这篇文章我打算写一写我在阅读论文过程中总结出的一些方法,希望能对你有帮助,当然如果你有其他更好的方法,欢迎补充。文章共分为四个部分,第一部分介绍读论文的核心要素,第二部分列出阅读单篇论文的具体步骤,第三部分是一些补充。方法论讲完之后,最后一部分将阐述为什么要阅读文献期刊。
根据每个人读论文的目的不同,阅读的侧重点也会有所不同,但都不外乎要获取知识、解决问题,所以无论你的目的是什么,有三个核心要素是你在阅读一篇论文时必须掌握的:
阅读论文不能盲目的去读,要带着问题去读才有收获,只要了解了这三个核心要素,就可以对论文有一个整体的印象。
针对单篇论文: