谈新技术学习方法-如何学习一门新技术新编程语言

学习一门编程语言或者编程技术的方式基本上是这样一个流程:

1,对学习这门语言或者技术的必要性进行评估。比如你是工作需要,或者兴趣所至,甚至是为了把妹。这个必要性关系到你要学多深入,需要学习多长时间。

比如我想学Lua,是想学它如何在万把行代码里面实现了一个如此精巧的编程语言,想学习它的GC机制,学习它如何设计VM,如何用纯C语言设计项目等等。

2,寻找相关资源。比较好的起始点是这门技术的官方网站以及维基百科。

比如Lua语言的官方网站是http://www.lua.org,维基百科地址为http://en.wikipedia.org/wiki/Lua_%28programming_language%29

一般在google.com里面敲入"lua wiki"之类就能直接搜索到相关维基条目。使用维基百科的好处是能够对编程语言有个概括了解,基本上看了以后,你都可以跟别人扯上几句一点问题也没有。另外维基百科在编程语言相关条目中有一个很有意思的特色就是:influenced by以及influenced列表。比如Lua条目中注明被Scheme、SNOBOL、Modula、CLU、C++所影响,影响了IO、GameMonkey、Squirrel、Falcon、Dao、MiniD这些语言,通过它可以了解到这门语言的祖先以及后代,相当的有意思。

而在官方网站,会有最新鲜的新闻、下载、文档帮助、论坛等相关内容。

image

3 找到官网以后,就要花上一段时间在官方网站好好浏览探寻一番。比如Lua官方网站的about栏目介绍了Lua是什么,为什么选择Lua,谁编写了Lua代码等等。在News栏目有关于Lua的最新新闻。Download栏目中有软件下载,学习一门语言,重要的是在练习中学习,大多数人都用Windows,就可以遵照下载栏目的推荐下载Lua for windows。

4 下载了软件(Lua for windows),安装成功以后,就可以看看文档document了。在Lua的文档网页中有在线参考手册(reference manual),大多数编程语言也都会在下载安装包中自带一份手册文档(就我所知Ruby Python都是如此)。

如何系统的学习一门语言?通过手册不是什么好办法,手册内容相对教条枯燥,读起来不容易。而且在线学习注意力不容易集中,很容易点着点着就跑偏了。最好的办法还是要买一本实体的参考书。

买实体书就要用到amazon或者douban了,你可以根据amazon以及douban上的打分来确定这本书的好坏,另外在Lua的document页面也有几本书推荐,像是Lua这种略微偏门的语言,其实选书很简单,因为就那么两三本,我个人推荐Programming in lua,国内有翻译版本,另外也可以下载到5.0的中文版。

image image

那么对于java、dotnet这类参考书乌央乌央的技术来说,该如何选书?这时候我会参考以下几个因素:一个是语言创始人写的可选择,一个是奥莱里oreilly出版的可以买,另外可以参考豆瓣或者amazon的书单功能,看看其他人都推荐什么。最不济的办法可以看销量,销量高的书未必就好,但是选了也不至于错的离谱。

买到书以后,最好花上几天时间通读一下,对于不理解的部分先标记略过,力争先对语言技术的整体有个了解,对于一些基本操作、命令有一些印象。

5 通读以后就要细读了,一般来讲,每个编程语言都力争相对完整,所以必然有一些你未必感兴趣的内容或者用不到的内容,这些都可以放在一边需要时候再捡起来。细读的过程最好准备个小本子,另外建议在github上注册一个账号,github有个gist.github.com页面可以保存代码片段,在做代码练习的时候很有用。

细读的过程力争完全理解,书上的示例代码也都尽量自己敲进去运行一次,另外可以对示例代码做一定的扩展,比如在第五章的代码中加入第四章的代码,让它们组合起来看看如何。

6 用一两个月时间细读以后就是熟练提高阶段。当你细读了感兴趣的章节,最好在一段时间内尽量用新语言完成自己的编程需求,比如写个网络爬虫,或者删除某个目录下的特定文件,或者做做文本处理,一定要经常用才不会忘记。这段使用过程可能需要两三个月的时间,力争达到常见的代码函数不怎么查手册就可以熟练写下来。另外可以有意的对自己已经完成的算法或者应用进行语言上的翻译,用新语言实现一下快速排序,实现一下正则表达式。编程其实就是个熟练过程,越练越顺手。

这个时候可以试着购买一些advanced级别的书籍,了解一些更深入的内容,书籍的好坏依然是到amazon或者douban上搜索。

提高的过程中可以订阅一些相关的博客内容,可以到blogsearch.google.com查找博客文章,或者到csdn、javaeye、cnblogs这样的技术相关博客站点搜索。看到好的文章,可以使用delicious.com这个书签网站保存起来以后慢慢阅读。

7 在这段期间包括以后的使用过程,如果出现问题怎么办?可以遵照以下顺序查找帮助:

    a)书籍或者手册,在线文档,在线帮助等等

    b)在官网的wiki或者stackoverflow.com上搜索相关的关键字。

    c)使用google搜索相关关键字。

    d)到stackoverflow或者官方邮件列表、官方论坛中提问。

一般来说最好订阅这门语言的邮件列表,比如Lua的邮件列表就是http://www.lua.org/lua-l.html 即使不提问,看看别人的问题也是很有意思的。

我不建议大家加入什么QQ群学习,QQ或者msn的即时通讯特性决定了它不是一个很好的学习方式,基本上只适合打屁聊天。

8 到了四五个月以后,按照前面步骤学下来的朋友应该已经算是中级水平了,不太可能问出什么“跪求、裸求”之类的弱智问题。这时候就可以往更深入的层次发展,比如试着读读源代码,试着写写相关编程库编程插件,在官方论坛、maillist、stackoverflow里面多帮人解答解答问题,试着多写写自己对于这门语言的使用经验,分享一些相关问题等等,就此走向“破碎虚空”的高手之路。

好了,就这样吧!

你在项目中用了很多技术么?软件开发中7种反模式

From “make good software"

软件开发中一个经常发生的常见错误是太关注于技术、架构、中间件或者其他技术细节。我们忘记了任务是产生一个出色的应用程序,而不是我们用了最强劲的工具。

下面是我列出的一些反模式。

反模式1:基于知道的技术数量来选择人

在选择人才方面一个最常见的情况是我们让技术来驱动我们的决策,这是非常不保靠的。我们不能只关心候选者知道多少技术,而不去他们有什么好的编码设计技能,其实后者是更重要的。

反模式2:选择技术不是基于有用与否

我们都准备差不多了,项目就要开始,我们做的第一件事是罗列出觉得适用于这个项目的技术、框架。这就像是列一个要去超级市场时用的购物单子。我认为一开始越简单越好,只在必要的时候,确定新技术能够增加生产力的情况下,再加入新的技术、框架。

反模式3:过度使用新技术(炫技)

”你拿着锤子,什么东西看上去都像是钉子”。设想一下决定使用“Spring”作为依赖注入架构。接下来你会想,Spring可以创建应用中所有的对象,然后配置文件相应的就增加了上千行代码。

反模式4:用技术细节掩盖设计上的瑕疵

当我们讨论这个反模式,性能问题立刻浮现出来。当应用程序性能非常糟糕的时候抱怨或者关注于相应的技术细节是很常见的,但是我的经验是,性能问题常常产生于设计层面。

反模式5:一直倾向使用新技术而不是平常方法

一些开发人员一旦发现他们能够用到某种新技术,立刻就对简单常用的方式弃如敝履,通常情况下这不是什么好现象。值得记住的是技术、架构、中间件都可能是项目中的负担,它们需要维护、学习、支持、配置等等。

反模式6:即使没必要也拔高扩展性的优先级

我听到的一个很常见的使用酷炫的新技术的理由是他们有良好的扩展性以及其他平常方法做不到的可配置能力。听上去很酷是不是,其实大多数情况下对于项目来说这都不是必须的,使用它们只能增加项目工程完成的风险。

反模式7:MDT-领导层驱动技术

这个反模式常常是这样的:你的领导读了一篇杂志或文章,谈论到某个高超的技术,他感到很兴奋。隔天到了公司以后他决定说:“我发现了针对我们所有问题的解决方案,从现在起我们都要开始使用xxx!”

image

1)我需要管理一个很“性感”的项目来提升我的职业经验。

2)它要听上去不错,而且在我得到提拔之前不能失败。

3)“反恐纳米干细胞”,这个怎么样?O-O-OKAY.

IronRuby一些小技巧

操作excel

 1: require "Microsoft.Office.Interop.Excel, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" 

 2:  

 3: include Microsoft::Office::Interop::Excel

 4: excel = ApplicationClass.new

 5: excel.Visible = true

 6: workbook = excel.Workbooks.Add()

 7: worksheet = workbook.Worksheets.Add()

 8: worksheet.Name = "aaaaa" 

 9:  

 10: cell1 = worksheet.Cells(1,1)

 11: cell1.Value = 42

如何获得assembly的strong name?

 1: load_assembly 'Microsoft.Office.Interop.Excel'

 2:  

 3: System::AppDomain.current_domain.get_assemblies.each{|x| puts x};

RPC 解决方案(http://www.ruby-forum.com/topic/206314

Very CLR centric:

You can create a proxy to your webservice using visual studio, compile to a dll and use the proxy from your ruby code.

CLR centric:

You can use System.Net.HttpWebRequest to make the request and System.Xml.XmlDocument to parse the response

Very Ruby centric:

Use Net::HTTP to perform the request and REXML to parse the response

IronRuby试玩

IronRuby下载最新版本解压,然后把目录加入系统Path。

IronRuby使用Sinatra

1)igem install sinatra –no-rdoc –no-ri

2) 应该提示rack和sinatra都安装完毕

3)写代码如下:

 1: require 'rubygems'

 2: require 'sinatra' 

 3: get '/' do

 4: "My machine name is #{System::Environment::machine_name}"

 5: end

保存为mysinatra1.rb

4) 运行 ir mysinatra1.rb,应该提示类似pid=xxxx port=4567,打开浏览器,输入http://localhost:4567/ 就可以看到期望的信息了。

注意,在我测试过程中,最新版本下,不需要对sinatra做任何patch,跟ironruby官网提到的不一样。

IronRuby使用Rails,参考http://www.ironruby.net/Documentation/Real_Ruby_Applications/Rails

1)安装 "igem install rake rails activerecord-adonet-sqlserver –no-rdoc –no-ri"

2)如果自己测试,可使用sqlite3-ironruby,"igem install sqlite3-ironruby –no-ri –no-rdoc”

3)建立一个IronRuby rail程序, "ir -S rails IronFirst"

4)修改config/environment.rb,可以看到有类似的代码,改成 config.gem "sqlite3-ironruby", :lib => "sqlite3" ,使用sqlserver有另外的修改方式,大家自己看网页吧。

5)ir script\generate scaffold post title:string body:text published:boolean

    ir -S rake db:migrate

6)ir script\server

这时候可以看到http://localhost:3000 是rails的默认界面,进入http://localhost:3000/posts 可以进行添删改操作。不过我测试,默认下不支持中文,应该是要修改一些参数才行。

all done.

一个内部局域网投票程序的初步设计

最近准备学习dotnet,要有一些代码练练手。看好了sliverlight或者wpf,毕竟是下一代显示技术。

基本设想如下,客户端运行程序,读取数据,动态生成投票(或者是survey)界面,运行,保存,然后将数据传回服务器端。

技术问题不算多,也有,比如sliverlight其实是没法直接连接数据库的,这个从安全角度也说得通。所以就要引入WCF或者RIAService技术,又多了一层曲线要学。

如何让读取保存数据过程更简单,容易实现?我想到了ironpython。

下载了最新版本的ironpython,搜索一下xmlrpc就能找到这篇文章:

http://www.ibm.com/developerworks/library/ws-pyth10.html

其中服务器代码如下:

import calendar, SimpleXMLRPCServer

#The server object
class Calendar:
    def getMonth(self, year, month):
        return calendar.month(year, month)

    def getYear(self, year):
        return calendar.calendar(year)

calendar_object = Calendar()
server = SimpleXMLRPCServer.SimpleXMLRPCServer(("localhost", 8888))
server.register_instance(calendar_object)

#Go into the main listener loop
print "Listening on port 8888"
server.serve_forever()

客户端代码如下

import xmlrpclib

server = xmlrpclib.ServerProxy("http://localhost:8888")

month = server.getMonth(2002, 8)
print month

主要是python的标准库实现了xmlrpc机制,而WCF技术说白了,也就是类似XMLRPC这样的remote process calling技术,换个马甲我就不认识你了么?

应该也可以通过dotnet framework,没那兴趣继续研究,就到这里吧。

ironpython应用于WPF的文章也很多,有机会试验了以后写出来。

image

使用Lua编写Utility的一些小贴士

string trim功能

 1: function string_trim(s)

 2: if s == nil then

 3: return

 4: end

 5:  

 6: return (string.gsub(s, "^%s*(.-)%s*$", "%1"))

 7: end

检查某个字符串是不是指向合法目录。

 1: function check_directory(s)

 2: s = string_trim(s)

 3: if not s or s == "" then

 4: return false

 5: end

 6:  

 7: if string.sub(s, -1, -1) == [[\]]then

 8: s = string.sub(s, 1, -2)

 9: end

 10:  

 11: local attr = lfs.attributes (s)

 12: if (attr and attr.mode == "directory") then

 13: return true

 14: end

 15:  

 16: return false

 17: end

对于文件操作,最好先备份一下原来文件:

 1: local str = "copy \"" .. Folder .. '\\log.db' .. "\" \"" .. Folder .. '\\log.db' .. "." .. os.time() .. "\" /v /y"

 2:  

 3: os.execute(str)

对于sqlite的操作,注意使用了一个自增myid作为key。

 1: Db1 = sqlitelua.open(upFolder .. '\\mainlog.db')

 2:  

 3: Db1:exec('CREATE TABLE newfiles(myid INTEGER PRIMARY KEY AUTOINCREMENT, myname, myfolder)')

 4:  

 5: local stmt1 = Db1:prepare[[ INSERT INTO newfiles VALUES (:myid, :myname, :myfolded) ]]

 6:  

 7: stmt1:bind_names{myname = new_name, myfolder = currentFolder}

 8:  

 9: stmt1:step()

 10: stmt1:reset()

 11: stmt1:finalize()