本文和大家重点学习一下Perl use和require用法对比,这两个函数都是一个意思,加载和引用Perl的模块,或者是子程序,区别在于Perl use是在当前默认的里面去寻找,一旦模块不在指定的区域内的化,用Perl use是不可以引入的。
Perl use和require用法对比
对比(一)说明:
这两个函数都是一个意思,加载和引用Perl的模块,或者是子程序,
区别在于Perl use是在当前默认的里面去寻找,一旦模块不在指定的区域内的化,用Perl use是不可以引入的
第一、Perl use引入的名称不需要后缀名,而require需要
第二、Perl use语句是编译时引入的,require是运行时引入的
第三,Perl use引入模块的同时,也引入了模块的子模块。而require则不能引入,要在重新声明
Perl usemy
my中包含了一个Module.pm
而require
则需要引入requiremy requiremy::Module.pm
如果不想让Perl use引入Module.pm则可以用Perl userequire()加一对括号来说明即可
第四用Perl use引入模块是趋势,但是也不能说require没有存在的必要,视具体情况而定
对比(二)说明
区别一:跟require不同的是,Perl use只能用于模块的包含,也就是.pm文件。
比如:
Perl useMyModule;
实际上,编译器将从@INC指定的目录下去寻找MyModule.pm模块。如果模块名称中包含::双冒号,该双冒号将作为路径分隔符,相当于Unix下的/或者Windows下
的。如:
Perl useMyDirectory::MyModule;
编译器将从@INC指定的目录下的MyDirectory子目录去寻找MyModule模块,类似
如下路径:
C:PerllibMyDirectory
C:PerlextlibMyDirectory
C:PerlsitelibMyDirectory
区别二:两个都是包含,但是包含的条件是不一样的。require包含是发生在程序运行期,而Perl use包含是发生在编译期。学过C/C++的人比较容易理解。下面的例子是错误的:
Perl useConfig;
if($Config{'osname'}eq"MSWin32")
{ Perl useWin32Module; }
else { Perl useUnixModule; }
|
正因为Perl use是发生在编译期,代码没有执行,所以$Config变量的值是无法判断的。在内部,Perl use其实调用了require和import静态函数。import()函数告诉包哪些特征将要被导入当前包中,这意味着用之前不必验证函数或者变量是否合法。而require是不会调用import()的。
分享到:
相关推荐
# 问题 ... 'use strict'; // existing version for noConflict() var _Base64 = global.Base64; // 这句出错了...变量global的值是传入的this指针值,this指针为空了. var version = "2.1.9
总的来说,`use` 关键字主要用于处理命名空间,而 `include` 和 `require` 用于引入文件。在实际开发中,理解这些概念的差异对于编写可维护和可扩展的代码至关重要。正确使用它们可以提高代码的组织性和可读性,减少...
在这个"use.js"项目中,很可能就是基于或类似于RequireJS的实现,用于管理和组织代码,使其结构清晰、可维护性增强。 AMD模式的主要特点是: 1. **异步加载**:不同于传统的同步加载,AMD模式允许脚本在不影响页面...
本文将深入探讨AMD的代表作require.js和CMD的代表作sea.js。 首先,require.js是由James Burke创建的,它引入了异步模块加载的概念,允许开发者按需加载模块,而不是一次性加载整个脚本。require.js的核心函数有两...
Require.js是一个JavaScript文件和模块加载器,支持AMD规范,可以在浏览器中异步加载JavaScript模块,以提高页面性能。在开发微信上传图片组件时,我们可以将各个组件的html、js、css分别放在用组件名字命名的文件夹...
Browserify通过捆绑所有依赖项,使您在浏览器中需要... You can use browserify to organize your code and use third-party libraries even if you don't use node itself in any other capacity except for bundling
require.main process.mainModule和require.main进行调试和测试。 用法 // Always overwrite the main module. Use this to code your own conditions for an overwrite. require ( "fake-require-main" ) . fake ...
var use = require('koa-use');...var app = use(koa());app.use([ logger(), bodyparser(), ...]);app.listen(3000);等于: var koa = require('koa');...var app = koa();app.use(logger());app.use(bodyparser())...
要求样式Browserify 转换以允许在 .css 文件上调用require() 。 将重写模块,以便将<link>元素注入<head> 。 对于那些你希望你的 CSS 和你的 JS 分开而不是在一个大的缠结球中的时候。 // Sourcerequire...
`require.js` 是一个流行的JavaScript模块化加载器,它的核心功能是帮助管理和组织JavaScript代码,使其更容易维护和按需加载。在`require.js`中,`define`函数是定义模块的关键,它允许开发者声明模块的依赖,并...
安装 npm install --save require-https原料药requireHttps(状态,消息) 参数: status -可选的HTTP状态代码在错误包括在检测到不安全的连接时。 默认为403 Forbidden 。 message -可选的错误消息中的错误,包括当...
编辑#!/usr/bin/perl -wuse strict;...require 'shellwords.pl';#$f->PAUSE("$0");my $dirname = dirname($0);#my $dirname = dirname(__FILE__);my $JOB = $ENV{JOB};my $STEP = $ENV{STEP};
-- use require --> < script > var assert = require ( "chai" ) . assert ; var Emitter = require ( "emitter" ) ; </ script > 如果您发现某些东西不起作用,请报告。 它是如何
本文将详细介绍PHP中namespace和use关键字的用法,并通过实例分析加深理解。 首先,我们来认识一下什么是命名空间。在PHP中,命名空间可以类比于文件系统中的目录,它为类、接口、函数和常量提供了一个封装的上下文...
Node.JS 的扩展需求 ...// only files under /path/to/project/lib will use that include path set // you can create as many include path sets as you want var includePath = er . newIncludePath
节点要求clojurescript Node挂钩的概念证明允许require()ClojureScript模块。... main.js是在Node中运行的ClojureScript编译器。...// Use eval() to compile and run arbitrary ClojureScript code
nodejs-模块-需要 nodejs-module-require 是一个自定义模块加载器 ... // use custom module var m1 = mrequire ( "myChoosedModuleName" ) ; 也可以使用相对源“./file.js” 使用另一个名称链接 node
var express = require('express'); // let path = require('path') // const proxy = require('express-http-proxy'); var request = require('request'); var log4js = require('log4js'); // var fs = ...
安装 $ component install segmentio/use-https例子在https://example.com ... var https = require ( 'use-https' ) ;https ( ) ; // truehttps ( '//site.com' ) ; // "https://site.com"应用程序接口使用Https()...