用perl写计时器,计算到毫秒精度。

 1 #!/usr/bin/perl
  2
  3
  4
  5 my $receive_key;
  6 my $end_key;
  7 my $Time_Start;
  8 my $Time_End;
  9 my $Time_Snano;
 10 my $Time_Enano;
 11
 12 print "Now it's time to start timing:";
 13 $receive_key=<STDIN>;
 14
 15 $Time_Start=`date +%s`;
 16 $Time_Snano=`date +%N`;
 17 $Time_Snano=sprintf("%3d",$Time_Snano);
 18 $Time_S=sprintf("%d.%d",$Time_Start,$Time_Snano);
 19
 20 while(1)
 21 {
 22     $end_key=<STDIN>;
 23     if($end_key)
 24     {
 25         $Time_End=`date +%s`;
 26         $Time_Enano=`date +%N`;
 27         $Time_Enano=sprintf("%3d",$Time_Enano);
 28         $Time_E=sprintf("%d.%d",$Time_End,$Time_Enano);
 29
 30         last;
 31     }
 32 }
 33
 34
 35 #my $timing = $Time_End-$Time_Start;

 36 my $timing = sprintf("The timing is %.2f seconds.\n",$Time_E-$Time_S);

38 print $timing;

相信大家对date +%N 有点陌生, 根据man date文档

%N     nanoseconds (000000000..999999999)

求的是纳秒,在这里取前三位代表毫秒数。 这里是按一个回车开始计时,再按一个回车停止计时,如果你不想在开始按回车开始计时,去掉$receive_key=<STDIN>这一行。


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值