首頁 後端開發 PHP問題 php裡箭頭什麼意思

php裡箭頭什麼意思

Nov 03, 2022 am 09:25 AM
php 箭頭函數

php裡箭頭是一種箭頭函數,是用php編寫的短函數,當向函數中傳遞閉包時,這個功能是很有用,其使用語法如“$posts = [/* … */];$ids = array_map(fn($post) => $post->id, $posts);」。

php裡箭頭什麼意思

本教學操作環境:windows7系統、PHP8.1版、Dell G3電腦。

php裡箭頭什麼意思?

PHP 7.4 新語法之箭頭函數實例詳解

短閉包,也叫做箭頭函數,是一種用php 寫的短函數.當傳送閉包時,這個功能是非常有用的,例如使用array_map 或是array_filter函數時.

#這就是它們看起來的樣子:

// Post 对象的集合
$posts = [/* … */];
$ids = array_map(fn($post) => $post->id, $posts);
登入後複製

而以前,你必須這樣寫:

$ids = array_map(function ($post) {
  return $post->id;
}, $posts);
登入後複製

我們來總結一下短閉包函數如何使用.

在PHP 7.4 裡可用

    ##以fn 關鍵字開頭
  • 只能包含一個表達式, 即傳回表達式
  • return 關鍵字可忽略
  • 參數與傳回型別皆可做型別暗示
上面範例更嚴格的型別限定寫法可寫:

$ids = array_map(fn(Post $post): int => $post->id, $posts) ;

有兩點要提及:

    也允許使用擴充運算子
  • 允許引用,兩個參數都可以當作傳回值
假如你想要透過引用的方式回傳結果,應該使用下列語法:

fn&($x) => $x

簡而言之,除了只允許一個表達式以外,簡短的閉包和普通閉包的功能是一樣的。

單行

你應該正確的理解它:短閉包只能有一個表達式。這意味著閉包體中不能有多行。

原因如下:短閉包的目的是為了減少冗餘。當然,在任何情況下, fn 都比 function 短。然而, RFC 的創建者 Nikita Popov 認為,如果你要處理的是多行表達式的函數,那麼使用閉包獲得的益處就更少了。

畢竟,多行閉包的定義已經很冗餘了,所以,有和沒有這2個關鍵字( function 和 return )將不會有太大差別。

你是否同意這個觀點取決於你自己。雖然我可以在我的專案中想到很多單行閉包的場景,但也有很多多行閉包的情況,從個人角度,我會喜歡這些情況下的簡短語法。

不過還是有希望的:未來可能會增加多行短閉包,但那也是一個單獨的 RFC 。

外部作用域的值

短閉包和普通閉包的另一個顯著特徵是,短閉包不需要用use關鍵字就能存取外部作用域的資料。

$modifier = 5;
array_map(fn($x) => $x * $modifier, $numbers);
登入後複製

要注意的是,不能修改外部範圍中的變數。因為它屬於值傳遞而不是引用傳遞。這意味著你可以改變短閉包內的

$modifier 變量,但它不會對外部作用域中的 $modifier 變數產生影響。

當然,有一個例外,那就是$this 關鍵字,它的作用與普通閉包中的作用完全相同:

array_map(fn($x) => ; $x * $this->modifier, $numbers);

#發展前景

我已經提過的多行閉包仍然是將來的一個發展可能。另一個在我腦海中的想法就是在允許在類中使用短閉包,比如getters 和setters 函數.

class Post {
  private $title;

  fn getTitle() => $this->title;
}
登入後複製
總而言之,短閉包是一個很受歡迎的特性,儘管有很多地方需要提高.其中最有可能就是多行閉包了.

推薦學習:《

PHP視頻教程#

以上是php裡箭頭什麼意思的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1677
14
CakePHP 教程
1431
52
Laravel 教程
1334
25
PHP教程
1280
29
C# 教程
1257
24
繼續使用PHP:耐力的原因 繼續使用PHP:耐力的原因 Apr 19, 2025 am 12:23 AM

PHP仍然流行的原因是其易用性、靈活性和強大的生態系統。 1)易用性和簡單語法使其成為初學者的首選。 2)與web開發緊密結合,處理HTTP請求和數據庫交互出色。 3)龐大的生態系統提供了豐富的工具和庫。 4)活躍的社區和開源性質使其適應新需求和技術趨勢。

如果session_start()被多次調用會發生什麼? 如果session_start()被多次調用會發生什麼? Apr 25, 2025 am 12:06 AM

多次調用session_start()會導致警告信息和可能的數據覆蓋。 1)PHP會發出警告,提示session已啟動。 2)可能導致session數據意外覆蓋。 3)使用session_status()檢查session狀態,避免重複調用。

IIS和PHP的兼容性:深度潛水 IIS和PHP的兼容性:深度潛水 Apr 22, 2025 am 12:01 AM

IIS和PHP可以兼容,通過FastCGI實現。 1.IIS通過配置文件將.php文件請求轉發給FastCGI模塊。 2.FastCGI模塊啟動PHP進程處理請求,提高性能和穩定性。 3.實際應用中需注意配置細節、錯誤調試和性能優化。

作曲家:通過AI的幫助開發PHP 作曲家:通過AI的幫助開發PHP Apr 29, 2025 am 12:27 AM

AI可以幫助優化Composer的使用,具體方法包括:1.依賴管理優化:AI分析依賴關係,建議最佳版本組合,減少衝突。 2.自動化代碼生成:AI生成符合最佳實踐的composer.json文件。 3.代碼質量提升:AI檢測潛在問題,提供優化建議,提高代碼質量。這些方法通過機器學習和自然語言處理技術實現,幫助開發者提高效率和代碼質量。

session_start()函數的意義是什麼? session_start()函數的意義是什麼? May 03, 2025 am 12:18 AM

session_start()iscucialinphpformanagingusersessions.1)ItInitiateSanewsessionifnoneexists,2)resumesanexistingsessions,and3)setsasesessionCookieforContinuityActinuityAccontinuityAcconActInityAcconActInityAcconAccRequests,EnablingApplicationsApplicationsLikeUseAppericationLikeUseAthenticationalticationaltication and PersersonalizedContentent。

使用Laravel:使用PHP簡化Web開發 使用Laravel:使用PHP簡化Web開發 Apr 19, 2025 am 12:18 AM

Laravel優化Web開發流程的方法包括:1.使用路由系統管理URL結構;2.利用Blade模板引擎簡化視圖開發;3.通過隊列處理耗時任務;4.使用EloquentORM簡化數據庫操作;5.遵循最佳實踐提高代碼質量和可維護性。

PHP和IIS:讓他們一起工作 PHP和IIS:讓他們一起工作 Apr 21, 2025 am 12:06 AM

在IIS上配置和運行PHP需要以下步驟:1)下載並安裝PHP,2)配置IIS並添加FastCGI模塊,3)創建並設置應用池,4)創建網站並綁定到應用池。通過這些步驟,你可以在Windows服務器上輕鬆部署PHP應用,並通過配置擴展和優化性能來提升應用的穩定性和效率。

如何使用MySQL的函數進行數據處理和計算 如何使用MySQL的函數進行數據處理和計算 Apr 29, 2025 pm 04:21 PM

MySQL函數可用於數據處理和計算。 1.基本用法包括字符串處理、日期計算和數學運算。 2.高級用法涉及結合多個函數實現複雜操作。 3.性能優化需避免在WHERE子句中使用函數,並使用GROUPBY和臨時表。

See all articles