我们经常需要对二维数组进行迭代,比如这样:
for(int x = 0; x < width; x++){
for(int y = 0; y < height; y++){
screen[x][y].setColor("black");
}
}
过上一段时间,你又要写这么一段代码:
for(int i = 0; i < rows; i++){
for(int j = 0; j< columns; j++){
objects[i][j].update();
}
}
如果你是程序员,那么你理应厌烦:又一次重复得输入for
,[]
,{}
……而且一个不小心,还很容易输入错误。浪费时间寻找哪里少了一个分号可不是你该做的事情。
那么不如来试试Snippet,一小段预先定义好格式的代码块。下次使用时,只需填入变化的部分。是的,就像填表一样。
在Atom中设置你的Snippet
为了在Atom中使用Snippet,你需要首先定义好你的代码块格式。
Linux环境下,进入Edit->Snippets...,相对应的,在Windows下是File->Snippets...。
这实际上是一个cson文件,格式如下:
'.source.python': # 在何种文件中使用这个Snippet
'python coding': # 对Snippet的简短说明
'prefix': 'coding' # 输入什么前缀可以触发这个Snippet
'body': '# -*- coding:utf8 -*-\n' # Snippet的内容
第一行指定在何种文件中使用Snippet,你可以在设置的Packages中的Installed Package里搜索你要用的编程语言。
点击对应的包,通常名字是:language-编程语言。在打开的包里看看Scope是什么。
常用的几种如下:
文件后缀 | Scope |
---|---|
.c .h | .source.c |
.py | .source.python |
.java | .source.java |
.js | .source.js |
.css | .source.css |
.md | .source.gfm |
第一个示例:指定Python文件的编码
我们都知道,如果你在python2中使用中文,在Python文件开头,你需要添加这么一段代码,指定这个文件的编码格式:
# -*- coding:utf8 -*-
每次都要输入,重复!那就把它变成一段Snippet吧:
'.source.python':
'python coding':
'prefix': 'coding'
'body': '# -*- coding:utf8 -*-\n'
这样,在打开.py文件后,只需输入coding
,然后按下Tab键,这段遍布着*
的代码行就一下子输入成功了。
第二个示例:划分你的代码
还是在Python中,如果你想要添加一段像下面这样的代码,将你的.py文件划分成多块的话:
#=====================
# 数据爬取结束,开始匹配
#=====================
这时候,中间的文字是你每次都需要更改的部分,当然可以在输入其他部分后再移到中间部分进行编辑,但我们有更好的东西:
'.source.python':
'python coding':
'prefix': 'coding'
'body': '# -*- coding:utf8 -*-\n'
'section':
'prefix': 'section'
'body': '#=====================\n# $1\n#=====================\n$2'
注意,对同一后缀文件的Snippet,都得写在一起。
$1表示光标第一次所处的位置,按一下Tab后光标会移到$2所处的位置。
在这个例子中,输入section然后按Tab,光标就自动出现在这段代码的中间,输入完中间部分,再按Tab,光标就会移动到这段文字的最后。你可以继续编码,而无需浪费时间在移动光标上。
第三个示例:同时编辑多处
在上面,我们使用\n
划分多行,但是行数一多,这样看起来就眼花缭乱了,我们可以使用"""
来编写多行的Snippet:
'.source.java':
'iterate two dimension array':
'prefix' : 'for2'
'body' : """
for(int $1 = 0; $1 < $2; $1++){
for(int $3 = 0; $3 < $4; $3++){
$5[$1][$3]$6
}
}
$7
"""
Atom的一个优势就是可以同时修改文件的不同位置,Snippet自然支持这一点。
你会注意到,$1出现三次,这意味着一次键入,三处输入。这样不但快捷,还能保证命名一致。(错也会错成一样的)。
要注意的
- Snippet很方便,但只有你用起来的时候才能加速你的编码。要记得使用,直到肌肉有了记忆,自然而然地使用Snippet。
- Snippet的介绍似乎不是很重要,但安装了其他人的Snippet后,你需要这些介绍来进行区分,所以还是要认真编写的。
- 保持开心,如果Snippet用起来感觉不是爽而是痛苦,那就不要使用它。也许你会发现,这些重复的编码可以用其他的东西来解决,比如
map
函数。