贴一段代码,在php中获取随机数组 不用多说,直接贴代码,php中的array_rand很变态,突破了正常人的理解,繁琐
例1
代码如下 | 复制代码 |
function create_random_ids( $min,$max,$limited ) |
例2
代码如下 | 复制代码 |
<?php |
第一次得到的结果为:
第二次得到的结果为:
第三次得到的结果为:在php中数组排序有很多函数可以实现的,如果是简单的一维数组排序我们可以使用php 自带的排序函数了,但多维数组时我们需要自己写了。
回来后一直在揪心啊,于是翻了一下书本查阅,给我知道了答案。为了记住它们,我决定来一个数组排序函数大总结。
首先接触的就是PHP数组排序、降序的排序问题。
sort:本函数为 array 中的单元赋予新的键名。这将删除原有的键名而不仅是重新排序。
rsort:本函数对数组进行逆向排序(最高到最低)。 删除原有的键名而不仅是重新排序。
asort:对数组进行排序并保持索引关系
arsort:对数组进行逆向排序并保持索引关系
ksort:对数组按照键名排序,保留键名到数据的关联
krsort:对数组按照键名逆向排序,保留键名到数据的关联
natsort:对字母数字字符串进行排序并保持原有键/值的关联
natcasesort:同natsort排序算法,但不区分大小写字母排序
PHP 数组排序(sort)
数字索引数组排序:
函数:sort(array, [sort type])
说明:sort()函数按升序对指定数组(第一个参数)进行排序。
sort函数第二参数作用为指定排序类型,是可选参数,可能的值为:
SORT_REGULAR: 默认值,不改变类型进行排序;
SORT_NUMERIC: 把值作为数字进行排序;
SORT_STRING: 把值作为字符串进行排序;
如数组中有4和”37″,按数字排序,4小于”37″;按字符串排序,4大于”37″;
一、一维数组
假设有一个一维数组,如下:
$sortArr = array("name"=>"hiro", "age"=>"23", "city"=>"Shanghai", "code"=>"200051");
print_r()输出的原始数组结果为:
Array ( [name] => hiro [age] => 23 [city] => Shanghai [code] => 200051 )
1.sort()函数:根据数组下标进行升序排列;
print_r()输出的数组结果为(输出时只有数组下标,而不是键名):
1
Array ( [0] => 23 [1] => 200051 [2] => Shanghai [3] => hiro )
2.rsort()函数:与sort()函数相反,根据数组下标进行降序排列;
print_r()输出的数组结果为(输出时只有数组下标,而不是键名):
Array ( [0] => hiro [1] => Shanghai [2] => 200051 [3] => 23 )
3.asort()函数:根据数组的键名进行升序排列;
print_r()输出的数组结果为:
1
Array ( [age] => 23 [code] => 200051 [city] => Shanghai [name] => hiro )
4.arsort()函数:与asort()函数相反,根据数组的键名进行降序排列;
print_r()输出的数组结果为:
Array ( [name] => hiro [city] => Shanghai [code] => 200051 [age] => 23 )
5.ksort()函数:根据数组的键值进行升序排列;
print_r()输出的数组结果为:
Array ( [age] => 23 [city] => Shanghai [code] => 200051 [name] => hiro )
6.krsort()函数:与ksort()函数相反,根据数组的键值进行降序排列;
print_r()输出的数组结果为:
代码如下 | 复制代码 |
|
7.reverse_array()函数:反向当前的数组排列顺序;
print_r()输出的数组结果为:
代码如下 | 复制代码 |
Array ( [name] => hiro [age] => 23 [city] => Shanghai [code] => 200051 ) |
8.shuffle()函数:随机地排列数组顺序(每次刷新后排列的顺序都不相同);
print_r()输出的数组结果为(只是其中一种随机排列):
Array ( [0] => 23 [1] => 200051 [2] => Shanghai [3] => hiro )
二、二维数组
假设有一个二维数组,如下:
代码如下 | 复制代码 |
$person = array( 1 |
二维数组的排序是根据每维的键名排序的,所以需要额外地编写比较函数。先举三个例子:
1.按每维的第一个元素升序排列,代码如下:
代码如下 | 复制代码 |
function compare0($x, $y) { 1 |
2.按每维的第三个元素升序排列,代码如下:
代码如下 | 复制代码 |
function compare2($x, $y) {
|
3.按每维的第三个元素升序排列,代码如下:
代码如下 | 复制代码 |
function reverse_compare2($x, $y) { if($x[2] == $t[2]) { return 0; } elseif ($x[2] < $y[2]) { return 1; //改变后即可反向 } else { return -1; //改变后即可反向 } } usort($person, reverse_compare2); |
echo "按第三个元素反向排序:";
print_r($person);
输出的结果如下:
1
按第三个元素反向排序:
代码如下 | 复制代码 |
Array ( [0] => Array ( [0] => janstar [1] => 28 [2] => xinjiang ) [1] => Array ( [0] => hiro [1] => 23 [2] => suzhou ) [2] => Array ( [0] => yoyo [1] => 25 [2] => shanghai ) ) |
呵呵,是不是代码多了点,记下了以后方便查阅啊!
例
代码如下 | 复制代码 |
<?php /** $array = array(100, 1000, 1, 10000); |
在PHP中,静态变量的解释是存在于类作用域的变量,在第一次初始化时给变量赋值,以后类初始化时,静态变量将不会再被重新赋值,主要用于一个类具有多个实例时的变量共享,以下为PHP的静态变量使用代码:
使用静态变量
变量范围的另一个重要特性是静态变量(static variable)。静态变量仅在局部函数域中存在,但当程序执行离开此作用域时,其值并不丢失。看看下面的例子:
例子 7-4. 演示需要静态变量的例子
代码如下 | 复制代码 |
<?php function Test () { $a = 0; echo $a; $a++; } ?> |
本函数没什么用处,因为每次调用时都会将 $a 的值设为 0 并输出 "0"。将变量加一的 $a++ 没有作用,因为一旦退出本函数则变量 $a 就不存在了。要写一个不会丢失本次计数值的计数函数,要将变量 $a 定义为静态的:
例子 7-5. 使用静态变量的例子
代码如下 | 复制代码 |
<?php |
现在,每次调用 Test() 函数都会输出 $a 的值并加一。
静态变量也提供了一种处理递归函数的方法。递归函数是一种调用自己的函数。写递归函数时要小心,因为可能会无穷递归下去。必须确保有充分的方法来中止递归。一下这个简单的函数递归计数到 10,使用静态变量 $count 来判断何时停止:
例子 7-6. 静态变量与递归函数
代码如下 | 复制代码 |
<?php $count++; |
注: 静态变量可以按照上面的例子声明。如果在声明中用表达式的结果对其赋值会导致解析错误。
例子 7-7. 声明静态变量
代码如下 | 复制代码 |
<?php $int++; |
静态方法
代码如下 | 复制代码 |
class Apple extends Fruit { Apple::find("Apple"); 程序运行结果: 1 I'm Apple |
Program List:重写基类方法
在派生类重写基类的方法。
代码如下 | 复制代码 |
class Apple extends Fruit static function Color() Apple::Foo(); // This time it works.
Apple's color is red |
Program List:静态数组的使用
静态和const作用域都可以用::操作符访问,如果你想使用::操作符访问数组,你需要事先将数组声明为静态
代码如下 | 复制代码 |
<?php class Apple class Banana new Apple(); // prints array(2) { ["color1"]=> string(3) "red" ["color2"]=> string(6) "yellow" } |
Program List:再来一个单例模式
Static真的很酷,下面的程序演示了如何获得一个已经存在的实例。
代码如下 | 复制代码 |
private static $instance=null; private function __construct($value) { public static function getInstance() { } $x = Singleton::getInstance(); |
例
静态变量与静态方法
代码如下 | 复制代码 |
class A { |
输出结果为11,可以看到类A在第二次实例化后,静态变量$i依然与上一次实例化时后设定的$i值是一致的。用java来解释,其实就是一个类的静态变量在多个实例中都使用了一个内存空间,我觉得这样解释更加便于理解。因为静态变量和静态方法不需要实例化就可以使用,因而在文件被加载后静态变量就会初始化,而静态方法则会被注册。这也就可以理解,为什么java类的入口会这样的了:
代码如下 | 复制代码 |
public static void main(String[] args) |
我以前一直觉得由于静态方法不需要实例化就可以直接使用,节约了实例化的巨大开销,因而在使用一个类的方法时我更加倾向于直接静态调用而避免实例化。对于这个问题,我与同事已经争论过很多次,他不主张静态调用主要有以下想法:
1.实例化类更加符合面向对象编程的思想;
2.静态调用方法并不能在消耗上有较大的节约。
对于这个问题,我还是坚持自己的观点,但也并不是无论什么时候都使用静态调用。我主要有以下想法:
1.由于静态变量在文件被载入时就会被初始化,因此如果有多个类,并且类中存在多个静态变量与方法,势必在还未实例化时已消耗较多的内存(未验证)。所以对于访问不频繁或特殊需要,不建议将一个方法设为static;
2.对于调用较为频繁的类,我强烈建设使用static静态和静态方法,不仅可以共享内存空间,还可以共享数据。细心就会发现目前主流的PHP框架的基类都是使用的静态调用方法。
PHP date()参数说明
这里主要用到了 w 这个参数,关于这个参数的解释是:
w 表示星期中的第几天,数字表示 0(表示星期天)到 6(表示星期六)
有了这个一切就很简单了,作者这里就直接贴代码了,细节不解释:
简单的获取星期几,其实就是date函数的用法
date("l");
//data就可以获取英文的星期比如Sunday
date("w");
//这个可以获取数字星期比如123,注意0是星期日
获取中文星期可以这样
代码如下 | 复制代码 |
$weekarray=array("日","一","二","三","四","五","六"); |
获取指定日期是:
代码如下 | 复制代码 |
$weekarray=array("日","一","二","三","四","五","六"); |
例
代码如下 | 复制代码 |
<?php 或者 <?php |
phP的date函数是有时间范围区间的,即只能从1970~2038年,因此在这个区间范围之外的算法都是不准的。那倒底怎么算呢?其实是有一个公式的:
蔡勒(Zeller)公式:w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1
公 式中的符号含义如下,w:星期;c:世纪-1;y:年(两位数);m:月(m大于等于3,小于等于14,即在蔡勒公式中,某年的1、2月要看作上一年的 13、14月来计算,比如2003年1月1日要看作2002年的13月1日来计算);d:日;[ ]代表取整,即只要整数部分。(C是世纪数减一,y是年份后两位,M是月份,d是日数。1月和2月要按上一年的13月和 14月来算,这时C和y均按上一年取值。)
算出来的W除以7,余数是几就是星期几。如果余数是0,则为星期日。
以2049年10月1日(100周年国庆)为例,用蔡勒(Zeller)公式进行计算,过程如下:
蔡勒(Zeller)公式:w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1
=49+[49/4]+[20/4]-2×20+[26× (10+1)/10]+1-1
=49+[12.25]+5-40+[28.6]
=49+12+5-40+28
=54 (除以7余5)
即2049年10月1日(100周年国庆)是星期5。
例
代码如下 | 复制代码 |
<?php |
结果: 3
如果没有全局变量global在方法内是不能获得$a,$b值的,所以在方法里面想用外面的变量就需要先声明这个变量为全局变量,这样就可以使用了
总结:在函数体内定义的PHP Global变量,函数体外可以使用,在函数体外定义的global变量不能在函数体内使用,
$glpbal $a; $a=123; function f() { echo $a; //错误, }
再看看下面一例
代码如下 | 复制代码 |
function f() |
在用户自定义函数中,一个局部函数范围将被引入。任何用于函数内部的变量按缺省情况将被限制在局部函数范围内(包括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 |
2.优秀的访问器
代码如下 | 复制代码 |
//A.php 文件 |
再来看看$GLOBALS[]
代码如下 | 复制代码 |
$var3 = 1; |
//2 为什么$var2的打印结果是1,而$var4的打印结果为2呢?其实就是因为$var3的引用指向了$var4的引用地址。$var4的实际值并没有改变。官方的解释是:$GLOBALS['var']是外部的全局变量本身,global $var是外部$var的同名引用或者指针。
也许这个例子还不是很清晰,我再引入一个例子:
代码如下 | 复制代码 |
$var2 = 1; |
echo $var2; //1 $var1的值被删除,而$var2的值还存在。这就证明,$var2只是别名引用,本身的值没有受到任何的改变。也就是说global $var其实就是$var = &$GLOBALS['var'],调用外部变量的一个别名而已!