`
gaozengguang
  • 浏览: 63267 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Perl5 Hash数组(数组元素是Hans结构)--2存在问题

阅读更多

上 一篇文章《Perl5 Hash数组(数组元素是Hans结构)》中遇到了一个Hash数组定义的问题

 

1、创建Hash数组定义源代码

#!/usr/bin/perl
####################################################################################
##            创建Hash数组定义
## 编写:高增光
## 日期:2011.09.16北京 
## 功能:测试脚本
## 脚本说明:
###------------------------------------------------------------------
my @array_attributeObjs = make_hash_array();

#print "数组的长度:".@attributeObjs_array."\n";

my $num = 0;
foreach $hash_obj (@array_attributeObjs) 
{
	$num++;
	print "数组外部->第$num个元素:".$hash_obj->{"attributecnname"}."\n";
}
### 函数名称: make_hash_array
### 函数功能: 创建Hash数组
### 输入参数:
### 输出参数: 无
### 返回  值: 
### 说    明:
###------------------------------------------------------------------
sub make_hash_array()
{
               #定义一个数组
	my @array_attributeObjs=();
	for ($count=0; $count <= 2; $count++)
	{
		$hash_obj->{"resattributeid"} = $count;
		$hash_obj->{"attributecnname"} = "新的Hash_$count";
		push(@array_attributeObjs,$hash_obj);
		print "数组内部->第$num个元素:".$array_attributeObjs[$count]->{"attributecnname"}."\n";
	}
	return @array_attributeObjs;
}

 2、创建Hash数组定义--运行结果

数组内部->第个元素:新的Hash_0
数组内部->第个元素:新的Hash_1
数组内部->第个元素:新的Hash_2
数组外部->第1个元素:新的Hash_2
数组外部->第2个元素:新的Hash_2
数组外部->第3个元素:新的Hash_2

 

3、咱们可以发现 在循环中是,数组取得的Hash值是正确的,但是一旦跳出循环则始终取得的是最后一次定义的Hash值。上一篇文章通过定义N个Hash表,然后把这N个Hash表插入到数组中。可以规避这个问题,但是不是最终解决办法?

 

希望可以跟大家探讨一下 如何解决?

分享到:
评论

相关推荐

    Java 实例 - 数组排序及元素查找源代码-详细教程.zip

    在Java编程语言中,数组是基础且重要的数据结构,用于存储一组同类型的元素。本教程主要涵盖两个核心主题:数组的排序和元素查找。通过学习这些概念,开发者能够有效地管理和操作数组,提升程序的效率。 一、数组...

    查找数组中和为某个值的元素对的个数

    在编程领域,"2-sum"问题是一个常见的算法挑战,它涉及到在给定的整数数组中寻找两个元素,使得它们的和等于一个特定的目标值。这个问题对于理解和掌握基础的算法设计以及数据结构优化至关重要,特别是在面试和编程...

    perl_hash 函数

    ### Perl Hash 数据结构详解 #### 一、Perl Hash 概述 **Perl Hash** 是 Perl 编程语言中的一种非常重要的数据结构。它类似于数组,但与数组不同之处在于其索引(通常称为 key)不是数字,而是字符串。这意味着...

    浅谈js多维数组和hash数组定义和使用

    JavaScript中的数组是存储数据的重要工具,它可以容纳各种类型的值,包括数字、字符串、对象等。在JavaScript中,有两种特殊的数组形式:多维数组和Hash数组(也称为关联数组)。接下来,我们将深入探讨这两种数组的...

    perl5语言全教程

    - **变量和数据类型**:Perl5支持多种变量类型,包括标量(scalar)、数组(array)和哈希(hash)。标量用于存储单个值,数组存储一系列有序元素,而哈希则以键值对的形式存储数据。 - **语法和控制结构**:Perl5...

    神奇的perl-最佳Perl入门

    - 数组是一种有序的元素集合。 - 列表:可以使用`()`创建匿名列表,如`(@array = (1, 2, 3))`。 - 数组声明与赋值:`@array = (1, 2, 3)`。 - 元素访问与修改:`$element = $array[0]`。 #### 范围操作符 - `..`...

    Learning Perl第5版

    - **警告功能**:Perl内置警告机制,用于提示可能存在的问题。 - **变量声明**:使用`$`前缀声明标量变量,如`my $number = 5;`。 - **输出语句**:使用`print`函数输出文本到屏幕,如`print "Hello, World!\n";`。 ...

    perl神奇入门-最佳perl入门读物

    - **数组 (@)**:数组是Perl中的一种数据结构,用于存储多个有序的元素。可以通过索引来访问数组中的特定元素,索引从0开始。例如: ```perl @colors = ("Red", "Green", "Blue"); print $colors[0]; # 输出 ...

    Perl 5 example.pdf

    ### Perl 5 示例知识点 #### 一、概览与入门 **标题:** Perl 5 example.pdf **描述:** 本PDF文档包含了大量Perl 5的学习实例。 **标签:** Perl example #### 二、内容摘要 1. **章节1:开始你的旅程** - *...

    Java集合,HashMap底层实现和原理(1.7数组+链表与1.8+的数组+链表+红黑树) 数组和链表.pdf

    数组是HashMap的基础结构,链表是用于解决哈希冲突的问题。每个键值对组成了一个Entry实体,Entry类实际上是一个单向的链表结构,它具有Next指针,可以连接下一个Entry实体,依次来解决Hash冲突的问题。 在HashMap...

    HashMap扩容时的rehash方法中(e.hash & oldCap) == 0算法推导.docx

    `(oldCap - 1)`与`e.hash`的按位与运算结果确定了元素在旧数组的索引,而`(2 * oldCap - 1)`与`e.hash`的按位与运算结果相当于在旧索引的基础上加上旧数组长度,确保了元素被分配到新数组的不同位置。 这种分治策略...

    javascript如何判断数组内元素是否重复的方法集锦

    2. **遍历数组并检查元素**:通过 `for-in` 循环遍历数组,使用元素值作为对象的键,检查对象中是否已经存在该键。 3. **记录元素**:如果没有找到,则将该元素添加到哈希表中。 #### 方法四:使用正则表达式 此...

    unity中各种数组使用的区别

    数组是一种基本的数据结构,允许开发者存储多个元素并对其进行操作。在 Unity 中,数组可以用来存储游戏对象、玩家信息、敌人信息等。在 Unity 中,数组可以分为两大类:built-in arrays 和 collections。 Built-in...

    perl-5.32.1.tar.gz

    - **变量**:Perl支持多种类型的变量,如标量(scalar)、数组(array)、哈希(hash)等,以及引用(reference)机制,允许创建复杂的数据结构。 - **正则表达式**:Perl的正则表达式功能强大且灵活,可以进行模式...

    Perl 5教程及perl常问问题集

    数组是一系列按顺序排列的元素集合,通过索引访问,例如`$array[0]`。哈希则由键值对组成,通过键来访问值,例如`$hash{'key'}`。Perl的数组和哈希操作十分灵活,可以方便地进行遍历、添加和删除元素。 Perl的控制...

    10Ruby 数组.docx

    此外,Ruby 支持负数索引,即索引 -1 表示数组的最后一个元素,-2 表示倒数第二个元素,以此类推。 #### 四、数组的操作与管理 - **创建数组**: - 使用 `Array.new` 创建一个空数组。 ```ruby names = Array....

    数组的度(hash映射)1

    数组的度(hash映射)1 是一个关于数组处理和哈希算法的问题,主要涉及寻找具有相同最大出现频率的最短连续子数组。这个问题是基于LeetCode的一个挑战,它要求我们理解数组的特性以及如何有效地利用哈希表来解决实际...

Global site tag (gtag.js) - Google Analytics