function counter($d=0) {
$counter = 1+$d;
return function() use(&$counter) {return $counter ++;};
}
$a = counter();
echo $a(); //1
echo $a(); //2
问题:
$a = counter(); //返回闭合函数; 函数执行完毕删除所有内部变量;
ref=2? 好吧等于2; 删除一个; 还有一次引用;
函数内部的变量是局域的,内存地址可以公开使用??????????
搞不明白,局部变量的内存地址怎么可以变成全局的;
echo $a(); //1
echo $a(); //2
我不太理解,请详细的回答下;研究了2小时没研究明白;
----------
function aaa() { $a =1; return function() use(&$a) {return $a ++;}; //该$a继承父作用域的$a内存地址; } //首先返回的是一个闭合函数: function() use (&$a) {return $a ++;} //函数嵌套函数,当外层函数执行时,其内部函数变成全局作用域; //闭合函数: 拥有 $a内存的控制权;同时又是全局函数; 有点...... $a = aaa(); //aaa()执行完毕,清空变量,因&引用,ref_count -1 ,不释放内存; echo $a(); //1; echo $a(); //2;
我乱写的,也不知道分析的对不对,请修正指教;
回复讨论(解决方案)
用什么不理解的?
既然你 use( &$counter) 那当然是要知道这么做的后果的,因为那个 & ,规则就发生了变化
既然是引用,就是两个及以上变量指向同一数据区,删除一个,其他的还在
js的闭包挺流行,但貌似php很少...
匿名函数赋给$a后,等价于诞生了一个全局函数,但这不是重点...
use中的$counter如果只是拷贝调用,在$a = $counter();的赋值过后,内存也就释放了
偏偏是指针...所以那块内存在这个匿名函数中留了下来
此时匿名函数中的$counter只属于$a,如果你再令$b = counter();,会有另一个独立的$counter

PHPsessionscanstorestrings,numbers,arrays,andobjects.1.Strings:textdatalikeusernames.2.Numbers:integersorfloatsforcounters.3.Arrays:listslikeshoppingcarts.4.Objects:complexstructuresthatareserialized.

TostartaPHPsession,usesession_start()atthescript'sbeginning.1)Placeitbeforeanyoutputtosetthesessioncookie.2)Usesessionsforuserdatalikeloginstatusorshoppingcarts.3)RegeneratesessionIDstopreventfixationattacks.4)Considerusingadatabaseforsessionstoragei

Session regeneration refers to generating a new session ID and invalidating the old ID when the user performs sensitive operations in case of session fixed attacks. The implementation steps include: 1. Detect sensitive operations, 2. Generate new session ID, 3. Destroy old session ID, 4. Update user-side session information.

PHP sessions have a significant impact on application performance. Optimization methods include: 1. Use a database to store session data to improve response speed; 2. Reduce the use of session data and only store necessary information; 3. Use a non-blocking session processor to improve concurrency capabilities; 4. Adjust the session expiration time to balance user experience and server burden; 5. Use persistent sessions to reduce the number of data read and write times.

PHPsessionsareserver-side,whilecookiesareclient-side.1)Sessionsstoredataontheserver,aremoresecure,andhandlelargerdata.2)Cookiesstoredataontheclient,arelesssecure,andlimitedinsize.Usesessionsforsensitivedataandcookiesfornon-sensitive,client-sidedata.

PHPidentifiesauser'ssessionusingsessioncookiesandsessionIDs.1)Whensession_start()iscalled,PHPgeneratesauniquesessionIDstoredinacookienamedPHPSESSIDontheuser'sbrowser.2)ThisIDallowsPHPtoretrievesessiondatafromtheserver.

The security of PHP sessions can be achieved through the following measures: 1. Use session_regenerate_id() to regenerate the session ID when the user logs in or is an important operation. 2. Encrypt the transmission session ID through the HTTPS protocol. 3. Use session_save_path() to specify the secure directory to store session data and set permissions correctly.

PHPsessionfilesarestoredinthedirectoryspecifiedbysession.save_path,typically/tmponUnix-likesystemsorC:\Windows\TemponWindows.Tocustomizethis:1)Usesession_save_path()tosetacustomdirectory,ensuringit'swritable;2)Verifythecustomdirectoryexistsandiswrita


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

Notepad++7.3.1
Easy-to-use and free code editor

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

Dreamweaver CS6
Visual web development tools
