0

0

如何在PHP中填充数组?array_fill()和array_fill_keys()的用法

爱谁谁

爱谁谁

发布时间:2025-08-29 13:55:01

|

967人浏览过

|

来源于php中文网

原创

答案:PHP中array_fill()用于按数量填充数组,array_fill_keys()根据键名数组填充值。前者适用于创建固定长度的默认数组,后者适合以指定键名初始化数组;起始索引可为负数,影响键名范围;键名重复时后者覆盖前者;性能上array_fill()略优,但差异不大;实际应用如配置数组初始化。

如何在php中填充数组?array_fill()和array_fill_keys()的用法

在PHP中,你可以使用

array_fill()
array_fill_keys()
函数来填充数组。前者使用相同的值填充指定数量的元素,后者使用指定的值填充由键名数组指定的元素。

解决方案

array_fill()
函数允许你使用一个给定的值来填充数组的特定范围。它需要起始索引、要填充的元素数量以及用于填充的值作为参数。

$filledArray = array_fill(0, 5, 'apple');
print_r($filledArray); // 输出:Array ( [0] => apple [1] => apple [2] => apple [3] => apple [4] => apple )

这个例子从索引0开始,用'apple'填充了5个元素。

立即学习PHP免费学习笔记(深入)”;

array_fill_keys()
函数则使用一个数组作为键名,并用给定的值填充这些键名对应的元素。

$keys = ['a', 'b', 'c'];
$filledArray = array_fill_keys($keys, 'banana');
print_r($filledArray); // 输出:Array ( [a] => banana [b] => banana [c] => banana )

这里,键名'a'、'b'和'c'都被赋予了'banana'这个值。

使用场景:何时选择

array_fill()
还是
array_fill_keys()

array_fill()
更适合你需要快速创建一个具有特定大小和默认值的数组的情况,例如初始化一个用于存储结果的数组。如果你需要基于一组已知的键名来创建数组,并且所有这些键需要相同的值,那么
array_fill_keys()
是更好的选择。举个例子,假设你从数据库查询得到一组字段名,你想创建一个数组,以这些字段名为键,初始值都设为null,那么
array_fill_keys()
就非常方便。

array_fill()
的起始索引可以是负数吗?对结果有什么影响?

是的,

array_fill()
的起始索引可以是负数。这会影响数组的键名。

Napkin AI
Napkin AI

Napkin AI 可以将您的文本转换为图表、流程图、信息图、思维导图视觉效果,以便快速有效地分享您的想法。

下载
$filledArray = array_fill(-2, 4, 'orange');
print_r($filledArray); // 输出:Array ( [-2] => orange [-1] => orange [0] => orange [1] => orange )

在这个例子中,数组的键名从-2开始,而不是从0开始。这在某些需要特定键名范围的场景下可能很有用。需要注意的是,如果起始索引加上填充数量导致键名冲突,后面的值会覆盖前面的值。

如果

array_fill_keys()
的键名数组中包含重复的键,会发生什么?

如果

array_fill_keys()
的键名数组中包含重复的键,后面的键对应的值会覆盖前面的键对应的值。也就是说,最终数组中只会保留最后一个重复键对应的值。

$keys = ['a', 'b', 'a', 'c'];
$filledArray = array_fill_keys($keys, 'grape');
print_r($filledArray); // 输出:Array ( [a] => grape [b] => grape [c] => grape )

尽管'a'出现了两次,但最终数组中'a'只对应一个'grape'值。

性能考量:

array_fill()
array_fill_keys()
哪个更快?

通常来说,

array_fill()
的性能略优于
array_fill_keys()
,因为它只需要处理数字索引,而
array_fill_keys()
需要处理键名数组的遍历和查找。但在大多数实际应用中,这种性能差异可以忽略不计,除非你需要填充非常大的数组。更重要的是选择适合你特定场景的函数。例如,如果你已经有了一个键名数组,使用
array_fill_keys()
会更简洁明了。

一个实际的例子:初始化配置数组

假设你需要创建一个配置数组,其中包含一些默认值。你可以使用

array_fill_keys()
来轻松地实现这一点。

$configKeys = ['debug', 'log_level', 'cache_enabled'];
$defaultConfig = array_fill_keys($configKeys, false);

// 假设从配置文件中读取了一些配置项
$configFile = ['debug' => true, 'log_level' => 'warning'];

// 合并配置项,配置文件中的值会覆盖默认值
$config = array_merge($defaultConfig, $configFile);

print_r($config);
// 输出:Array ( [debug] => 1 [log_level] => warning [cache_enabled] => )

这个例子展示了如何使用

array_fill_keys()
创建一个包含默认配置的数组,然后使用
array_merge()
将配置文件中的值合并到该数组中。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

254

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1089

2024.03.01

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

389

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2112

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

357

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

259

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

329

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

420

2023.10.16

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.4万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号