数字、浮点、布尔型、字符串和数组、浮点、布尔型是值类型,英文:int、float、bool,这样你知道他们怎么用了.
比如语句:$fa=3.14;
字符串和数组是引用类型,也就是说他们作为地址放在栈里,当重新赋值时,栈里的地址改变方向,原来的指向变没或给回收了,英文:string、array.
比如:$str=”字符串”;$arr=array(“a”=>”数”,”b”=>”组”);// array()是一个数组赋值函数,这样的函数PHP有一千多个,一般常用的不到200个,我觉得.
字符串操作,实例2:字符串合并、相加,代码如下:
- <?PHP
- $str = 1;
- echo $str .= ""; //数字转化为字符串再合并,结果:"1"。
- echo "<br>";
- echo $str += "1元"; //字符串转化为数字再相加,如"1xxx"转化为数字1,结果: 2。
- echo "<br>";
- ?>
实例3:字符串改变大小写,代码如下:
- <?PHP
- $str="12345abc";
- echo strtolower($str);//变小写,结果:"12345abc"。
- echo "<br>";
- echo strtoupper($str);//变小写,结果:"12345abc"。
- echo "<br>";
- ?>
- <?PHP
- $str = "字符串2";
- echo mb_strlen($str, "utf-8"); //返回字符串长度的函数,第二个参数是编码,由于页面用utf-8编码,所以为这样。如果省去,返回内存占用的字节数(ascii),即10。结果4
- echo "<br>";
- echo mb_substr($str, 1, 2, "utf-8"); //返回字符截取,1为从”符”地址开始截取,2为截取2个"utf-8"编码的字符,结果:“符串”。
- echo "<br>";
- /**
- * 知识点:现在开始接触函数了,每个函数都有()作为堆栈调用,()里面放0个或多个参数,可以自定义可以有默认值。而关键字比如echo是没有()的。
- * 很多书用gb2312编码,取长度和子串时很麻烦。下面给大家参考一下不用上面的mb中文字符串扩展库实现原理:
- */
- function my_mb_strlen($str, $code = "utf-8") // 定义一个新函数,$str是必须传入的参数。
- {$num= 0;
- if ($code == "utf-8")
- {
- $str = iconv("utf-8", "gb2312", $str); //转化为gb2312编码,ord函数返回对应的ascii值判断每个字节该中文字符是否结束。
- for($i = 0;$i < strlen($str);$i++) // 在此strlen($str)返回内存占用的字节数相当于mb_strlen($str)
- {
- if (ord($str[$i]) > 0xa0)$i++; //$str[$i]对应内存的i字节。如果直接用utf-8判断会复杂些,因为编码的多样性utf-8是网页常用编码,utf-16(unicode)是windows编码。
- $num++;
- }
- }
- else
- {
- $num = "编码未实现";
- } //有兴趣的自己查资料吧
- return $num;
- }
- echo my_mb_strlen($str) . ";" . my_mb_strlen($str, "gb2312") . "<br>"; //该页编码用utf-8,你却说传入的字符串3是gb2312,就算函数实现了也无法正确的。
- ?>
实例5:子字符串查找、替换,代码如下:
- <?PHP
- $str = "字符串4";
- echo mb_strpos($str, '串4', 0, "utf-8"); //查找从0开始找到的第一个子字符串位置,结果:2。如果查找不到,返回空(="");如果最后两个参数不要,返回6。
- echo "<br>";
- echo mb_strstr($str, '串', "utf-8"); //截取从0开始找到的第一个子字符串至结尾,结果:"串4"。如果查找不到,返回空(="");如果最后两个参数不要,返回相同=strstr($str,'串')。
- echo "<br>";
- echo str_replace("4", "不是4", $str) ; //字符串替换,结果: "字符串不是4"。
- echo "<br>";
- ?>
实例6:子字符串去空、html转义,代码如下: