自己对之前sina面试题的一个总结

2023-10-25 11:38
文章标签 总结 面试题 之前 sina

本文主要是介绍自己对之前sina面试题的一个总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 1. echo count("abc"); 输出什么?
:"1"
count —计算数组中的单元数目或对象中的属性个数
int count (mixed$var [, int$mode ] ), 如果 var 不是数组类型或者实现了Countable 接口的对象,将返回 1,有一个例外,如果 varNULL 则结果是 0
对于对象,如果安装了 SPL,可以通过实现Countable 接口来调用 count()。该接口只有一个方法 count(),此方法返回 count() 函数的返回值。




2. 用PHP写出显示客户端IP与服务器IP的代码
:$_SERVER['SERVER_ADDR']服务器  

$_SERVER['REMOTE_ADDR']客户端

functiongetOnlineIP (){

        if (
getenv ( 'HTTP_CLIENT_IP' )) returngetenv ( 'HTTP_CLIENT_IP' );

        if (
getenv ( 'HTTP_X_FORWARDED_FOR' )) returngetenv ( '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. echo,print()和print_r()有什么区别?
:echo是一个语言结构,没有返回值。
print是一个函数,返回int类型的值。[只能打印int string]
print_r()是一个函数,返回bool类型值,按结构输出变量的值。打印关于变量的易于理解的信息[数组、对象等]

5. 打开php.ini中的Safe_mode,会影响哪些函数?至少说出6个。
:1:用户输入输出函数(fopen() file()require(),只能用于调用这些函数有相同脚本的拥有者)
2:创建新文件(限制用户只在该用户拥有目录下创建文件)
3:用户调用popen() systen()exec()等脚本,只有脚本处在safe_mode_exec_dir配置指令指定的目   录中才可能
4:加强HTTP认证,认证脚本拥有者的UID的划入认证领域范围内,此外启用安全模式下,不会设置PHP_AUTH
5:mysql服务器所用的用户名必须与调用mysql_connect()的文件的拥有者用户名相同
6:受影响的函数变量以及配置命令达到40个

6. 写个函数来解决多线程同时读写一个文件的问题
:flock($hander,LOCK_EX);这个可是内置函数啊,
这个尚待解决

7. 请写一个函数验证电子邮件的格式是否正确(要求使用正则
:preg_match('/^[/w/-/.]+@[/w/-]+(/./w+)+$/',$email);

8. 考SQL语句的题,题太长了,实在不好回忆了。
:去理解别人的回忆是件很困难的事情

9. MySQL数据库,一天一万条以上的增量,怎么优化?
答:我们曾做过短信SP的东西,有个短信发送的日志表,每天增量也很大,处理的方法是按月进行分表,因为是日志表,主要操作是insert操作,所以每月初自动生成新的数据表,数据插入到对应月份的那张数据表。[比如表明前缀是cdb_smslog后面加200910 及时cdb_smslog_200910]
其他优化方式暂时想不起来,对于myISAM, 考虑容量的话,也有优化的方案

但是对于那种查询操作的表的话,我的思路是根据作者的发布时间存储到不同的表里面

所以对sina那种海量数据的处理很感兴趣,很好奇他们的处理方法,[以前同事说sina 的首页同时操作10多个数据库]

10. 写出一种排序算法(要写出代码),并说出优化它的方法。
答:

//冒泡排序

function maopao ( $arr ) {

    
$count = count ( $arr );

     for(
$i = 0 ; $i < $count - 1 ; ++ $i ) {

        for(
$j = 0 ; $j < $count - $i - 1 ; ++ $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 < $count - 1 ; ++ $i ) {

       
$p = $i ;

        for(
$j = $i + 1 ; $j < $count ; ++ $j ) {

          
$p = $arr [ $p ] > $arr [ $j ] ? $j : $p ;

        }

        if(
$p != $i ){

          
$tvalue = $arr [ $i ];

           
$arr [ $i ] = $arr [ $p ];

          
$arr [ $p ] = $tvalue ;

        }

     }

     return
$arr ;

}
复制代码

ps:有人说加个监控,计算数组交换的频度[这对冒泡],比如冒泡的第一次操作频度为0,则无需操作,直接返回,因为已经是排好序的数组

11. 写个函数用来对二维数组排序。

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 );
复制代码

12. 写5个不同的自己的函数,来截取一个全路径的文件的扩展名,允许封装php库中已有的函数。

$path = str_replace ( '//' , '/' , __FILE__ );

echo
$path . '<br />' ;

function
extname1 ( $path ) {

    
returnstrrchr ( $path , '.' );

}



function
extname2 ( $path ) {

    
$position = strrpos ( $path , '.' );

    
returnsubstr ( $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 ) {

    
returnpreg_replace ( '/^[^/.]+/.([/w]+)$/' , '${1}' , basename ( $path ));

}



print_r ( extname5 ( $path ));
复制代码

13.一群猴子排成一圈,按1,2,...,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去...,如此不停的进行下去,直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n,输出最后那个大王的编号。

yuesefu环问题,PPC有很多针对这个问题的处理,我的就不上啦

function yuesefu ( $n , $m ) {

   
$r = 0 ;

     for(
$i = 2 ; $i <= $n ; $i ++) {

      
$r =( $r + $m )% $i ;

     }

     return
$r + 1 ;

}

print_r ( yuesefu ( 3 , 3 ));

这篇关于自己对之前sina面试题的一个总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/282309

相关文章

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Nginx Location映射规则总结归纳与最佳实践

《NginxLocation映射规则总结归纳与最佳实践》Nginx的location指令是配置请求路由的核心机制,其匹配规则直接影响请求的处理流程,下面给大家介绍NginxLocation映射规则... 目录一、Location匹配规则与优先级1. 匹配模式2. 优先级顺序3. 匹配示例二、Proxy_pa

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

MySQL基本查询示例总结

《MySQL基本查询示例总结》:本文主要介绍MySQL基本查询示例总结,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Create插入替换Retrieve(读取)select(确定列)where条件(确定行)null查询order by语句li

Linux区分SSD和机械硬盘的方法总结

《Linux区分SSD和机械硬盘的方法总结》在Linux系统管理中,了解存储设备的类型和特性是至关重要的,不同的存储介质(如固态硬盘SSD和机械硬盘HDD)在性能、可靠性和适用场景上有着显著差异,本文... 目录一、lsblk 命令简介基本用法二、识别磁盘类型的关键参数:ROTA查询 ROTA 参数ROTA

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Windows Docker端口占用错误及解决方案总结

《WindowsDocker端口占用错误及解决方案总结》在Windows环境下使用Docker容器时,端口占用错误是开发和运维中常见且棘手的问题,本文将深入剖析该问题的成因,介绍如何通过查看端口分配... 目录引言Windows docker 端口占用错误及解决方案汇总端口冲突形成原因解析诊断当前端口情况解

springboot security之前后端分离配置方式

《springbootsecurity之前后端分离配置方式》:本文主要介绍springbootsecurity之前后端分离配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的... 目录前言自定义配置认证失败自定义处理登录相关接口匿名访问前置文章总结前言spring boot secu

java常见报错及解决方案总结

《java常见报错及解决方案总结》:本文主要介绍Java编程中常见错误类型及示例,包括语法错误、空指针异常、数组下标越界、类型转换异常、文件未找到异常、除以零异常、非法线程操作异常、方法未定义异常... 目录1. 语法错误 (Syntax Errors)示例 1:解决方案:2. 空指针异常 (NullPoi