11.1 使用模块
模块有两种风格:传统的和面向对象的。传统模块为调用者的输入和使用定义了子过程和 变量。面向对象的模块的
运转类似类声明并且是通过方法调用来访问的,在第十二章, 对象,里描述。有些模块有上面两种类型的东西。
因此 如果你的模块的名字是 Red::Blue::Green,Perl 就会把它看作Red/Blue/Green.pm。
[root@wx03 test]# cat t1.pl
unshift(@INC,"/root/test");
require Red::Blue;
use Exporter;
print $Red::Blue::var;
print "\n";
print @INC;
print "\n";
[root@wx03 test]# perl t1.pl
31313
/root/test/usr/local/perl/lib/site_perl/5.22.1/x86_64-
linux/usr/local/perl/lib/site_perl/5.22.1/usr/local/perl/lib/5.22.1/x86_64-linux/usr/local/perl/lib/5.22.1.
Perl 将在 @INC 数组里面列出的每一个目录里面查找模块。
11.2.1 模块私有和输出器
Exporter - Implements default import method for modules 实现的默认的模块导入方法:
描述:
Exporter 模块实现一个导入方法 允许一个模块来导出函数和变量到用户的名字空间。
很多模块使用Exporter 相比实现它们自己的导入方法 因为Exporter 提供了一个高度灵活的接口,
实现优化的公用的情况。
Perl 会自动的import 方法 当处理一个use 语句 对于一个模块。 Modules使用是记录在perldunc和perlmod
How to Export 如何导出:
数组 @EXPORT 和@EXPORT_OK 是一个模块 持有符号表的列表, 被导出到用户的名字空间,
它们可以请求被导出, 分别的。 符号表可以代表功能,标量,数组,hash和类型团。
符号表必须是给全名
@EXPORT = qw(afunc $scalar @array); # afunc is a function
@EXPORT_OK = qw(&bfunc %hash *typeglob); # explicit prefix on &bfunc
数组@EXPORT和@EXPORT_OK 在模块里持有符号表的列表,被导出到用户的名字.
如果你只导出函数名字 推荐省略&记号, 这样会更快
Selecting What to Export
不要导出方法名字:
Exports 污染 模块用户的名字空间, 如果你必须export 尝试使用@EXPORT_OK
有限于 @EXPORT 避免短下的或者相同的符号名字来降低名字冲突的风险
通常任何不被导出的仍旧可以方位从外部访问这个模块使用 YourModule::item_name
(或者 $blessed_ref->method) syntax.
通过转换 你可以使用一个前导下划线来非正式的表明 它们是内部的, 不是公用的。
实际上可能得到私有的函数通过:
my $subref = sub { ... };
$subref->(@args); # Call it as a function
$obj->$subref(@args); # Use it as a method
然而 如果使用它们用于方法 , 让你明白如何使用继承工作
作为一个规则, 如果模块 是尝试面向对象的那么什么也不会导出。
它只是 函数的收集然后 @EXPORT_OK 任何但是使用@EXPORT
对于函数和方法命名使用barewords 在优先的 前缀命名
How to Import 如何导入:
在其他文件 你希望使用摩卡 这里有3种基本的方式 来加载模块和导入它的符号表:
use YourModule;
导入所有的符号表 在你的模块的@EXPORT 到你的名字空间
use YourModule ();
这个会导致perl加载你的模块但是不导入任何的符号表
use YourModule qw(...);
这个只会导入 列出的符号表到名字空间
所有列出的 符号表必须在你的@EXPORT or @EXPORT_OK
否则一个错误发生。