ruby 多线程及查看程序运行情况

每个正在系统上运行的程序都是一个进程。每个进程包含一到多个线程。
线程是程序中一个单一的顺序控制流程,在单个程序中同时运行多个线程完成不同的工作,称为多线程。
Ruby 中我们可以通过 Thread 类来创建多线程,Ruby的线程是一个轻量级的,可以以高效的方式来实现并行的代码。

def function1
    i = 0
    while i<=50
        puts "func1 at : #{Time.now}"
        sleep(2)
        i=i+1
    end
end

def function2
    j = 0
    while j<=50
        puts "func2 at : #{Time.now}"
        sleep(1)
        j=j+1
    end
end
start = Time.now
t1 = Thread.new{function1}
t2 = Thread.new{function2}
t1.join
t2.join

end_time = Time.now
puts "used :"+(end_time-start).to_s

查看程序运行占用cpu情况:top -p $(pgrep ruby)
这里写图片描述


pstack查看进程所有线程的执行栈,里面有当前执行到哪一个函数, 函数的调用关系等:pstack $(pgrep ruby)
这里写图片描述


查看程序进程树:pstree -p pid
这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值