教小朋友编程的几个建议(翻译)

编程是一项任何孩子都可以参与的创造性活动。你的孩子或许不喜欢编写数据处理算法,但他们可能会喜欢创造游戏、对音乐编程、设计网站、或只是摆弄代码。

我曾经写过几本编程的入门书籍,适合各个年龄段的初学者,根据我的经验,你不必认为自己是技术人员或“擅长数学”才能学习编程。实际上,孩子学习编程要比成年人更快,因为他们不知道编程的“困难”所在。

如果你不会编写任何代码,但想通过学习来教你的孩子,看看我最新的Python图书《Automate the Boring Stuff with Python》,它适合初学者,你可以在网上免费阅读。

不管你是软件工程师,还是完全没有编程背景,下面这六个建议都将有助于你的孩子学习编程:
继续阅读“教小朋友编程的几个建议(翻译)”

微信公众号上运行的前端代码精简压缩,优化加载速度,提升用户体验——gzip大法

再次体会到全栈开发的威力!其效率绝对大于纯前端+纯后端。因为可以从更高的维度来思考问题,看问题也更加全面和透彻。

继上次优化微信H5的前端js和css加载速度后,仍有一些用户反馈加载速度慢的情况。这次通过server端来进行gzip压缩和处理。效果非常显著。

我们微信服务器的后端server用的Nginx做反向代理,如下是具体的gzip配置和分析。

继续阅读“微信公众号上运行的前端代码精简压缩,优化加载速度,提升用户体验——gzip大法”

android postDelayed

这是一种可以创建多线程消息的函数
使用方法:
1. 首先创建一个Handler对象
Handler handler=new Handler();

2. 然后创建一个Runnable对象
Runnable runnable=new Runnable(){
@Override
public void run() {
// TODO Auto-generated method stub
//要做的事情,这里再次调用此Runnable对象,以实现每两秒实现一次的定时器操作
handler.postDelayed(this, 2000);
}
};

3. 使用PostDelayed方法,两秒后调用此Runnable对象
handler.postDelayed(runnable, 2000);
实际上也就实现了一个2s的一个定时器

4. 如果想要关闭此定时器,可以这样操作
handler.removeCallbacks(runnable);

当然,你也可以做一个闹钟提醒延时的函数试试,比如,先用MediaPlayer播放闹钟声音,
如果不想起,被停止播放之后,下次就5分钟后再播放,再被停止的话,下次就4分钟后播放,
………………
只要更改延时的时间就可以实现了,用一个static对象的话会比较容易操作。

是可以异步效果,但Runnable的执行是在Handler对象所在的线程
如果其所在的线程是UI线程的话,Runnable中还是不能执行耗时操作,不然会ANR
前几天我们自己的设备很卡,卡到跳转界面都需要不到1秒的时间,我就把跳转的动作放在Runnable里边,外边加上弹出进度提示框

注:举例说明

Android setTextSize

在帮TextView控件设置大小的时候,发现和在XML中用PX设置的不一样,原因是setTextSize()默认的单位是sp,可以用另一个设置字体大小的方法:

setTextSize(int unit, int size)

第一个参数可设置如下静态变量:

TypedValue.COMPLEX_UNIT_PX : Pixels
TypedValue.COMPLEX_UNIT_SP : Scaled Pixels
TypedValue.COMPLEX_UNIT_DIP : Device Independent Pixels

阿里云CentOS Linux系统CPU100%——被黑客种下恶意程序“门罗币”“挖坑机”的排除修复案例

收到阿里云短信,提示server被搞成“挖坑机”的肉鸡了。

一、排除过程
1. top c 命令发现如下进程CPU占用率100%(恢复快照后,第二次CPU占用率50%)

继续阅读“阿里云CentOS Linux系统CPU100%——被黑客种下恶意程序“门罗币”“挖坑机”的排除修复案例”

将footer固定在页面底部的实现方法,附实例

方法1:footer高度固定+绝对定位

test1实例 继续阅读“将footer固定在页面底部的实现方法,附实例”

Android安卓平台上网页WebView中全屏横屏播放html5视频的实现

可以实现在WebView中全屏横屏播放html5视频,但是没办法播放的时候直接进入全屏,因为监听不到播放事件。如果有兴趣可以考虑使用点击事件的监听来曲线救国。

继续阅读“Android安卓平台上网页WebView中全屏横屏播放html5视频的实现”

微信公众号上运行的前端代码精简压缩,优化加载速度,提升用户体验——grunt+requireJS

背景:
1. grunt编译压缩,requireJS加载
2. css编译压缩成单独的min.css文件,大小:384kb
3. js编译压缩成单独的min.js文件,大小:562kb
4. 调用了第三方统计JS 继续阅读“微信公众号上运行的前端代码精简压缩,优化加载速度,提升用户体验——grunt+requireJS”