PHP 8.5.0 Beta 3 available for testing

้…ๅˆ— ้–ขๆ•ฐ

ๅ‚่€ƒ

is_array(), explode(), implode(), preg_split(), ใŠใ‚ˆใณ join() ใ‚‚ๅ‚็…งใใ ใ•ใ„ใ€‚

็›ฎๆฌก

  • array โ€” ้…ๅˆ—ใ‚’็”Ÿๆˆใ™ใ‚‹
  • array_all โ€” array ใฎใ™ในใฆใฎ่ฆ็ด ใŒใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’ๆบ€ใŸใ™ใ‹ใฉใ†ใ‹ใ‚’่ชฟในใ‚‹
  • array_any โ€” array ใฎใ„ใšใ‚Œใ‹ใฎ่ฆ็ด ใŒใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’ๆบ€ใŸใ™ใ‹ใฉใ†ใ‹ใ‚’่ชฟในใ‚‹
  • array_change_key_case โ€” ้…ๅˆ—ใฎใ™ในใฆใฎใ‚ญใƒผใฎๅคงๆ–‡ๅญ—ๅฐๆ–‡ๅญ—ใ‚’ๅค‰ๆ›ดใ™ใ‚‹
  • array_chunk โ€” ้…ๅˆ—ใ‚’ๅˆ†ๅ‰ฒใ™ใ‚‹
  • array_column โ€” ๅ…ฅๅŠ›้…ๅˆ—ใ‹ใ‚‰ๅ˜ไธ€ใฎใ‚ซใƒฉใƒ ใฎๅ€คใ‚’่ฟ”ใ™
  • array_combine โ€” ไธ€ๆ–นใฎ้…ๅˆ—ใ‚’ใ‚ญใƒผใจใ—ใฆใ€ใ‚‚ใ†ไธ€ๆ–นใฎ้…ๅˆ—ใ‚’ๅ€คใจใ—ใฆใ€ใฒใจใคใฎ้…ๅˆ—ใ‚’็”Ÿๆˆใ™ใ‚‹
  • array_count_values โ€” ้…ๅˆ—ๅ†…ใซๅญ˜ๅœจใ™ใ‚‹ใ€็•ฐใชใ‚‹ๅ€คใฎๅ‡บ็พๅ›žๆ•ฐใ‚’ๆ•ฐใˆใ‚‹
  • array_diff โ€” ้…ๅˆ—ใฎๅทฎใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_diff_assoc โ€” ่ฟฝๅŠ ใ•ใ‚ŒใŸๆทปๅญ—ใฎ็ขบ่ชใ‚’ๅซใ‚ใฆ้…ๅˆ—ใฎๅทฎใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_diff_key โ€” ใ‚ญใƒผใ‚’ๅŸบๆบ–ใซใ—ใฆ้…ๅˆ—ใฎๅทฎใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_diff_uassoc โ€” ใƒฆใƒผใ‚ถใƒผใŒๆŒ‡ๅฎšใ—ใŸใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’ๅˆฉ็”จใ—ใ€ ่ฟฝๅŠ ใ•ใ‚ŒใŸๆทปๅญ—ใฎ็ขบ่ชใ‚’ๅซใ‚ใฆ้…ๅˆ—ใฎๅทฎใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_diff_ukey โ€” ใ‚ญใƒผใ‚’ๅŸบๆบ–ใซใ—ใ€ใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’็”จใ„ใฆ้…ๅˆ—ใฎๅทฎใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_fill โ€” ้…ๅˆ—ใ‚’ๆŒ‡ๅฎšใ—ใŸๅ€คใงๅŸ‹ใ‚ใ‚‹
  • array_fill_keys โ€” ใ‚ญใƒผใ‚’ๆŒ‡ๅฎšใ—ใฆใ€้…ๅˆ—ใ‚’ๅ€คใงๅŸ‹ใ‚ใ‚‹
  • array_filter โ€” ใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’ไฝฟ็”จใ—ใฆใ€้…ๅˆ—ใฎ่ฆ็ด ใ‚’ใƒ•ใ‚ฃใƒซใ‚ฟใƒชใƒณใ‚ฐใ™ใ‚‹
  • array_find โ€” ใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’ๆบ€ใŸใ™ๆœ€ๅˆใฎ่ฆ็ด ใ‚’่ฟ”ใ™
  • array_find_key โ€” ใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’ๆบ€ใŸใ™ๆœ€ๅˆใฎ่ฆ็ด ใฎใ‚ญใƒผใ‚’่ฟ”ใ™
  • array_flip โ€” ้…ๅˆ—ใฎใ‚ญใƒผใจๅ€คใ‚’ๅ่ปขใ™ใ‚‹
  • array_intersect โ€” ้…ๅˆ—ใฎๅ…ฑ้€š้ …ใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_intersect_assoc โ€” ่ฟฝๅŠ ใ•ใ‚ŒใŸๆทปๅญ—ใฎ็ขบ่ชใ‚‚ๅซใ‚ใฆ้…ๅˆ—ใฎๅ…ฑ้€š้ …ใ‚’็ขบ่ชใ™ใ‚‹
  • array_intersect_key โ€” ใ‚ญใƒผใ‚’ๅŸบๆบ–ใซใ—ใฆ้…ๅˆ—ใฎๅ…ฑ้€š้ …ใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_intersect_uassoc โ€” ่ฟฝๅŠ ใ•ใ‚ŒใŸๆทปๅญ—ใฎ็ขบ่ชใ‚‚ๅซใ‚ใ€ใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’็”จใ„ใฆ ้…ๅˆ—ใฎๅ…ฑ้€š้ …ใ‚’็ขบ่ชใ™ใ‚‹
  • array_intersect_ukey โ€” ใ‚ญใƒผใ‚’ๅŸบๆบ–ใซใ—ใ€ใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’็”จใ„ใฆ ้…ๅˆ—ใฎๅ…ฑ้€š้ …ใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_is_list โ€” ๆŒ‡ๅฎšใ•ใ‚ŒใŸ้…ๅˆ—ใŒใƒชใ‚นใƒˆใ‹ใฉใ†ใ‹ใ‚’ใƒใ‚งใƒƒใ‚ฏใ™ใ‚‹
  • array_key_exists โ€” ๆŒ‡ๅฎšใ—ใŸใ‚ญใƒผใพใŸใฏๆทปๅญ—ใŒ้…ๅˆ—ใซใ‚ใ‚‹ใ‹ใฉใ†ใ‹ใ‚’่ชฟในใ‚‹
  • array_key_first โ€” ้…ๅˆ—ใฎๆœ€ๅˆใฎใ‚ญใƒผใ‚’ๅพ—ใ‚‹
  • array_key_last โ€” ้…ๅˆ—ใฎๆœ€ๅพŒใฎใ‚ญใƒผใ‚’ๅพ—ใ‚‹
  • array_keys โ€” ้…ๅˆ—ใฎใ‚ญใƒผใ™ในใฆใ€ใ‚ใ‚‹ใ„ใฏใใฎไธ€้ƒจใ‚’่ฟ”ใ™
  • array_map โ€” ๆŒ‡ๅฎšใ—ใŸ้…ๅˆ—ใฎ่ฆ็ด ใซใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’้ฉ็”จใ™ใ‚‹
  • array_merge โ€” ใฒใจใคใพใŸใฏ่ค‡ๆ•ฐใฎ้…ๅˆ—ใ‚’ใƒžใƒผใ‚ธใ™ใ‚‹
  • array_merge_recursive โ€” ไธ€ใคไปฅไธŠใฎ้…ๅˆ—ใ‚’ๅ†ๅธฐ็š„ใซใƒžใƒผใ‚ธใ™ใ‚‹
  • array_multisort โ€” ่ค‡ๆ•ฐใพใŸใฏๅคšๆฌกๅ…ƒใฎ้…ๅˆ—ใ‚’ใ‚ฝใƒผใƒˆใ™ใ‚‹
  • array_pad โ€” ๆŒ‡ๅฎš้•ทใ€ๆŒ‡ๅฎšใ—ใŸๅ€คใง้…ๅˆ—ใ‚’ๅŸ‹ใ‚ใ‚‹
  • array_pop โ€” ้…ๅˆ—ใฎๆœซๅฐพใ‹ใ‚‰่ฆ็ด ใ‚’ๅ–ใ‚Š้™คใ
  • array_product โ€” ้…ๅˆ—ใฎๅ€คใฎ็ฉใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_push โ€” ไธ€ใคไปฅไธŠใฎ่ฆ็ด ใ‚’้…ๅˆ—ใฎๆœ€ๅพŒใซ่ฟฝๅŠ ใ™ใ‚‹
  • array_rand โ€” ้…ๅˆ—ใ‹ใ‚‰ไธ€ใคไปฅไธŠใฎใ‚ญใƒผใ‚’ใƒฉใƒณใƒ€ใƒ ใซๅ–ๅพ—ใ™ใ‚‹
  • array_reduce โ€” ใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’็นฐใ‚Š่ฟ”ใ—้…ๅˆ—ใซ้ฉ็”จใ—ใ€้…ๅˆ—ใ‚’ใฒใจใคใฎๅ€คใซใพใจใ‚ใ‚‹
  • array_replace โ€” ๆธกใ•ใ‚ŒใŸ้…ๅˆ—ใฎ่ฆ็ด ใ‚’็ฝฎใๆ›ใˆใ‚‹
  • array_replace_recursive โ€” ๆธกใ•ใ‚ŒใŸ้…ๅˆ—ใฎ่ฆ็ด ใ‚’ๅ†ๅธฐ็š„ใซ็ฝฎใๆ›ใˆใ‚‹
  • array_reverse โ€” ่ฆ็ด ใ‚’้€†้ †ใซใ—ใŸ้…ๅˆ—ใ‚’่ฟ”ใ™
  • array_search โ€” ๆŒ‡ๅฎšใ—ใŸๅ€คใ‚’้…ๅˆ—ใงๆคœ็ดขใ—ใ€่ฆ‹ใคใ‹ใฃใŸๅ ดๅˆใซๅฏพๅฟœใ™ใ‚‹ๆœ€ๅˆใฎใ‚ญใƒผใ‚’่ฟ”ใ™
  • array_shift โ€” ้…ๅˆ—ใฎๅ…ˆ้ ญใ‹ใ‚‰่ฆ็ด ใ‚’ไธ€ใคๅ–ใ‚Šๅ‡บใ™
  • array_slice โ€” ้…ๅˆ—ใฎไธ€้ƒจใ‚’ๅฑ•้–‹ใ™ใ‚‹
  • array_splice โ€” ้…ๅˆ—ใฎไธ€้ƒจใ‚’ๅ‰Š้™คใ—ใ€ไป–ใฎ่ฆ็ด ใง็ฝฎๆ›ใ™ใ‚‹
  • array_sum โ€” ้…ๅˆ—ใฎไธญใฎๅ€คใฎๅˆ่จˆใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_udiff โ€” ใƒ‡ใƒผใ‚ฟใฎๆฏ”่ผƒใซใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’็”จใ„ใ€้…ๅˆ—ใฎๅทฎใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_udiff_assoc โ€” ใƒ‡ใƒผใ‚ฟใฎๆฏ”่ผƒใซใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’็”จใ„ใ€ ่ฟฝๅŠ ใ•ใ‚ŒใŸๆทปๅญ—ใฎ็ขบ่ชใ‚’ๅซใ‚ใฆ้…ๅˆ—ใฎๅทฎใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_udiff_uassoc โ€” ใƒ‡ใƒผใ‚ฟใจๆทปๅญ—ใฎๆฏ”่ผƒใซใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’็”จใ„ใ€ ่ฟฝๅŠ ใ•ใ‚ŒใŸๆทปๅญ—ใฎ็ขบ่ชใ‚’ๅซใ‚ใฆ้…ๅˆ—ใฎๅทฎใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_uintersect โ€” ใƒ‡ใƒผใ‚ฟใฎๆฏ”่ผƒใซใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’็”จใ„ใ€้…ๅˆ—ใฎๅ…ฑ้€š้ …ใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_uintersect_assoc โ€” ใƒ‡ใƒผใ‚ฟใฎๆฏ”่ผƒใซใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’็”จใ„ใ€ ่ฟฝๅŠ ใ•ใ‚ŒใŸๆทปๅญ—ใฎ็ขบ่ชใ‚‚ๅซใ‚ใฆ้…ๅˆ—ใฎๅ…ฑ้€š้ …ใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_uintersect_uassoc โ€” ใƒ‡ใƒผใ‚ฟใจๆทปๅญ—ใฎๆฏ”่ผƒใซๅ€‹ๅˆฅใฎใ‚ณใƒผใƒซใƒใƒƒใ‚ฏ้–ขๆ•ฐใ‚’็”จใ„ใ€ ่ฟฝๅŠ ใ•ใ‚ŒใŸๆทปๅญ—ใฎ็ขบ่ชใ‚‚ๅซใ‚ใฆ้…ๅˆ—ใฎๅ…ฑ้€š้ …ใ‚’่จˆ็ฎ—ใ™ใ‚‹
  • array_unique โ€” ้…ๅˆ—ใ‹ใ‚‰้‡่ค‡ใ—ใŸๅ€คใ‚’ๅ‰Š้™คใ™ใ‚‹
  • array_unshift โ€” ไธ€ใคไปฅไธŠใฎ่ฆ็ด ใ‚’้…ๅˆ—ใฎๆœ€ๅˆใซๅŠ ใˆใ‚‹
  • array_values โ€” ้…ๅˆ—ใฎๅ…จใฆใฎๅ€คใ‚’่ฟ”ใ™
  • array_walk โ€” ้…ๅˆ—ใฎๅ…จใฆใฎ่ฆ็ด ใซใƒฆใƒผใ‚ถใƒผๅฎš็พฉใฎ้–ขๆ•ฐใ‚’้ฉ็”จใ™ใ‚‹
  • array_walk_recursive โ€” ้…ๅˆ—ใฎๅ…จใฆใฎ่ฆ็ด ใซใ€ใƒฆใƒผใ‚ถใƒผ้–ขๆ•ฐใ‚’ๅ†ๅธฐ็š„ใซ้ฉ็”จใ™ใ‚‹
  • arsort โ€” ้€ฃๆƒณใ‚ญใƒผใจ่ฆ็ด ใจใฎ้–ขไฟ‚ใ‚’็ถญๆŒใ—ใคใค้…ๅˆ—ใ‚’้™้ †ใซใ‚ฝใƒผใƒˆใ™ใ‚‹
  • asort โ€” ้€ฃๆƒณใ‚ญใƒผใจ่ฆ็ด ใจใฎ้–ขไฟ‚ใ‚’็ถญๆŒใ—ใคใค้…ๅˆ—ใ‚’ๆ˜‡้ †ใซใ‚ฝใƒผใƒˆใ™ใ‚‹
  • compact โ€” ๅค‰ๆ•ฐๅใจใใฎๅ€คใ‹ใ‚‰้…ๅˆ—ใ‚’ไฝœๆˆใ™ใ‚‹
  • count โ€” ้…ๅˆ—ใพใŸใฏ Countable ใ‚ชใƒ–ใ‚ธใ‚งใ‚ฏใƒˆใซๅซใพใ‚Œใ‚‹ใ™ในใฆใฎ่ฆ็ด ใฎๆ•ฐใ‚’ๆ•ฐใˆใ‚‹
  • current โ€” ้…ๅˆ—ๅ†…ใฎ็พๅœจใฎ่ฆ็ด ใ‚’่ฟ”ใ™
  • each โ€” ้…ๅˆ—ใ‹ใ‚‰็พๅœจใฎใ‚ญใƒผใจๅ€คใฎใƒšใ‚ขใ‚’่ฟ”ใ—ใฆใ€ใ‚ซใƒผใ‚ฝใƒซใ‚’้€ฒใ‚ใ‚‹
  • end โ€” ้…ๅˆ—ใฎๅ†…้ƒจใƒใ‚คใƒณใ‚ฟใ‚’ๆœ€็ต‚่ฆ็ด ใซใ‚ปใƒƒใƒˆใ™ใ‚‹
  • extract โ€” ้…ๅˆ—ใ‹ใ‚‰ใ‚ทใƒณใƒœใƒซใƒ†ใƒผใƒ–ใƒซใซๅค‰ๆ•ฐใ‚’ใ‚คใƒณใƒใƒผใƒˆใ™ใ‚‹
  • in_array โ€” ้…ๅˆ—ใซๅ€คใŒใ‚ใ‚‹ใ‹ใƒใ‚งใƒƒใ‚ฏใ™ใ‚‹
  • key โ€” ้…ๅˆ—ใ‹ใ‚‰ใ‚ญใƒผใ‚’ๅ–ใ‚Šๅ‡บใ™
  • key_exists โ€” array_key_exists ใฎใ‚จใ‚คใƒชใ‚ขใ‚น
  • krsort โ€” ้…ๅˆ—ใ‚’ใ‚ญใƒผใง้™้ †ใซใ‚ฝใƒผใƒˆใ™ใ‚‹
  • ksort โ€” ้…ๅˆ—ใ‚’ใ‚ญใƒผใงๆ˜‡้ †ใซใ‚ฝใƒผใƒˆใ™ใ‚‹
  • list โ€” ้…ๅˆ—ใจๅŒๆง˜ใฎๅฝขๅผใงใ€่ค‡ๆ•ฐใฎๅค‰ๆ•ฐใธใฎไปฃๅ…ฅใ‚’่กŒใ†
  • natcasesort โ€” ๅคงๆ–‡ๅญ—ๅฐๆ–‡ๅญ—ใ‚’ๅŒบๅˆฅใ—ใชใ„"่‡ช็„ถ้ †"ใ‚ขใƒซใ‚ดใƒชใ‚บใƒ ใ‚’็”จใ„ใฆ้…ๅˆ—ใ‚’ใ‚ฝใƒผใƒˆใ™ใ‚‹
  • natsort โ€” "่‡ช็„ถ้ †"ใ‚ขใƒซใ‚ดใƒชใ‚บใƒ ใง้…ๅˆ—ใ‚’ใ‚ฝใƒผใƒˆใ™ใ‚‹
  • next โ€” ้…ๅˆ—ใฎๅ†…้ƒจใƒใ‚คใƒณใ‚ฟใ‚’้€ฒใ‚ใ‚‹
  • pos โ€” current ใฎใ‚จใ‚คใƒชใ‚ขใ‚น
  • prev โ€” ๅ†…้ƒจใฎ้…ๅˆ—ใƒใ‚คใƒณใ‚ฟใ‚’ใฒใจใคๅ‰ใซๆˆปใ™
  • range โ€” ใ‚ใ‚‹็ฏ„ๅ›ฒใฎ่ฆ็ด ใ‚’ๅซใ‚€้…ๅˆ—ใ‚’ไฝœๆˆใ™ใ‚‹
  • reset โ€” ้…ๅˆ—ใฎๅ†…้ƒจใƒใ‚คใƒณใ‚ฟใ‚’ๅ…ˆ้ ญใฎ่ฆ็ด ใซใ‚ปใƒƒใƒˆใ™ใ‚‹
  • rsort โ€” ้…ๅˆ—ใ‚’้™้ †ใซใ‚ฝใƒผใƒˆใ™ใ‚‹
  • shuffle โ€” ้…ๅˆ—ใ‚’ใ‚ทใƒฃใƒƒใƒ•ใƒซใ™ใ‚‹
  • sizeof โ€” count ใฎใ‚จใ‚คใƒชใ‚ขใ‚น
  • sort โ€” ้…ๅˆ—ใ‚’ๆ˜‡้ †ใซใ‚ฝใƒผใƒˆใ™ใ‚‹
  • uasort โ€” ใƒฆใƒผใ‚ถใƒผๅฎš็พฉใฎๆฏ”่ผƒ้–ขๆ•ฐใง้…ๅˆ—ใ‚’ใ‚ฝใƒผใƒˆใ—ใ€้€ฃๆƒณใ‚คใƒณใƒ‡ใƒƒใ‚ฏใ‚นใ‚’ไฟๆŒใ™ใ‚‹
  • uksort โ€” ใƒฆใƒผใ‚ถใƒผๅฎš็พฉใฎๆฏ”่ผƒ้–ขๆ•ฐใ‚’็”จใ„ใฆใ€ใ‚ญใƒผใง้…ๅˆ—ใ‚’ใ‚ฝใƒผใƒˆใ™ใ‚‹
  • usort โ€” ใƒฆใƒผใ‚ถใƒผๅฎš็พฉใฎๆฏ”่ผƒ้–ขๆ•ฐใ‚’ไฝฟ็”จใ—ใฆใ€้…ๅˆ—ใ‚’ๅ€คใงใ‚ฝใƒผใƒˆใ™ใ‚‹
๏ผ‹add a note

User Contributed Notes 4 notes

up
16
permanovd at gmail dot com ยถ
7 years ago
A simple trick that can help you to guess what diff/intersect or sort function does by name.

[suffix] assoc - additional index check. Compares both value and index.

Example: array_diff_assoc, array_intersect_assoc.

[suffix] key - index only check. Ignores value of array, compares only indexes.

Example: array_diff_key, array_intersect_key.

[suffix] **empty** - no "key" or "assoc" word in suffix. Compares values only. Ignores indexes of array.

Example: array_diff, array_intersect.

[prefix] u - will do comparison with user defined function. Letter u can be used twice in some functions (like array_udiff_uassoc), this means that you have to use 2 functions (one for value, one for index).

Example: array_udiff_uassoc, array_uintersect_assoc.

This also works with array sort functions:

[prefix] a - associative. Will preserve keys.

Example: arsort, asort.

[prefix] k - key sort. Will sort array by keys.

Example: uksort, ksort.

[prefix] r - reverse. Will sort array in reverse order.

Example: rsort, krsort.

[prefix] u - sort by user defined function (same as for diff/intersect).

Example: usort, uasort.
up
8
et2225zas14 at susu dot ru ยถ
1 year ago
Be careful with type hints in callbacks when using array-traverse functions. In some cases, this may silently cause the data type of elements to change.

<?php
declare(strict_types=1);

// Missing fatal TypeError, No side effects
$unexpected = array_filter(['123', (string) PHP_INT_MAX], fn (int $item) => true);
var_dump($unexpected);

// Missing fatal TypeError, Typecasting side effect
$unexpectedTypecasting = array_map(fn (int $item) => $item, ['123', (string) PHP_INT_MAX]);
var_dump($unexpectedTypecasting);

// Missing fatal TypeError, Typecasting side effect
$unexpectedTypecasting = array_map(fn (string $item) => $item, [123, PHP_INT_MAX]);
var_dump($unexpectedTypecasting);

// Missing fatal TypeError, Typecasting side effect
$unexpectedTypecasting = array_reduce(['123', (string) PHP_INT_MAX], fn (?int $carry, int $item) => $item);
var_dump($unexpectedTypecasting);

$bigIntValue = bcadd((string) PHP_INT_MAX, '1');
// Fatal TypeError
$expectedTypeError = array_map(fn (int $item) => $item, [$bigIntValue]);
var_dump($expectedTypeError);
?>

The above example will output (PHP version 8.3.6, error_reporting E_ALL):

<?php
array(2) {
[
0]=>
string(3) "123"
[1]=>
string(19) "9223372036854775807"
}
array(
2) {
[
0]=>
int(123)
[
1]=>
int(9223372036854775807)
}
array(
2) {
[
0]=>
string(3) "123"
[1]=>
string(19) "9223372036854775807"
}
int(9223372036854775807)

Fatal error: Uncaught TypeError: {closure}(): Argument #1 ($item) must be of type int, string given
?>
up
4
renatonascto at gmail dot com ยถ
16 years ago
Big arrays use a lot of memory possibly resulting in memory limit errors. You can reduce memory usage on your script by destroying them as soon as youยดre done with them. I was able to get over a few megabytes of memory by simply destroying some variables I didnยดt use anymore.
You can view the memory usage/gain by using the funcion memory_get_usage(). Hope this helps!
up
-3
indioeuropeo at driverop dot com ยถ
6 years ago
I need to take an element from the Array and change its position within the Array by moving the rest of the elements as required.
This is the function that does it. The first parameter is the working Array. The second is the position of the element to move and the third is the position where to move the element.
The function returns the modified Array.
<?php
function array_move_elem($array, $from, $to) {
if (
$from == $to) { return $array; }
$c = count($array);
if ((
$c > $from) and ($c > $to)) {
if (
$from < $to) {
$f = $array[$from];
for (
$i = $from; $i < $to; $i++) {
$array[$i] = $array[$i+1];
}
$array[$to] = $f;
} else {
$f = $array[$from];
for (
$i = $from; $i > $to; $i--) {
$array[$i] = $array[$i-1];
}
$array[$to] = $f;
}

}
return
$array;
}

?>
Examples:
<?php
$array
= array('Cero','Uno','Dos','Tres','Cuatro','Cinco','Seis','Siete','Ocho','Nueve','Diez');
$array = array_move_elem($array, 3, 5); // Move element in position 3 to position 5...
print_r($array);

$array = array_move_elem($array, 5, 3); // Move element in position 5 to position 3, leaving array as it was... ;)
print_r($array);

?>
Return:
<?php
Array ( [0] => Cero [1] => Uno [2] => Dos [3] => Cuatro [4] => Cinco [5] => Tres [6] => Seis [7] => Siete [8] => Ocho [9] => Nueve [10] => Diez )
Array ( [
0] => Cero [1] => Uno [2] => Dos [3] => Tres [4] => Cuatro [5] => Cinco [6] => Seis [7] => Siete [8] => Ocho [9] => Nueve [10] => Diez )
?>
To Top