Heim Backend-Entwicklung PHP-Tutorial php中 -> 和 => 和 :: 的用法

php中 -> 和 => 和 :: 的用法

Jun 23, 2016 pm 01:27 PM

=> <br />数组中 用于数组的 key 和 value之间的关系<br />例如:<br />$a = array(<br />  '0' => '1',<br />  '2' => '4',<br />);<br /><br />echo $a['0'];<br />echo $a['2'];<br /><br /><br />-> <br />类中 用于引用类实例的方法和属性<br />例如:<br />class Test{<br />    function add(){return $this->var++;}<br />    var $var = 0;<br />}<br /><br />$a = new Test(); //实例化对象名称<br />echo $a->add();<br />echo $a->var;<br /><br /><br />::<br />类中 静态方法和静态属性的引用方法<br />例如<br />class Test{<br />    public static function test(){<br />    public static $test = 1;<br />   }<br />}<br /><br />类的静态方法和静态属性可以不用实例化对象直接使用(使用的方式是 类名::静态方法名 )<br /><br />Test::test(); 调用静态方法test<br />Test::$test;  来取得$test静态属性的值<br /><br />注:<br />静态方法在读到这个类或者引入这个类文件的时候,就已经实例化并存放到内存中了,非静态类则需要new一下。<br />静态类在内存中即使有多个实例,静态的属性也只有一份。<br /><br /><br /><br />=============================self是引用静态类的类名,而$this是引用非静态类的实例名===========<br /><br /><br /><br />static 的属性和方法,只能访问static的属性和方法,不能类访问非静态的属性和方法。因为静态属性和方法被创建时,可能还没有任何这个类的实例可以被调<br /><br />	用。<br /><br />	static的属性,在内存中只有一份,为所有的实例共用。<br /><br />	使用self:: 关键字访问当前类的静态成员。<br /><br />	一个类的所有实例,共用类中的静态属性。<br /><br />	也就是说,在内存中即使有多个实例,静态的属性也只有一份。<br /><br />	下面例子中的设置了一个计数器$count属性,设置private 和 static 修饰。<br /><br />	这样,外界并不能直接访问$count属性。而程序运行的结果我们也看到多个实例在使用同一个静态的$count 属性。<br /><br />	<?php     <br />	class user   <br />	{     <br />	    private static $count = 0 ; //记录所有用户的登录情况.     <br />	    public function __construct() {     <br />	        self::$count = self::$count + 1;     <br />	    }     <br />	    public function getCount() {       <br />	        return self::$count;     <br />	    }     <br />	    public function __destruct() {     <br />	        self::$count = self::$count - 1;     <br />	    }     <br />	}     <br />	$user1 = new user();     <br />	$user2 = new user();     <br />	$user3 = new user();     <br />	echo "now here have " . $user1->getCount() . " user";     <br />	echo "<br />";     <br />	unset($user3);     <br />	echo "now here have " . $user1->getCount() . " user";     <br />	?>    <br /><br />	静态属性直接调用<br />	静态属性不需要实例化就可以直接使用,在类还没有创建时就可以直接使用。<br /><br />	使用的方式是: 类名::静态属性名<br /><br />	<?php     <br />	class Math   <br />	{     <br />	    public static $pi = 3.14;     <br />	}     <br />	// 求一个半径3的园的面积。     <br />	$r = 3;     <br />	echo "半径是 $r 的面积是<br />";     <br />	echo Math::$pi * $r * $r;     <br />	echo "<br /><br />";     <br />	//这里我觉得 3.14 不够精确,我把它设置的更精确。     <br />	Math::$pi = 3.141592653589793;     <br />	echo "半径是 $r 的面积是<br />";     <br />	echo Math::$pi * $r * $r;      <br />	?>    <br /><br /><br />	类没有创建,静态属性就可以直接使用。那静态属性在什么时候在内存中被创建? 在PHP中没有看到相关的资料。引用Java中的概念,来解释应该也具有通用性<br /><br />	。静态属性和方法,在类被调用时创建。<br /><br />	静态方法<br />	静态方法不需要所在类被实例化就可以直接使用。<br /><br />	使用的方式是类名::静态方法名<br /><br />	下面我们继续写这个Math类,用来进行数学计算。我们设计一个方法用来算出其中的最大值。既然是数学运算,我们也没有必要去实例化这个类,如果这个方法<br /><br />	可以拿过来就用就方便多了。我们这只是为了演示static方法而设计的这个类。在PHP提供了 max() 函数比较数值。<br /><br />	view plaincopy to clipboardprint?<br />	<?php     <br />	class Math   <br />	{     <br />	    public static function Max($num1, $num2) {     <br />	        return $num1 > $num2 ? $num1 : $num2;     <br />	    }          <br />	}     <br />	$a = 99;     <br />	$b = 88;     <br />	echo "显示 $a 和 $b 中的最大值是";     <br />	echo "<br />";     <br />	echo Math::Max($a, $b);     <br />	echo "<br />";   <br />	echo "<br />";   <br />	echo "<br />";     <br />	$a = 99;     <br />	$b = 100;     <br />	echo "显示 $a 和 $b 中的最大值是";     <br />	echo "<br />";     <br />	echo Math::Max($a,$b);     <br />	?>   <br /><br />	静态方法如何调用静态方法<br />	第一个例子,一个静态方法调用其它静态方法时,使用self:: <br /><br />	<?php     <br />	// 实现最大值比较的Math类。     <br />	class Math   <br />	{     <br />	    public static function Max($num1, $num2) {     <br />	        return $num1 > $num2 ? $num1 : $num2;     <br />	    }     <br />	    public static function Max3($num1, $num2, $num3) {     <br />	        $num1 = self::Max($num1, $num2);     <br />	        $num2 = self::Max($num2, $num3);     <br />	        $num1 = self::Max($num1, $num2);             <br />	        return $num1;     <br />	    }     <br />	}     <br />	$a = 99;     <br />	$b = 77;     <br />	$c = 88;     <br />	echo "显示 $a $b $c 中的最大值是";     <br />	echo "<br />";     <br />	echo Math::Max3($a, $b, $c);     <br />	?> <br /><br /><br /><br />	静态方法调用静态属性<br />	使用self:: 调用本类的静态属性。<br /><br />	<?php     <br />	//      <br />	class Circle   <br />	{     <br />	    public static $pi = 3.14;     <br />	    public static function circleAcreage($r) {     <br />	        return $r * $r * self::$pi;     <br />	    }     <br />	}     <br />	$r = 3;     <br />	echo " 半径 $r 的圆的面积是 " . Circle::circleAcreage($r);     <br />	?>    <br /><br /><br />	静态方法不能调用非静态属性 。不能使用self::调用非静态属性。 <br /><br />	<?php     <br />	// 这个方式是错误的     <br />	class Circle   <br />	{     <br />	    public $pi = 3.14;     <br />	    public static function circleAcreage($r) {     <br />	        return $r * $r * self::pi;     <br />	    }     <br />	}     <br />	$r = 3;     <br />	echo " 半径 $r 的圆的面积是 " . Circle::circleAcreage($r);     <br />	?>   <br /><br /><br />	也不能使用 $this 获取非静态属性的值。<br /><br />	静态方法调用非静态方法<br />	PHP5中,在静态方法中不能使用 $this 标识调用非静态方法。<br /><br />	<?php   <br />	// 实现最大值比较的Math类。     <br />	class Math   <br />	{         <br />	    public function Max($num1, $num2) {     <br />	        echo "bad<br />";             <br />	        return $num1 > $num2 ? $num1 : $num2;     <br />	    }     <br />	    public static function Max3($num1, $num2, $num3) {     <br />	        $num1 = $this->Max($num1, $num2);     <br />	        $num2 = $this->Max($num2, $num3);     <br />	        $num1 = $this->Max($num1, $num2);             <br />	        return $num1;     <br />	    }     <br />	}     <br />	$a = 99;     <br />	$b = 77;     <br />	$c = 188;     <br />	echo "显示 $a $b $c 中的最大值是";     <br />	echo "<br />";     <br />	echo Math::Max3($a, $b, $c);    //同样的这个会报错    <br />	?>   <br /><br />	当一个类中有非静态方法被self:: 调用时,系统会自动将这个方法转换为静态方法。<br /><br />	<?php     <br />	// 实现最大值比较的Math类。     <br />	class Math   <br />	{         <br />	    public function Max($num1, $num2) {            <br />	        return $num1 > $num2 ? $num1 : $num2;     <br />	    }     <br />	    public static function Max3($num1, $num2, $num3) {     <br />	        $num1 = self::Max($num1, $num2);     <br />	        $num2 = self::Max($num2, $num3);     <br />	        $num1 = self::Max($num1, $num2);             <br />	        return $num1;     <br />	    }     <br />	}     <br />	$a = 99;     <br />	$b = 77;     <br />	$c = 188;     <br />	echo "显示 $a $b $c 中的最大值是";     <br />	echo "<br />";     <br />	echo Math::Max3($a, $b, $c);     <br />	?><br /><br />---------------------------------------------<br />php中this的含义<br /><br /><br />下面定义了一个Cart类<br /><?php<br />class Cart<br />{<br /> var $items; // 购物车中的项目<br /><br /> // 把 $num 个 $artnr 放入车中<br /><br /> function add_item ($artnr, $num)<br /> {<br /> $this->items[$artnr] += $num;<br /> }<br /><br /> // 把 $num 个 $artnr 从车中取出<br /><br /> function remove_item ($artnr, $num)<br /> {<br /> if ($this->items[$artnr] > $num) {<br /> $this->items[$artnr] -= $num;<br /> return true;<br /> } else {<br /> return false;<br /> }<br /> }<br />}<br />?><br />以一段代码说明问题,在一个类的定义内部,你无法得知使用何种名称的对象是可以访问的:在编写 Cart 类时,并不知道之后对象的名称将会命名为 $cart 或者 $another_cart。因而你不能在类中使用 $cart->items。然而为了类定义的内部访问自身的函数和变量,可以使用伪变量 $this 来达到这个目的。$this 变量可以理解为“我自己的”或者“当前对象”。因而 '$this->>items[$artnr] += $num' 可以理解为“我自己的物品数组的 $artnr 计数器加 $num”或者“在当前对象的物品数组的 $artnr 计数器加 $num”。<br />
Nach dem Login kopieren




Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Arbeiten mit Flash -Sitzungsdaten in Laravel Arbeiten mit Flash -Sitzungsdaten in Laravel Mar 12, 2025 pm 05:08 PM

Laravel vereinfacht die Behandlung von temporären Sitzungsdaten mithilfe seiner intuitiven Flash -Methoden. Dies ist perfekt zum Anzeigen von kurzen Nachrichten, Warnungen oder Benachrichtigungen in Ihrer Anwendung. Die Daten bestehen nur für die nachfolgende Anfrage standardmäßig: $ Anfrage-

Curl in PHP: So verwenden Sie die PHP -Curl -Erweiterung in REST -APIs Curl in PHP: So verwenden Sie die PHP -Curl -Erweiterung in REST -APIs Mar 14, 2025 am 11:42 AM

Die PHP Client -URL -Erweiterung (CURL) ist ein leistungsstarkes Tool für Entwickler, das eine nahtlose Interaktion mit Remote -Servern und REST -APIs ermöglicht. Durch die Nutzung von Libcurl, einer angesehenen Bibliothek mit Multi-Protokoll-Dateien, erleichtert PHP Curl effiziente Execu

Vereinfachte HTTP -Reaktion verspottet in Laravel -Tests Vereinfachte HTTP -Reaktion verspottet in Laravel -Tests Mar 12, 2025 pm 05:09 PM

Laravel bietet eine kurze HTTP -Antwortsimulationssyntax und vereinfache HTTP -Interaktionstests. Dieser Ansatz reduziert die Code -Redundanz erheblich, während Ihre Testsimulation intuitiver wird. Die grundlegende Implementierung bietet eine Vielzahl von Verknüpfungen zum Antworttyp: Verwenden Sie Illuminate \ Support \ facades \ http; Http :: fake ([ 'Google.com' => 'Hallo Welt',, 'github.com' => ['foo' => 'bar'], 'Forge.laravel.com' =>

12 Beste PHP -Chat -Skripte auf Codecanyon 12 Beste PHP -Chat -Skripte auf Codecanyon Mar 13, 2025 pm 12:08 PM

Möchten Sie den dringlichsten Problemen Ihrer Kunden in Echtzeit und Sofortlösungen anbieten? Mit Live-Chat können Sie Echtzeitgespräche mit Kunden führen und ihre Probleme sofort lösen. Sie ermöglichen es Ihnen, Ihrem Brauch einen schnelleren Service zu bieten

Erklären Sie das Konzept der späten statischen Bindung in PHP. Erklären Sie das Konzept der späten statischen Bindung in PHP. Mar 21, 2025 pm 01:33 PM

In Artikel wird die in PHP 5.3 eingeführte LSB -Bindung (LSB) erörtert, die die Laufzeitauflösung der statischen Methode ermöglicht, um eine flexiblere Vererbung zu erfordern. Die praktischen Anwendungen und potenziellen Perfo von LSB

Rahmensicherheitsmerkmale: Schutz vor Schwachstellen. Rahmensicherheitsmerkmale: Schutz vor Schwachstellen. Mar 28, 2025 pm 05:11 PM

In Artikel werden wichtige Sicherheitsfunktionen in Frameworks erörtert, um vor Schwachstellen zu schützen, einschließlich Eingabevalidierung, Authentifizierung und regelmäßigen Aktualisierungen.

Erklären Sie JSON Web Tokens (JWT) und ihren Anwendungsfall in PHP -APIs. Erklären Sie JSON Web Tokens (JWT) und ihren Anwendungsfall in PHP -APIs. Apr 05, 2025 am 12:04 AM

JWT ist ein offener Standard, der auf JSON basiert und zur sicheren Übertragung von Informationen zwischen Parteien verwendet wird, hauptsächlich für die Identitätsauthentifizierung und den Informationsaustausch. 1. JWT besteht aus drei Teilen: Header, Nutzlast und Signatur. 2. Das Arbeitsprinzip von JWT enthält drei Schritte: Generierung von JWT, Überprüfung von JWT und Parsingnayload. 3. Bei Verwendung von JWT zur Authentifizierung in PHP kann JWT generiert und überprüft werden, und die Funktionen und Berechtigungsinformationen der Benutzer können in die erweiterte Verwendung aufgenommen werden. 4. Häufige Fehler sind Signaturüberprüfungsfehler, Token -Ablauf und übergroße Nutzlast. Zu Debugging -Fähigkeiten gehört die Verwendung von Debugging -Tools und Protokollierung. 5. Leistungsoptimierung und Best Practices umfassen die Verwendung geeigneter Signaturalgorithmen, das Einstellen von Gültigkeitsperioden angemessen.

See all articles