phpclosure
⑴ php7 有什麼實用的新功能沒
1.在use語句增加了group支持;
2.增加??操作符;
3. 64位PHP7字元串長度可以超過2^31次方位元組;
4.增加Closure::call支持
Closure::call將一個閉包函數動態綁定到一個新的對象實例並調用執行該函數;
5.雙引號字元串和heredocs裡面支持使用\u{xxxxx}來聲明unicode字元;
6.define對數組的支持;
7.增加比較運算符<=>;
8.php全局保留字可以聲明使用
include關鍵字可以當普通字元串關鍵字一樣被使用
9.標量類型(int,float,string,bool)支持
增加declare(strict_types=1)指令聲明是否嚴格類型校驗,
當在文件頭聲明declare(strict_types=1)
10.增加介面為用戶層提供安全方便的隨機數生成器。RFC: https://wiki.php.net/rfc/easy_userland_csprng (後續再議)
11.增加了yield from 操作符。
⑵ php如何序列化/存儲閉包(Closure)
實在需要序列化,可以用反射(Reflection),並直接操作代碼文件獲得上下文信息:/*** 創建一個反射:*/$reflection = new ReflectionFunction($closure);/*** 參數可以直接得到了:*/$params = $reflection-getParameters();/*** 獲得Closure的函數體和use變數,形如: * function($arg1, $arg2, ...) use ($val1, $val2, ...) { * // 要獲得這個部分的代碼!* }* 辦法很多,你可以直接用正則、字元串查找或者Tokenizer,等等等等。 * 比如可以先從reflection里得到函數的開始行和結束行:*/$startLine = $reflection-getStartLine(); $endLine = $reflection-getEndLine(); // 然後用str*這個,str*那個的函數來清理,細節不寫了:
⑶ php closure是如何實現的
就是匿名方法 Anonymous function:
call_user_func(function(){echo'hellophp';});
⑷ 如何實際使用PHP5.3閉包語法特性
PHP 5.3閉包語法就是一個匿名函數,可以為開發者帶來很多不同的體驗。與JavaScript的閉包相比稍微有點不同,可以這樣使用PHP 5.3閉包語法 $closure = function($param) { echo $param; }; //This one takes value of someVar and "stores" it in
⑸ 如何實際使用PHP5.3閉包語法特性
PHP 5.3閉包語法就是一個匿名函數,可以為開發者帶來很多不同的體驗。與JavaScript的閉包相比稍微有點不同,可以這樣使用PHP 5.3閉包語法
$closure = function($param) { echo $param; };
//This one takes value of someVar and "stores" it in the closure's scope even if
//we later change the value of someVar outside it. We assume that $somerVar is defined before this
$closure2 = function($param) use ($someVar) { echo $param . ' ' . $someVar; };
比如PHP 5.3閉包語法在輸出HTML中閉包很有用:
function item_list(array $items, $formatter = null) {
//create the default formatter
if($formatter == null) {
$formatter = function($row) {
return '<p>' . $row . '</p>';
};
}
$html = '<h2>Listing:</h2>';
foreach($items as $item) {
$html .= $formatter($item);
}
return $html;
}
以上就是介紹的兩種不同的PHP 5.3閉包語法的使用
⑹ php中怎麼類外訪問私有方法
你問的是私有方法還是私有屬性?
你說的__get __set 是訪問和設置屬性用的。
__call才是訪問方法用的。
但這兩種都需要修改原始類,既然有這個許可權了,那私有方法有什麼必要定義呢?
另外一種獲取私有屬性或調用私有方法的思路是通過反射:
//MyClass這個類中包含了一個名為myFun的私有方法
classMyClass{
private$tmp='hello';
privatefunctionmyFun()
{
echo$this->tmp.''.'world!';
}
}
//通過類名MyClass進行反射
$ref_class=newReflectionClass('MyClass');
//通過反射類進行實例化
$instance=$ref_class->newInstance();
//通過方法名myFun獲取指定方法
$method=$ref_class->getMethod('myFun');
//設置可訪問性
$method->setAccessible(true);
//執行方法
$method->invoke($instance);
//獲取屬性
$property=$ref_class->getProperty('tmp');
//列印屬性
var_mp($property);
不知道你提這個單純是個問題,還是有別的需求,可以多看看php手冊學習一下。
php 訪問控制
php 反射
⑺ PHP閉包函數傳參及使用外部變數的方法
本文實例講述了PHP閉包函數傳參及使用外部變數的方法。分享給大家供大家參考,具體如下:
在Laravel控制器寫兩個方法,一個是在內部創建一個閉包函數,一個是執行傳過來的閉包函數,測試閉包的寫法,use使用外部變數,及閉包函數的傳參。如下:
//測試閉包傳參及use使用外部變數
public
function
testClosure($t1,
$t2)
{
$closure
=
function
($param1,
$param2)
use
($t1,
$t2)
{
echo
$param1.$param2.$t1.$t2;
};
$this->execClosure('test.closure',
$closure);
}
//執行閉包函數
protected
function
execClosure($name,
Closure
$closure)
{
echo
'Closure
func
name:'.$name;
echo
'<br>';
$closure('p1',
'p2');
}
在routes.php添加路由:
復制代碼
代碼如下:Route::get('/test/closure/{t1}/{t2}',['uses'=>'TestController@testClosure']);
訪問www.example.com/test/closure/hehe1/hehe2
瀏覽器輸出結果:
Closure
func
name:test.closure
p1p2hehe1hehe2
轉自:小談博客
http://www.tantengvip.com/2016/03/php-closure-use/
更多關於PHP相關內容感興趣的讀者可查看本站專題:《php操作office文檔技巧總結(包括word,excel,access,ppt)》、《php日期與時間用法總結》、《php面向對象程序設計入門教程》、《php字元串(string)用法總結》、《php+mysql資料庫操作入門教程》及《php常見資料庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
⑻ Php7有哪些新特性
PHP 7.4 的主要特性包括以下幾個,
短閉包函數(short closure) 預載入提交性能 屬性類型限定 Improved type variance(不會翻譯) 三元運算簡寫 數組展開運算 新增類的魔術方法:serialization 數字分隔符 運算優先順序 允許在__toString中拋出異常 支持反射引用 新增位元組分割函數 移除php短標簽 棄用左關聯運算符 不再向後兼容的變更 短閉包函數短閉包函數可以減少冗餘代碼:
array_map(function (User $user) { return $user->id; }, $users) array_map(fn(User $user) => $user->id, $users)需要注意幾點:
短閉包可以直接訪問閉包函數外面的變數,所以不需要再寫?use?關鍵詞 以fn關鍵詞開始 $this?可以像普通的閉包一樣使用 短閉包只有一行代碼,僅僅做返回聲明使用,不允許使用return?關鍵詞還可以使用更嚴格類型的方式
$ids = array_map(fn(User $user): int => $user->id, $user); 預載入PHP預載入可以極大的提高性能
優點:在PHP 7.4以前,如果你使用了框架來開發,每次請求文件就必須載入和重新編譯。預載入在框架啟動時在內存中載入文件,而且在後續請求中永久有效。
缺點:性能的提升會在其他方面花費很大的代價,每次預載入的文件發生改變時,框架需要重新啟動。
屬性類型限定 class A { public string $name; public Foo $foo; }不得不說,PHP越來越接近Java等強類型語言
Improved type variance協變返回類型:
class ParentType {} class ChildType extends ParentType {} class A { public function covariantReturnTypes(): ParentType { /* … */ } } class B extends A { public function covariantReturnTypes(): ChildType { /* … */ } }依賴(是不是很熟悉):
class ParentType {} class ChildType extends ParentType {} class A { public function covariantReturnTypes(): ParentType { /* … */ } } class B extends A { public function covariantReturnTypes(): ChildType { /* … */ } } 簡寫三元運算符在目前> PHP 7以後的寫法:
$data['date'] = $data['date'] ?? new DateTime(); 在PHP 7.4你可以這樣寫: $data['date'] ??= new DateTime(); 數組展開運算合並數組到另一個數組中,返回一維數組
$arrayA = [1, 2, 3]; $arrayB = [4, 5]; $result = [0, ...$arrayA, ...$arrayB, 6 ,7]; // [0, 1, 2, 3, 4, 5, 6, 7]注意? :只對數字索引有效
新增類的魔術方法RFC添加了兩個新的魔術方法__serialize和__unserialize
數字分隔符允許使用下劃線更直觀的分隔數值
$unformattedNumber = 107925284.88; $formattedNumber = 107_925_284.88; 運算優先順序PHP 7.4之前,如果你這樣寫:
echo "sum: " . $a + $b; PHP會解析為: echo ("sum: " . $a) + $b; PHP 8將會解析為: echo "sum :" . ($a + $b); __toString中拋出異常支持反射引用PHP 7.4將會新增ReflectionReference?類
移除php短標簽<?將會在PHP 8中移除,<?=會繼續保留
棄用左關聯運算符PHP遺留了一些奇怪的怪癖,比如
1 ? 2 : 3 ? 4 : 5; // 將會在 PHP 7.4 中廢棄,在 PHP 8中會拋出編譯錯誤 (1 ? 2 : 3) ? 4 : 5; // 正確 不再向後兼容的變更 棄用在沒有父類的情況下調用parent:: 調用var_mp列印DateTime和DateTimeImmutableshi』實例,將不再保留對象上的可訪問屬性 openssl_random_pseudo_bytes?會在調用錯誤時拋出異常 序列化PDO和PDOStatement?實例將會生成一個Exception而不是PDOException異常 調用get_object_vars()列印ArrayObject?實例將會返回ArrayObject?自己的屬性,而不是被包裹的數組或對象的值,數組強制轉換不受影響
⑼ php方法中如何獲取閉包的值
親,你好,很高興為你解答該問題
首先,你的這個寫法是有問題的哦!~
classA{
publicfunctionaa(){
//函數體為空,所以外面不會有任何輸出,即使設置變數來接受該方法,也不會有任何返回
//所以你肯定拿不到123
}
}
$a=newA;
$a->aa(function(){//aa方法是不接受任何參數的,這個傳了閉包進去
return123;
});
要想拿到閉包中的123,你需要這樣寫才可以呦~~
classA{
publicfunctionaa($closure){//aa方法接受一個閉包函數進來
return$closure(123);//調用閉包函數,傳入相應參數,並將閉包返回的值再次返回出去
}
}
$a=newA;
$b=$a->aa(function($param){//給aa傳入一個帶一個參數的閉包
return$param;//閉包方法返回傳入的參數
});
var_mp($b);
希望可以幫到你,給我個採納呦!~~
⑽ php callable和closure的區別
回調函數就是一個通過函數指針調用的函數。如果你把函數的指針(地址)作為參數傳遞給另一個函數,當這個指針被用來調用其所指向的函數時,我們就說這是回調函數。回調函數不是由該函數的實現方直接調用,而是在特定的事件或條件發生時由另外的.