PHP的基本常识小结
这些php的概念,有些刚开始比较难懂,很难理解,我把他们都列出来,希望能帮助一些人,在前进的路上少点荆棘。
1. variable variables(变量的变量)
variable_variables.php
<?php
$a = 'hello';
$hello = 'hello everyone';
echo $$a.'<br />';
$b = 'john';
$c = 'mary';
$e = 'joe';
$students = array('b','c','e');
echo ${$students[1]};
/*
foreach($students as $seat){
echo $$seat.'<br />';
}
$$var[1]
${$var[1]} for #1
*/
$a = 'hello';
将hello 赋值给 变量 $a, 于是 $$a = ${hello} = $hello = 'hello everyone';
如果对于 $$students[1], 这样会产生混乱,php的解释器可能无法理解,‘[' 虽然有较高运算符,但结果可能无法输出。
好的写法是:${$students[1]} = ‘mary';
2. array's function(数组函数)
array_functions.php
<?php
echo '<p>shift & unshift </p>';
$numbers = array(1,2,3,4,5,6);
print_r($numbers);
echo '<br />';
// shifts first elemnt out of an array
// the index will reset
$a = array_shift($numbers);
echo 'a: '.$a.'<br />';
print_r($numbers);
// push element to the front of array
// returns the count of array and reset array index
$b = array_unshift($numbers, 'first');
echo '<br />b: '.$b.'<br />';
print_r($numbers);
echo '<hr />';
echo '<p>pop & push </p>';
// pop the last element out of array
$c = array_pop($numbers);
print_r($numbers);
echo '<br />';
// push the element to the last of array
$d = array_push($numbers, 'last');
echo 'd: '.$d.'<br />';
print_r($numbers);
3. dates and times (时间和日期)
有3种方法可以创建一个unix time(从1970/1/1 到现在的秒数)
time(); 返回当前的时间戳
mktime($hr, $min, $sec, $month, $day, $year); mktime(6,30,0,5,22,2012) 返回2012 5/22 6:30:00 的时间戳
strtotime($string); strtotime("+1 day") 返回明天这个时候的时间戳 更多 'last monday' 'lasy year'
checkdate($month, $day, $year); 验证一个日期是否为真 checkdate(5,32,2012) ? 'true' : 'false'; // return false
得到了时间戳后,我们需要对它进行转化为可读的,如2012/5/22
我们有2种方法 date($format, $timestamp) ; strftime($format [,$timestamp])
推荐用第2种,strftime("%y-%m-%d %h:%m:%s"); // return 2012-05-22 15:46:40
5. server variables (服务器和执行环境信息)
$_server
server_variables.php
<?php
echo 'server details:<br />';
echo 'server_name: '.$_server['server_name'].'<br />';
echo 'server_add: '.$_server['server_addr'].'<br />';
echo 'server_port: '.$_server['server_port'].'<br />';
echo 'document_root: '.$_server['document_root'].'<br />';
echo '<br />';
echo 'page details:<br />';
echo 'remote_addr: '.$_server['remote_addr'].'<br />';
echo 'remort_port: '.$_server['remote_port'].'<br />';
echo 'request_uri: '.$_server['request_uri'].'<br />';
echo 'query_string: '.$_server['query_string'].'<br />';
echo 'request_method: '.$_server['request_method'].'<br />';
echo 'request_time: '.$_server['request_time'].'<br />';
echo 'http_user_agent: '.$_server['http_user_agent'].'<br />';
echo '<br />';
6.variable_scope(变量的作用域 global static)
static_variables.php
<?php
function test()
{
$a = 0;
echo $a;
$a++;
}
test();
echo '<br />';
test();
echo '<br />';
test();
echo '<br />';
echo '<hr />';
function test1()
{
static $a = 0;
echo $a;
$a++;
}
test1();
echo '<br />';
test1();
echo '<br />';
test1();
echo '<br />';
test() 函数中的变量 $a 没有保存 $a++ 的结果 , 重复调用test() 并没有使 $a 的值增加
而test1() 函数中 变量 $a 申明了 staic $a = 0, 为静态变量。
引用:a static variable exists only in a local function scope, but it does not lose its value when program execution leaves this scope.
一个静态变量 只能存在于本地的函数作用域内 也就是test1() 函数体内, 但是当程序离开这个test1() 作用域时,静态变量不会失去它的值,也就是 $a 变量会增加 1; 当重新调用 test1() 时,$a = 1;
global_variables.php
<?php
$a = 1;
$b = 2;
function sum()
{
global $a, $b;
$b = $a + $b;
}
sum();
echo $b;
echo '<hr />';
$a = 1;
$b = 2;
function sum1()
{
$globals['b'] = $globals['a'] + $globals['b'];
}
sum1();
echo $b;
引用:in php global variables must be declared global inside a function if they are going to be used in that function
如果这些变量将在函数中使用,全局变量必须在使用的那个函数中进行定义。 这样可以避免很多麻烦。
7.reference(引用)
variable_reference.php
<?php
$a = 'arist';
$b = $a;
$b = 'ming';
echo "my name is:{$a}. but my mother call me {$b}.<br />";
echo '<hr />';
$a = 'arist';
$b = &$a;
$b = 'ming';
echo "my name is:{$a}. and my mother call me {$b}.<br />";
这个概念可以这样理解,我妈叫我明明,但是我的领导会叫我小言;不管是明明或者是小言,都是我。
'&' 而这个就是不同的人叫我们的别名的方法 即引用,相当于 $a = {我,或者内存中的值} , $b = {领导,妈妈,或者变量}
通过 & , $b指向了$a 在内存中唯一也是相同的值。 所以不管你领导叫你什么,或者你妈叫你什么,你都是你。只是称呼不同。
所以通过引用后, 我们改变$b的值,同时也改变了$a的值。
8. pass reference variable to function(传递引用参数给函数)
<?php
function ref_test(&$var){
return $var *= 2;
}
$a = 10;
ref_test($a);
echo $a;
当我们按引用传递参数给函数时,我们传递地不是变量的副本(copy) ,而是真实的值,
所以当我们调用函数ref_test($a)的时候已经改变了 $a 的值, 所以最后 $a = 20;
9. reference function return value(引用函数的返回值)
reference_function_return_value.php
<?php
function &increment(){
static $var = 0;
$var++;
return $var;
}
$a =& increment(); // 1
increment(); // 2
$a++; //3
increment(); // 4
echo "a: {$a}";
首先申明一个引用函数,在函数体内,申明一个静态变量 $var, 可以保存增加的值;
$a =& increment(); 这条语句是 变量$a 引用 函数increment() 的返回值,
和前面的引用变量一样, 你可以把increment()函数, 看作是一个变量; 这样就变为 $a = & $b;
所以increment() 和 $a 都指向同一个值,改变任何一个,都能改变同一个值。
对象 oop
1.fatal error: using $this when not in object context
这个错误刚学 oop 肯定容易出现,因为有个概念你没有真正理解。 类的可访问性(accessible),也可以说是作用域, 你还可以认为是 1个 中国人 在国外,他不属于哪个文化,他不讲外语(可能他知道点);但是他无法通过自己跟老外沟通,因为他们不是在一个共同国度出生。
那么错误是如何发生的呢?看下面的例子:
<?php
class trones{
static public $fire = "i am fire.";
public $water = "i am water";
static function getfire( ) {
return $this->fire ; // wrong
}
static function getwater( ) {
return $self::water ; // wrong
}
static function fire( ) {
return self::$fire ; // be sure you use self to access the static property before you invoke the function
}
}
/*
fatal error: using $this when not in object context
*/
//echo trones::getfire( ) ;
//echo trones::getwater( ) ;
// correct
echo trones::fire( );
echo "<br />" ;
$trones = new trones ;
$trones->fire ; // notice: undefined property: trones::$fire (base on defferent error setting) simple is error
echo trones::$fire ;
这个错误很经典, 也很实用,先看 static 的定义:
declaring class properties or methods as static makes them accessible without needing an instantiation of the class. a property declared as static can not be accessed with an instantiated class object (though a static method can).
翻译:定义一个类的属性或方法为静态时,可以使他们在不需要初始化一个类时就能直接访问 。一个被定义为了静态的属性不能被类的对象用对象操作符访问* -> *,(可以通过静态的方法访问)。
例子说明:
7行 10行 犯了同一个错误,第一个是用对象操作符来访问静态变量。你看看定义,$this 是一个伪变量 相当于 object,一个实例。你用对象操作符 -> 访问就会报错。
同样你也不能用 静态操作符 :: 来访问一个公共变量 。 正确的访问应该是 14行 25行,一个是在类的定义里访问(self:: === trones::),一个是在类的外部访问。
对于继承类,以上的规则同样适合。
2.fatal error: call to private method
最近有部连续剧很好看,叫权利的游戏,我们假设有 3方人马, 7个国王, 平民, 龙女。 他们三方人马在下面争夺最终的胜利, 也就是王冠。
下面的故事还有一个标题:类的可见性(visibility) 你如果知道最终的答案,解释部分你可以略过了。
<?php
class trones {
protected $fire = " fire ";
public $water = " water " ;
static private $trones = "trones";
protected function getfire( ) {
$this->fire ;
}
static public function thedragenofmather( ) {
return __method__." use ".$this->getfire()." gets the ".self::gettrones( ) ;
}
static public function getwater( ) {
return __method__ ;
}
static private function gettrones( ) {
return self::$trones ;
}
}
class kings extends trones {
static function thesevenking( ) {
return __method__."gets the ".self::gettrones( );
}
}
class people extends trones{
static function thepeople( ) {
return __method__."gets the ".self::gettrones( );
}
}
echo kings::thesevenking( ) ;
echo trones::thedragenofmather( ) ;
echo people::thepeople( ) ;
正确答案是:7国征战 内斗,平民死伤无数,龙女想乘机渔翁得利;可惜 最终谁也没有得到皇冠和胜利。哈哈。
当static 碰到 private ,结合产生复杂,也产生美;就像抽象的人,像我们大学老师讲的数学课;(不过网易的公开数学课很好)
如果想要龙女 获得最后的胜利, 你只要帮她一把 将13行的 $this->getfire() 这部分去掉就可以了。同样的道理 你无法在一个静态函数里 使用任何对象操作符。
怎么使人民获得王冠呢? 你去奋斗吧!
如果你不构建大型的框架和网站 这些概念比如 interface implement abstract 。。。 你还是不知道的好。