zoukankan      html  css  js  c++  java
  • perl学习笔记(3)—— 坑

    (1)用perl来ls一个目录:

        写perl的时候,经常要调用到系统命令,perl有很多等价的函数可以用,但是,不小心任性了,就想用system来实现了,好吧,来个ls把,列出指定的一个目录,直接上代码

    sub ls{
           my ($dir) = @_;
           system("ls -al $dir ");
    }

    
    
    
    
    不做参数校验了,直接ls一个目录,这个是试了一下,确实可以这样做,感觉是挺容易的,没压力。但是,你仔细想一想,这真的可行吗?仔细想一下使用场景,你会发现,这个是一个坑,据说,是惨痛的教训。

    好了,不绕了,这是要在linux下使用的,linux下是允许文件名是有空格,要是我们输入一个带有空格的文件名,这里是会出错的,比如:你这样使用,

    ls("files isnot done");

    会被解释为“ls files isnot done”,这样就相当于ls了三个文件夹了,是不是很神奇。解决方法就是,把函数改为

    sub ls{
           my ($dir) = @_;
           system("ls -al '$dir' ");
    }

    像你在linux下ls一个文件一样。

    (2)函数的参数,如果把数组和标量作为参数,比如:

    sub func{
          my (@arrar, $var) = @_;
    }
    当你按函数定义传参的时候,你会发现,在函数体里$var为undef, 那时我纳闷了,说好的var去哪了,调试了一下,居然发现被存在@array里了,也是醉了,要解决这方法,可以把数组变为数组的引用,传参的时候也传一下数组的引用就可以了,这样var才不会被@array吞了。



    版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 相关阅读:
    MySQL 性能调优之索引
    MySQL 性能调优之存储引擎
    MySQL数据类型优化—整数类型优化选择
    MySQL数据性能优化-修改方法与步骤
    MySQL设计SQL语句优化规范
    MySQL索引的设计、使用和优化
    MySQL的SQL语句优化-group by语句的优化
    SQL性能优化-order by语句的优化
    MySQL查询优化注意下面的四个细节
    优化MySQL性能的几种方法-总结
  • 原文地址:https://www.cnblogs.com/Rex7/p/4752541.html
Copyright © 2011-2022 走看看