变量的范围即它定义的上下文背景(也就是它的生效范围)。大部分的 PHP 变量只有一个单独的范围。这个单独的范围跨度同样包含了 include 和 require 引入的文件。例如:
代码如下 | 复制代码 |
<?php |
这里变量 $a 将会在包含文件 b.inc 中生效。但是,在用户自定义函数中,一个局部函数范围将被引入。任何用于函数内部的变量按缺省情况将被限制在局部函数范围内。例如:
代码如下 | 复制代码 |
<?php function Test() Test(); |
这个脚本不会有任何输出,因为 echo 语句引用了一个局部版本的变量 $a,而且在这个范围内,它并没有被赋值。你可能注意到 PHP 的全局变量和 C 语言有一点点不同,在 C 语言中,全局变量在函数中自动生效,除非被局部变量覆盖。这可能引起一些问题,有些人可能不小心就改变了一个全局变量。PHP 中全局变量在函数中使用时必须申明为global。
今天就遇到了php 全局变量不起作用的问题.
先上一段简单的代码:
代码如下 | 复制代码 |
<?php $a = 0 ; function Test() { $a =1; } Test(); echo $a; ?> |
上面的代码中输出是0,那是因为函数体Test内$a变量被缺省设置为局部变量,$a的作用域就是在Test内.修改代码如下
代码如下 | 复制代码 |
<?php $a = 0 ; function Test() { global $a;//申明函数体Test内使用的$a变量为global全局变量 $a =1; } Test(); echo $a; ?> |
申明函数体Test内使用的$a变量为global全局变量后,使得$a的作用全局,所以输出为1.
上面的实例只是基本的global全局变量知识,下面我们看看复杂点的:
//A.php 文件
代码如下 | 复制代码 |
<?php $a = 0 ; //B.php 文件 <?php |
为什么输出的却是0?!!
在用户自定义函数中,一个局部函数范围将被引入。任何用于函数内部的变量按缺省情况将被限制在局部函数范围内(包括include 和 require 导入的文件内的变量)!
解释:A.php文件的内Test_Global是定义好的第三方函数,该函数用include导入了B.php文件内的$a的global全局变量,所以$a被限制在Test_Global局部函数范围内,所以B.php文件内的$a的作用范围都在Test_Global内,而不是作用了整个A.php内….
解决方案:
1. 冲出局部函数
代码如下 | 复制代码 |
//A.php 文件 <?php //B.php 文件 <?php |
2.优秀的访问器
代码如下 | 复制代码 |
//A.php 文件 //B.php 文件 <?php |
PHP5类方法
过程:过程是编制程序时定义的一个语句序列,用来完成某种指定的操作。
函数:函数有返回值,也是定义的语句序列。
方法:在面向对象概念中,类里面的一段语句序列。
一般来说,在面向对象概念中,函数和方法两个名词是通用的。
通过方法读取属性
下面的例子将属性设置为private ,同时声明了public的getName()方法,用来获取属性$name的值,调用getName()方法就会通过 return $this->name 返回 $name 的值。
代码如下 | 复制代码 |
<?php class Person { private $name = “NoName”; //private成员$name public function getName() { return $this->name; } } $newperson = new Person(); echo ” ” . $newperson->getName(); ?>
|
注意:这里,方法内部调用本地属性时,使用 $this->name来获取属性。在这个例子中,设置了公开的getName()方法,即用户只能获取$name, 而无法改变他的值。这就是封装的好处。
封装指的是将对象的状态信息(属性)和行为(方法)捆绑为一个逻辑单元的机制。
PHP5中通过将数据封装、声明为私有的(private),再提供一个或多个公开的(public)方法实现对该属性的操作,以实现下述目的:
防止对封装数据的未经授权的访问。使用者只能通过事先定制好的方法来访问数据,可以便地加入控制逻辑,限制对属性的不合理操作;
有利于保证数据的完整性;
便于修改,增强代码的可维护性;
方法的参数
通过方法定义时的参数,可以向方法内部传递变量。
如下第5行,定义方法时定义了方法参数$_a。使用这个方法时,可以向方法内传递参数变量。方法内接受到的变量是局部变量,仅在方法内部有效。可以通过向属性传递变量值的方式,让这个变量应用于整个对象。
代码如下 | 复制代码 |
<?php class Person { private $a; function setA($_a) { $thia->a = $_a; } function getA() { return $this->a; } } $newperson = new Person(); $newperson->setA(100); echo $newperson->getA(); ?>
|
如果声明这个方法有参数,而调用这个方法时没有传递参数,或者参数数量不足,系统会报出错误。如果参数数量超过方法定义参数的数量,PHP就忽略多于的参数,不会报错。可以在函数定义时为参数设定默认值。 在调用方法时,如果没有传递参数,将使用默认值填充这个参数变量。
代码如下 | 复制代码 |
<?php class A { public $name = “tom”; } class Person { private $a; function setA($_a) { $this->a = $_a; } function getA() { return $this->a; } } $a1 = new A(); $p = new Person(); $p->setA($a1); echo $p->getA()->name; ?> |
属性的使用:通过引用变量的-> 符号调用变量指向对象的属性。
在方法内部通过 $this-> 符号调用同一对象的属性。
代码如下 | 复制代码 |
<?php class Person { public $name = “NoName”; //定义public属性$name public $age = 20; //定义public属性$age } $p = new Person(); //创建对象 echo ” ” . $p->name; //输出对象$p的属性$name echo “<br />”; echo ” ” . $p->age; //输出$age属性 ?>
|
PHP5类中的属性
我们还可以改变属性的值,当然要注意的改变属性的值是通过public来修饰的
我们修改一下这个例子:
代码如下 | 复制代码 |
<?php class Person { public $name = “NoName”; //公共变量$name public $age = 20; //公共变量$age } $p = new Person(); $p->name = “Tom”; //我是Tom $p->age = 25 ; //年龄25 echo ” ” . $p->name; //输出名字 echo “<br />”; echo ” ” . $p->age; //年龄 ?>
|
创建一个Person的对象,改变这个对象的属性。为它命名,查看它的名字。你就是机器里面这个Person对象的上帝,按照你定义的规则,这个实实在在内存中的Person对象被创建了,而且它有了可以改变的属性。
属性的初值
在PHP5中,在属性定义可以不设置初值,或者赋予以下红色类型的初值。
PHP中简单类型有8种,分别是:
四种标量类型:
布尔型(boolean)
整型(integer)
浮点型(float)(浮点数,也作“double”)
字符串(string)
两种复合类型:
数组(array)
对象(object)
最后是两种特殊类型:
资源(resource)
一个简单的php分割字符串并循环输出 学习笔记本大家可参考参考。例子一
代码如下 | 复制代码 |
<?php $test='472347127,893372115,850965403'; $r=explode(",",$test); for($i=0;$i<sizeof($r);$i++) { echo $i.".". $r[$i].""; } ?> |
输出: 0.472347127 1.893372115 2.850965403
例子二
代码如下 | 复制代码 |
<?php $a="893372115,472347127,850965403" ; $b=explode(",",$a); foreach($b as $bb) { echo $bb.""; //print_r($b); } ?> |
输出: 893372115 472347127 850965403 PHP
循环读取数组变量值,类似ASP里的Split用法
除法运算符总是返回浮点数。只有在下列情况例外:两个操作数都是整数(或字符串转换成的整数)并且正好能整除,这时它返回一个整数。
取模运算符的操作数在运算之前都会转换成整数(除去小数部分)。
Note: 取模 $a % $b 在 $a 为负值时的结果也是负值。
例:
代码如下
复制代码
<?php
/* tested under PHP 5.2.6-1 with Suhosin-Patch 0.9.6.2 (cli) on both i386 and amd64, Debian lenny/sid */
$a = 2863311530;
$b = 256;
$c = $a % $b;
echo "$c <br />n";
echo (2863311530 % 256)." <br />n"; /* directly with no variables, just to be sure */
?>
运算符
说明
例子
结果
+
Addition
x=2
x+2
4
-
Subtraction
x=2
5-x
3
*
Multiplication
x=4
x*5
20
/
Division
15/5
5/2
3
2.5
%
Modulus (division remainder)
5%2
10%8
10%2
1
2
0
++
Increment
x=5
x++
x=6
--
Decrement
x=5
x--
x=4
赋值运算符
基本的赋值运算符是“=”。一开始可能会以为它是“等于”,其实不是的。它实际上意味着把右边表达式的值赋给左边的运算数。
赋值运算表达式的值也就是所赋的值。也就是说,“$a = 3”的值是 3。这样就可以做一些小技巧:
代码如下
复制代码
<?php
$a = ($b = 4) + 5; // $a 现在成了 9,而 $b 成了 4。
?>
在基本赋值运算符之外,还有适合于所有二元算术,数组集合和字符串运算符的“组合运算符”,这样可以在一个表达式中使用它的值并把表达式的结果赋给它,例如:
代码如下
复制代码
<?php
$a = 3;
$a += 5; // sets $a to 8, as if we had said: $a = $a + 5;
$b = "Hello ";
$b .= "There!"; // sets $b to "Hello There!", just like $b = $b . "There!";
?>
注意赋值运算将原变量的值拷贝到新变量中(传值赋值),所以改变其中一个并不影响另一个。这也适合于在很密集的循环中拷贝一些值例如大数组。也可以使用引用赋值,用 $var = &$othervar; 语法。引用赋值意味着两个变量都指向同一个数据,没有任何数据的拷贝。有关引用的更多信息见引用的说明。在 PHP 5中,对象总是通过引用赋值的,除非明确使用新的 clone关键字
运算符
说明
例子
=
x=y
x=y
+=
x+=y
x=x+y
-=
x-=y
x=x-y
*=
x*=y
x=x*y
/=
x/=y
x=x/y
.=
x.=y
x=x.y
%=
x%=y
x=x%y
比较运算符
比较运算符,如同它们名称所暗示的,允许对两个值进行比较。如果比较一个整数和字符串,则字符串会被转换为整数。如果比较两个数字字符串,则作为整数比较。此规则也适用于 switch 语句。
代码如下
复制代码
<?php
var_dump(0 == "a"); // 0 == 0 -> true
var_dump("1" == "01"); // 1 == 1 -> true
var_dump("1" == "1e0"); // 1 == 1 -> true
switch ("a") {
case 0:
echo "0";
break;
case "a": // never reached because "a" is already matched with 0
echo "a";
break;
}
?>
运算符
说明
例子
==
is equal to
5==8 returns false
!=
is not equal
5!=8 returns true
>
is greater than
5>8 returns false
<
is less than
5<8 returns true
>=
is greater than or equal to
5>=8 returns false
<=
is less than or equal to
5<=8 returns true
逻辑运算符
“与”和“或”有两种不同形式运算符的原因是它们运算的优先级不同(见运算符优先级)。
Example #1 逻辑运算符示例
代码如下
复制代码
<?php
// 下面的 foo() 不会被调用,因为它们被运算符“短路”了。
$a = (false && foo());
$b = (true || foo());
$c = (false and foo());
$d = (true or foo());
// "||" 的优先级比 "or" 高
$e = false || true; // $e 被赋值为 (false || true),结果为 true
$f = false or true; // $f 被赋值为 false [Altair注:"=" 的优先级比 "or" 高]
var_dump($e, $f);
// "&&" 的优先级比 "and" 高
$g = true && false; // $g 被赋值为 (true && false),结果为 false
$h = true and false; // $h 被赋值为 true [Altair注:"=" 的优先级比 "and" 高]
var_dump($g, $h);
?>
以上例程的输出类似于:
bool(true)
bool(false)
bool(false)
bool(true)
运算符
说明
例子
&&
and
x=6
y=3
(x < 10 && y > 1) returns true
||
or
x=6
y=3
(x==5 || y==5) returns false
!
not
x=6
y=3
!(x==y) returns true
在判断某个 PHP 数组的索引值是否存在,一般会使用 isset 和 array_key_exists 两种方法,但是两者返回的值会有不同,下面我来介绍isset 和 array_key_exists 区别,有需要的朋友可参考。
先来看个简单的例子
代码如下 | 复制代码 |
isset($a['key']) |
确切地告诉你,数组是否存在某个键,而 isset 则只是返回键值是否为 null 的状态。
isset函数是检测变量是否设置。
格式:bool isset ( mixed var [, mixed var [, ...]] )
返回值:
1.若变量不存在则返回 FALSE
2.若变量存在且其值为NULL,也返回 FALSE
3.若变量存在且值不为NULL,则返回 TURE
4.同时检查多个变量时,每个单项都符合上一条要求时才返回 TRUE,否则结果为 FALSE
例1
代码如下 | 复制代码 |
$a = array('key1' => '123', 'key2' => null); |
使用这两个方法判断键值存在情况,结果如下:
代码如下 | 复制代码 |
isset($a['key1']); // true isset($a['key2']); // false |
例2
代码如下 | 复制代码 |
<?php $a = array ('test' => 1, 'hello' => NULL); var_dump( isset ($a['test') ); // TRUE // 'hello' 等于 NULL,所以被认为是未赋值的。 ?> |