Perl组合技:sub

毋容置疑,编程的分分合合是很重要的思想。


就像下面的文件一样:

use File::Spec::Functions;
use strict;


################################
################################
# routines for Debug output
#
sub DEBUG_Activate 
 {
	open (DEBUG_CHANNEL , ">&STDOUT") or LOG_MsgExit ("Failed to attempt to open STDERR channel") ;

 }

sub DEBUG_Disable
 {
	
	open (DEBUG_CHANNEL , File::Spec->devnull() ) or LOG_MsgExit ("Failed to attempt to open NULL device");
 }

sub DEBUG_Write
 {
  	print DEBUG_CHANNEL ">>$_[0]\n";
        
 }

sub DEBUG_Close
 {
   close(DEBUG_CHANNEL);
 }



###########################################
###########################################
# Routines for dealing with the logfile
sub LOG_Disable 
 {
  open (LOGFILE, ">&STDOUT") or LOG_MsgExit ("Failed to attempt to open STDOUT device");
  DEBUG_Write ("Log messages output will be redirected to STDOUT");
 }

sub LOG_Create
 {
  my $file;

	$file=$_[0];
	open (LOGFILE,">$file") or LOG_MsgExit("Cannot create the logfile $file");
        close(LOGFILE);
        DEBUG_Write("Logfile $file has been created"); 
 }

##############################33
# returns 1 if file is writable, otherwise returns 0
# if cannot write, try to create it, and if success, then returns 1
#
sub LOG_IsLOGFILEWritable
 {
  my $file;
  my $k;

  	$file = $_[0];

	if ( -w $file ) {  return 1;  }
        else {  
               	$k = open(LOGFILE,">>$file");
                if ($k) { close(LOGFILE); return 1;}
                else { return 0; }
                
            }
 }

##########################################################
# Activates the channel LOGFILE, so print to this channel
# means write in the specified logfile
sub LOG_Enable
 {
  my $file;

 	$file = $_[0];
       utime(time(),time(),$file);

	open (LOGFILE , ">>$file") or LOG_MsgExit ("Failed to attempt to open the logfile $file");
	DEBUG_Write ("Opened the logfile: $file");
 }

sub LOG_Close
 { 
  close(LOGFILE);
 }

sub LOG_Msg 
 {
  my $t;
$t=localtime();

  print LOGFILE   "$t : $_[0]\n";
  DEBUG_Write ("Logged this alarm...: $_[0]");

 }

sub LOG_MsgExit
 {
 my $t;

$t=localtime();
  print LOGFILE "$t : $_[0]\n";
  DEBUG_Write("$_[0]");
  exit;
 }

return 1;

很明显这是一个.pm 的文件, 是.pl的模块,他们的关系就像:

.html - - .css   , .pl - - .pm

顿悟了吗


这里有好多的sub 函数,供随时调用(当然这里只举了个关于 logfile 的例子).

每一个sub函数,就相当于一个基本技,在主函数中进行组合,就是组合技,那么你就可以放肆地连招了。

PS:转载请注明出处,作者No. Liu

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值