广州明生堂生物科技有限公司


Ruby中区分运行来源的方法

网络编程 Ruby中区分运行来源的方法 06-22

当我们在写模块的时候,或多或少需要直接运行这个文件也可以执行一些方法,但是这样对于当这个模块被require或者include时,显得不好,在ruby里,有没有区分运行来自当前文件,还是被require的目标文件调用呢?

Python可以

比如像Python这样

if __name__ == '__main__':

    print "from direct running"

Ruby当然也可以

对于处处为程序员着想,拥有快乐编程理念的Ruby来说当然是可以区别的。其原理就是判断启动文件是否为模块的代码文件。

if __FILE__ == $0

    puts 'called from direct running'

end

举个例子

工具类模块utils.rb

module Utils

    class StringUtils

        def self.test

            puts "test method myfile=" + __FILE__ + ';load from ' +  $0

        end

    end

end

if __FILE__ == $0 puts 'called from direct running' Utils::StringUtils.test() end

直接运行,结果,if条件成立,执行了输出

20:04:37-androidyue~/rubydir/test$ ruby utils.rb

called from direct running

test method myfile=utils.rb;load from utils.rb

引用Utils的类test.rb

require './utils'

Utils::StringUtils.test()

运行结果,引入模块的条件不成立,没有输出called from direct running

20:08:07-androidyue~/rubydir/test$ ruby test.rb

test method myfile=/home/androidyue/rubydir/test/utils.rb;load from test.rb

Ruby中的Mechanize的使用教程
Ruby中实现网页抓取,一般用的是mechanize,使用非常简单。安装sudogeminstallmechanize抓取网页require'rubygems'require'mechanize'agent=Mechanize.newpage=agent.get('http://google

Ruby中使用多线程队列(Queue)实现下载博客文章保存到本地文件
Ruby:多线程下载博客文章到本地的完整代码#encoding:utf-8require'net/http'require'thread'require'open-uri'require'nokogiri'require'date'$queue=Queue.new#文章列表页数page_nums=8pa

Ruby中用线程实现经典的生产者消费者问题代码实例
示例代码:require"thread"puts"ProAndCon"queue=Queue.new#用队列Queue实现线程同步producer=Thread.newdo10.timesdo|i|sleeprand(i)#让线程睡眠一段时间queueiputs"#{i}produced"endendcon


编辑:广州明生堂生物科技有限公司

标签:模块,文件,线程,代码,队列