1、echo count(“abc”); 输出什么?
答:"1"count
— 计算数组中的单元数目或对象中的属性个数int count ( mixed var\[,intvar \[, intvar\[,intmode ] ), 如果 var 不是数组类型或者实现了 Countable 接口的对象,将返回 1,
有一个例外,如果 var 是 NULL 则结果是 0。对于对象,如果安装了 SPL,可以通过实现 Countable 接口来调用 count()。该接口只有一个方法 count(),此方法返回 count() 函数的返回值。
2、用PHP写出显示客户端IP与服务器IP的代码
答:$_SERVER[‘SERVER_ADDR’] 服务器
$_SERVER[‘REMOTE_ADDR’]客户端
function getOnlineIP(){
if (getenv('HTTP_CLIENT_IP')) return getenv('HTTP_CLIENT_IP');
if (getenv('HTTP_X_FORWARDED_FOR')) return getenv('HTTP_X_FORWARDED_FOR');
if ($_SERVER["REMOTE_ADDR"]) return $_SERVER["REMOTE_ADDR"];
if (!empty($HTTP_SERVER_VARS['REMOTE_ADDR'])) return $HTTP_SERVER_VARS['REMOTE_ADDR'];
}
复制代码
3、error_reporting(2047)什么作用?
答:PHP 显示所有错误 E_ALL
4、Js表单弹出对话框的函数是什么,并简要描述。
alert(); 只是提示信息 无返回值
confirm; 点确实返回true 否则false
5、下面的程序会输入是否?
$num = 10;
function multiply(){
$num = $num * 10;
}
Multiply();
echo $num;
?>
复制代码
答案:10 若要调用 函数中使用globle $num;
6、echo,print()和print_r()有什么区别?
echo是一个语言结构,没有返回值。
print是一个函数,返回int类型的值。[只能打印int string]
print_r()是一个函数,返回bool类型值,按结构输出变量的值。打印关于变量的易于理解的信息[数组、对象等]
7、isset();empty();有什么区别?对于不同的数据的判断的结果?
a=0;
a=0;a=’0’;
a=false;
a=false;a=null;
empty
如果 变量 是非空或非零的值,则 empty() 返回 FALSE。换句话说,""、0、“0”、NULL、FALSE、array()、var $var、未定义; 以及没有任何属性的对象都将被认为是空的,如果 var 为空,则返回 TRUE。
isset
如果 变量 存在(非NULL)则返回 TRUE,否则返回 FALSE(包括未定义)。变量值设置为:null,返回也是false;unset一个变量后,变量被取消了。注意,isset对于NULL值变量,特殊处理。
8、引用和拷贝有什么区别?
拷贝是将原来的变量内容复制下来,拷贝后的变量与原来的变量使用各自的内存,互不干扰。
引用相当于是变量的别名,其实就是用不同的名字访问同一个变量内容。当改变其中一个变量的值时,另一个也跟着发生变化。
9、打开php.ini中的Safe_mode,会影响哪些函数?至少说出6个。
答:
用户输入输出函数(fopen() file() require(),只能用于调用这些函数有相同脚本的拥有者)
创建新文件(限制用户只在该用户拥有目录下创建文件)
用户调用popen() systen() exec()等脚本,只有脚本处在safe_mode_exec_dir配置指令指定的目 录中才可能
加强HTTP认证,认证脚本拥有者的UID的划入认证领域范围内,此外启用安全模式下,不会设置PHP_AUTH
mysql服务器所用的用户名必须与调用mysql_connect()的文件的拥有者用户名相同
受影响的函数变量以及配置命令达到40个
10、写个函数来解决多线程同时读写一个文件的问题。
答:flock($hander,LOCK_EX); 这个可是内置函数啊
11、请写一个函数验证电子邮件的格式是否正确(要求使用正则)
答:preg_match(’/^ [\w-.]+@[\w-]+(.\w+)+/’,/’,/’,email);
12、写出匹配URL的正则表达式。
preg_match(’/(\w+)😕/([/:]+)(:\d*)?([# ]*)/’,$url);
13、写出发帖数量最多的5~15个人名字的SQL语句,利用下表;
Members(id,username,posts,pass,email);
select username from Members order by 发帖数量 desc limit 4,10
复制代码
14、MySQL数据库,一天5万条以上的增量,怎么优化?
a. 设计良好的数据库结构,允许部分数据冗余,尽量避免join查询,提高效率。
b. 选择合适的表字段数据类型和存储引擎,适当的添加索引。
c. mysql库主从读写分离。
d. 找规律分表,减少单表中的数据量提高查询速度。
e. 添加缓存机制,比如memcached,apc等。
f. 不经常改动的页面,生成静态页面。
g. 书写高效率的SQL。
15、写出一种排序算法(要写出代码),并说出优化它的方法。
//冒泡排序
function maopao($arr) {
$count = count($arr);
for($i=0; $i
for($j=0; $j
if($arr[$j] > $arr[$j+1]) {
$temp = $arr[$j];
$arr[$j] = $arr[$j+1];
$arr[$j+1] = $temp;
}
}
}
return $arr;
}
//顺序排序
function shunxu($arr) {
$count = count($arr);
for($i=0; $i
$p = $i;
for($j=$i+1; $j
$p = $arr[$p] > $arr[$j] ? $j : $p;
}
if($p != $i) {
$tvalue = $arr[$i];
$arr[$i] = $arr[$p];
$arr[$p] = $tvalue;
}
}
return $arr;
}
复制代码
16、写个函数用来对二维数组排序。
function array_sort_by_any_row($array_name, $row_id, $order_type){
$array_temp=array();
foreach($array_name as $key=>$value){
$array_temp[$key]=$value[$row_id];
}
if($order_type==="ASC"){ //顺序
asort($array_temp);
} else {
arsort($array_temp);
}
$result_array=array();
foreach($array_temp as $key=>$value){
$result_array[$key]=$array_name[$key];
}
return $result_array;
}
$arr = array(
array('num'=>5, 'value'=>6),
array('num'=>2, 'value'=>39),
array('num'=>36, 'value'=>29)
);
$sortarr = array_sort_by_any_row($arr, 'num', 'DESC');
print_r($sortarr);
复制代码
17、写5个不同的自己的函数,来截取一个全路径的文件的扩展名,允许封装php库中已有的函数。
$path = str_replace('\\', '/',__FILE__);
echo $path.'
';
function extname1($path) {
return strrchr($path, '.');
}
function extname2($path) {
$position = strrpos($path, '.');
return substr($path, $position);
}
function extname3($path) {
$arr = explode('.', $path);
return $arr[count($arr) - 1];
}
function extname4($path) {
preg_match_all('/[\w\/\:\-]+\.([\w]+)$/', $path, $out);
return $out[1][0];
}
function extname5($path) {
return preg_replace('/^[^\.]+\.([\w]+)$/', '${1}', basename($path));
}
print_r(extname5($path));
复制代码
18、一群猴子排成一圈,按1,2,…,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去…,如此不停的进行下去,直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n, 输出最后那个大王的编号。
function yuesefu($n,$m) {
$r=0;
for($i=2; $i<=$n; $i++) {
$r=($r+$m)%$i;
}
return $r+1;
}
print_r(yuesefu(3,3));
复制代码
19、用少量代码实现“Welcome to CCRF”字符串的反转?
function rev($var) {
$i = 0;
while ($var[$i] ==='') {
$i++; //得到字符长度
}
$data = '';
for ($j = $i-1 ; $j >= 0; $i-- ) {
$data .= $var[$j];
}
return $data;
}
复制代码
20、写一个函数,能够便利指定目录的文件。
/*
*定义一个函数 查看一个指定目录的所有文件 包含子文件
*$dir 指定目录名字
*/
function show_dir($dir) {
$files = array();
if(is_dir($dir)) {
if($dh = opendir($dir)) {
while (($file = readdir($dh)) !== false) {
if($file != "." && $file != "..") {
if(is_dir($dir."/".$file)) { //如果子文件是目录则 递归调用 以该子文件的名字作为数组的索引
$files[$file] = show_dir($dir."/".$file);
} else { //不是文件则直接 存入数组
$files[] = $dir."/".$file;
}
}
}
closedir($dh);
return $files;
}
}
}
复制代码
21、有一组数,28、32、43、14、53、67、42、54、46、31写程序排列这组数(要求:第一个是最大的,第二个是最小的,第三个是剩下中最大的,第四个是剩下最小的,第五个是剩下中最大的,第六个是剩下中最小的,依次向下排列。
$a = array(28, 32, 43, 14, 53, 67, 42, 54, 46, 31);
$b = array(28, 32, 43, 14, 53, 67, 42, 54, 46, 31);
rsort($a); //对数组逆向排序
sort($b); //对数组顺向排序
$num = sizeof($a); //计算数组中的单元数目或对象中的属性个数
for($i=0; $i<=$num/2-1; $i++) {
$x[$i*2] = $a[$i];//把最小的放在第二位上
$x[$i*2+1] = $b[$i];//把最大的放在第一位
}
print_r($x);
//Array ( [0] => 67 [1] => 14 [2] => 54 [3] => 28 [4] => 53 [5] => 31 [6] => 46 [7] => 32 [8] => 43 [9] => 42 )
?>
复制代码
点关注,不迷路
好了各位,以上就是这篇文章的全部内容了,能看到这里的人呀,都是人才。之前说过,PHP方面的技术点很多,也是因为太多了,实在是写不过来,写过来了大家也不会看的太多,所以我这里把它整理成了PDF和文档,如果有需要的可以
以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家,需要的可以加入我的