Perl与JS的对比分析(数组、哈希)

 更新时间:2016年07月28日 10:15:17   投稿:jingxian  
下面小编就为大家带来一篇Perl与JS的对比分析(数组、哈希)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

上一篇列出了Perl中定义数组,对象的方式与JS的异同。这里继续补充数组,哈希的相关操作。

一、数组

可以对数组进行增删,插入。与JS不同的是这些函数都是全局的,JS则是挂在Array.prototype上。

1,对数组尾部的操作pop(删除最后的元素)、push(在尾部添加)

@goods = qw/pen pencil/; 
pop(@goods); # @goods 变成 (pen) 
push(@goods, 'brush'); # @goods 变为 (pen, brush) 

在Perl中,函数调用时小括号是可选的(视上下文而定),就象前面使用的print。以下是等价的

pop @goods; # @goods 变成 pen 
push @goods, 'brush'; # @goods 变为 (pen, brush) 

2,对数组首部的操作shift(删除第一个元素)、unshift(在首部添加元素)

3,任意位置删除或插入splice

4,逆序数组,Perl有reverse函数,JS没有对应函数。

5,排序数组sort,Perl和JS都有。

2,3,4,5提到的函数不贴演示代码了。

6,JS使用length属性获取数组长度,Perl不同,有3种方式获取

@goods = qw/pen pencil/; 
 
# 将数组变量赋值给一个标量变量 
$len = @goods; 
 
# 使用scalar函数 
$len = scalar(@goods); 
 
# 最后一个元素的索引加1 
$len = $#goods + 1; 

7,遍历数组,Perl用foreach函数

@goods = qw/pen pencil brush/; 
 
# 默认的$_ 
foreach (@goods) { 
 print "$_"."\n"; 
} 
 
# 自定义变量 
foreach $item (@goods) { 
 print "$item"."\n"; 
} 

ES5可以用forEach

['pen', 'pencil', 'brush'].forEach(function(item) { 
  console.log(item) 
}) 

二、哈希

1,获取keys和values

%person = ( 
 name => 'Jack', 
 age => 30, 
); 
@k = keys %person; # (name, age) 
@v = values $person; # ('Jack', 30) 

ES5有Object.keys,但没有Object.values

person = { 
 name: 'Jack', 
 age: 30 
} 
Object.keys(person) // ['name', 'age'] 

2,获取键值对(key-value)数量(对Perl来说很容易)

%person = ( 
 name => 'Jack', 
 age => 30, 
); 
$len = keys %person; # 2 

对于JS来说,可能需要for in整个对象

function getObjLen(obj) { 
  var len = 0 
  for (var a in obj) { 
    if (obj.hasOwnProperty(a)) 
    len++ 
  } 
  return len 
} 
 
var person = { 
  name: 'Jack', 
  age: 30 
} 
getObjLen(person) // 2

3,遍历对象

Perl有两种方式,一种while+each,一种获取keys再foreach。

%person = ( 
 name => 'Jack', 
 age => 30, 
); 
 
# 方式1 
while ( ($k, $v) = each %person ) { 
 print "$k: $v"."\n"; 
} 
 
# 方式2 
@keys = keys %person; 
foreach(@keys) { 
 print "$_: ".$person{$_}."\n"; 
} 

JS一个for in即可。

4,判断某个key是否存在,Perl用exists函数

%person = ( 
 name => 'Jack', 
 age => 30, 
); 
if (exists $person{ndame}) { 
 print 'yes'; 
} else { 
 print 'no'; 
} 

JS用in运算符。

5,删除key,都用delete,但Perl是函数,JS是运算符

%person = ( 
 name => 'Jack', 
 age => 30, 
); 
delete $person{'name'}; 

三、数组与哈希互换

Perl里哈希很容易就被转成数组

%person = ( 
 name => 'Jack', 
 age => 30, 
); 
@arr = %person; # 将哈希转成数组 变成了('name', 'Jack', 'age', 30) 

数组转成哈希

@nums = qw/zero 0 one 1 two 2/; 
%hash = @nums; 
while( ($k, $v) = each %hash ) { 
 print "$k: $v\n"; 
} 

打印如下

以上互换JS里没有原生支持,需自行实现。

以上这篇Perl与JS的对比分析(数组、哈希)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持程序员之家。

相关文章

  • Perl中的列表和数组学习笔记

    Perl中的列表和数组学习笔记

    这篇文章主要介绍了Perl中的列表和数组学习笔记,本文讲解了列表、数组--列表的存贮、数组的存取、字符串中的方括号和变量替换、列表范围、数组的输出等内容,需要的朋友可以参考下
    2015-02-02
  • Perl中的真与假深入研究

    Perl中的真与假深入研究

    这篇文章主要介绍了Perl中的真与假深入研究,本文详细讲解了Perl中真值与假值的不同,需要的朋友可以参考下
    2015-06-06
  • perl 简明教程 perl教程集合

    perl 简明教程 perl教程集合

    perl是什么,干什么用的?perl原来设计者的意图是用来处理 字符的,80%的强项是处理字符,当然其它的很多都可以。现在很多网页也是用perl的,通常需要CGI环境
    2015-10-10
  • perl处理xml的模块介绍

    perl处理xml的模块介绍

    perl处理xml的模块介绍,需要的朋友可以参考下
    2013-02-02
  • 求婚示爱的Perl代码之改写篇

    求婚示爱的Perl代码之改写篇

    求婚示爱的Perl代码之改写篇,特分享下, 方便需要的朋友
    2013-03-03
  • perl哈希的一个实例分析

    perl哈希的一个实例分析

    上一篇文章介绍了hash的入门教程,这篇文章为大家提供一个实例,方便大家深入学习
    2013-02-02
  • Perl List::Util模块使用实例

    Perl List::Util模块使用实例

    这篇文章主要介绍了Perl List::Util模块使用实例,本文给出扫描符合条件的某个列表并取出第一个符合条件的、求1到1000之间的和 、求一组数字的最大值与最小值等实用功能代码,需要的朋友可以参考下
    2015-06-06
  • perl操作MongoDB报错undefined symbol: HeUTF8解决方法

    perl操作MongoDB报错undefined symbol: HeUTF8解决方法

    这篇文章主要介绍了perl操作MongoDB报错undefined symbol: HeUTF8解决方法,需要的朋友可以参考下
    2014-10-10
  • Linux/Unix下安装Perl模块的两种方法分享

    Linux/Unix下安装Perl模块的两种方法分享

    Linux/Unix下安装Perl模块有两种方法:手工安装和自动安装。一是从CPAN上下载需要的模块,手工编译、安装。二是联上internet,使用一个叫做CPAN的模块自动完成下载、编译、安装的全过程
    2013-02-02
  • Perl中的正则表达式介绍

    Perl中的正则表达式介绍

    正则表达式是 Perl 语言的一大特色,也是 Perl 程序中的一点难点,不过如果大家能够很好的掌握他,就可以轻易地用正则表达式来完成字符串处理的任务,当然在 CGI 程序设计中就更能得心应手了
    2013-07-07

最新评论

?


http://www.vxiaotou.com