>백엔드 개발 >PHP 튜토리얼 >시나 레쥬의 면접 질문과 나의 답변, 그리고 필기시험 문제에 대한 몇 가지 제안이 담겨 있다고 합니다.

시나 레쥬의 면접 질문과 나의 답변, 그리고 필기시험 문제에 대한 몇 가지 제안이 담겨 있다고 합니다.

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB원래의
2016-07-29 08:56:101133검색
1.
1. 다음 HTML이 있습니다: >1 ) js를 사용하여 객체를 얻기 위해 _________ 메소드를 얻습니다.
2) ________ 속성을 사용하여 속성 제목의 속성 값을 얻습니다. ) ________ 메소드를 사용하여 sina_title 속성의 속성 값을 얻습니다.
(1) document.getElementById('img1');
(2) document.getElementById ('img1').getAttribute('title');
(3) document.getElementById('img1').getAttribute('sina_title');
2. PHP의 쌍 배열 직렬화 및 역직렬화 함수는 각각 ______ 및 _______입니다.
직렬화, 업직렬화
3 rawurlencode 함수와 urlencode 함수의 차이점은 ____________________입니다.
rawurlencode는 공백을 +로 변환하고, urlencode는 공백을
으로 변환합니다. 4. PHP에서 HTML을 필터링하는 함수는 _______이고 이스케이프 함수는 _ ___________입니다.
strip_tags,htmlspecialchars
5. HTML에서 js 스크립트를 필터링하는 일반 규칙을 작성합니다.
preg_replace(' /< script.*?/script>/is','',$htmlcode);
6. SQL에서 LEFT JOIN의 의미는 ______________

Left Join은 먼저 왼쪽 테이블의 데이터를 모두 꺼낸 후, where 조건을 만족하는 오른쪽 테이블의 데이터를 꺼냅니다. 이 행의 데이터가 where 조건을 충족하지 않으면 비어 있는 값을 반환합니다.
tl.user에서 totalscore로 tu.name,sum(ts.score)를 선택하고 tl.uid에서 tl_score에 합류합니다. = ts .uid;
7. 시스템 명령을 호출하는 세 가지 함수를 작성합니다.
system, passthru,exec
8. 배열을 처리하는 함수는
json_encode,json_decode
9입니다. PHP에서 변수 설정 여부를 결정하는 함수는 _______입니다. 비어 있음은 ____________입니다.
isset,empty
10입니다. error_reporting("E_ALL")과 ini_set("display_errors", "on")_______ ;
전자는 오류 표시 수준을 설정하는 것이고, E_ALL은 모든 오류(알림, 경고 및 오류 포함)를 표시한다는 의미입니다. 후자는 오류를 표시하도록 PHP를 설정하는 것입니다. 오류 표시 제어에서는 후자가 가장 높은 우선순위를 갖습니다.
11. PHP는 클라이언트 IP를 표시하는 사전 정의된 변수 ________을 작성합니다. 소스 URL은 __________에서 제공됩니다.
$_SERVER['REMOTE_ADDR'] ['HTTP_REFERER']
12. utf-8을 gbk로 변환하는 PHP 기능은 ___________
iconv('UTF-8', 'GBK',$str );
13. 문자열을 배열로 분할하는 PHP 함수는 __________이고, 숫자를 연결하여 문자열을 형성하는 함수는 _______입니다. 🎜>14. PHP에서 클래스의 정적 메소드를 사용하는 방법_______________________________
클래스 외부에서는 클래스 이름 뒤에 이중 콜론을 사용하고 메소드 이름은 다음과 유사합니다. classname::staticFucntion(). static 메소드는 객체에 속하지 않고 클래스 전체에 속하므로 클래스 이름으로 호출해야 합니다.
2.
1. mysql 서버가 사라지지 않는 이유는 무엇인가요? (아마도 그럴겁니다)
mysql이 없어졌겠죠?
일반적으로 max_allowed_packet에 설정된 값이 너무 작아서 발생합니다. max_allowed_packet은 버퍼의 패킷 크기를 제어하는 ​​데 사용됩니다. 때로는 데이터를 가져올 때 이 값이 너무 작으면 버퍼 용량이 부족할 수 있습니다. my.ini 또는 my.cnf에서 이 값을 더 크게 설정하면 문제를 해결할 수 있습니다.
또 다른 가능성은 데이터베이스에 연결할 때 싱글톤 모드를 사용하는 것입니다. 데이터베이스는 여러 번 작동하지만 동일한 연결이 사용됩니다. MySQL은 대기열 모드에서 각 스레드를 처리하므로 현재 작업은 다음과 같습니다. still 이 문제는 실행이 완료되지 않고 wait_timeout에서 설정한 값보다 간격이 작은 경우에 발생할 수 있습니다. 해결 방법은 wait_timeout 값을 크게 설정하는 것입니다.
2. mysql의 정적 테이블과 동적 테이블의 차이점, MyISAM과 InnoDB의 차이점은
정적 테이블은 varchar를 사용하지 않는 경우이다. blob, text 이러한 가변 길이 필드가 있는 경우 해당 테이블은 정적 테이블입니다. 반면, 테이블에 가변 길이 필드가 하나 이상 포함되어 있거나 ROW_FORMAT=DYNAMIC 옵션을 사용하여 테이블을 생성한 경우에는 테이블이 정적 테이블입니다. 테이블은 동적 테이블입니다.
myisam과 innodb의 차이점은 myisam은 커밋 작업을 수행할 필요가 없기 때문에 트랜잭션 처리를 지원하지 않으므로 작업 속도가 innodb보다 빠릅니다. innodb는 트랜잭션 처리, 삽입, 업데이트, 삭제, 선택을 지원하므로 보안 측면에서 myisam보다 우수합니다. 작업의 기본값이 autocommit=0이면 각 작업은 트랜잭션으로 처리되어 롤백될 수 있습니다.autocommit=1이면 각 작업 후에 자동으로 트랜잭션을 커밋하므로 실행 효율성이 매우 느려지며 아마도 myisam보다 10배 느릴 것입니다.
3. $a = 1; $b = & $a;
unset($a), $b가 여전히 1인가요?
설정되지 않음($b), $a가 여전히 1인가요?
은 모두 1입니다.
PHP에서 참조 할당은 포인터와 다릅니다. 단지 다른 변수 이름이 특정 메모리 주소를 가리킬 뿐입니다. 이 질문에서는 $b = &$a; $b라는 이름이 $a 변수가 가리키는 메모리 주소를 가리킵니다. 설정하지 않으면 이 이름에 대한 포인터만 해제되고 메모리의 값은 해제되지 않습니다. 반면에 unset($a)는 실제로 메모리에 있는 값을 즉시 해제하지 않고 이 이름의 포인터만 해제합니다. 이 함수는 변수 값이 차지하는 공간이 256바이트를 초과하는 경우에만 값을 해제합니다. 메모리는 해제되고, 값을 가리키는 모든 변수(예: 값을 가리키는 참조 변수)가 소멸된 경우에만 주소가 해제됩니다.
3.
1. 3개 이상의 함수를 작성하고 '/as/image/bc.jpg' 파일과 같이 파일 이름의 접미사를 사용합니다. , jpg 또는 .jpg를 얻습니다.
function myGetExtName1( $path ){
//이 문자의 마지막 발생 위치를 가져옵니다.
$begin = strrpos ($path,'.');
//전체 문자열 길이 가져오기
$end = strlen($path);
//마지막 인덱스 위치에서 문자열의 전체 길이를 가로채는 결과가 반환됩니다.
return $begin?substr($path,$begin,$end): '파일에 확장자가 없습니다.';
}
function myGetExtName2( $path ){
return preg_match_all('/. [^. ]+/is',$path,$m)?$m[0][count($m[0])-1]:'파일에 확장자가 없습니다.';
}
function myGetExtName3( $path ){
// . 문자가 마지막으로 나타나는 인덱스 위치를 찾아 그 뒤의 모든 문자를 함께 반환합니다.
return strrchr($path,'.')?strrchr($path,'.'):'파일에 확장자가 없습니다';
}
2. $a = '/a/b/c/d/e.php' $b = '/a/b/12/34와 같이 두 파일의 상대 경로를 계산하는 함수를 작성하세요. /c.php' ; $a를 기준으로 $b의 위상 경로를 계산합니다.
$a = '/a/b/c/d/e.php';
$b = '/a/b/12/34/c .php';
//$a를 기준으로 $b의 상대 경로 찾기
function getRelativelyPath($a,$b){
//배열로 분할
$a =explod('/',$a);
$b =explod('/',$ b);
$path = '';
//두 배열의 인덱스 재설정
$c = array_values ​​( array_diff($a,$b));
$d = array_values(array_diff($b,$a));

//경로 a의 파일 이름 제거
array_pop($c);
//경로 a의 디렉터리 이름을 다음으로 바꿉니다..
foreach($c as &$v) $v = '..';

//두 배열 병합
$e = array_merge($c,$d);
//접합 경로
foreach($e as &$v )
$path .= $v.'/';
return rtrim($path,'/');
}
3. 요소를 찾으려면 이진 방법(반감 검색 방법이라고도 함)을 사용하세요.
//특정 값이 배열에 존재하는지 확인하는 바이너리 메서드
function binSearchWithArray($array,$searchValue){
전역 $time;
if(count($array)>=1){
$mid = intval(count($array)/2);

echo 'th',$time++,'time
';

echo '현재 배열:' ; print_r($array);echo '
';


echo '검색 위치 색인:',$mid,'
';

echo '값:',$array[$mid],'

';

if($searchValue == $array[$mid]){
$time--;
$searchValue가 '.'에서 발견되었습니다. .' 번, 인덱스는 '.$mid.'
';

}
elseif($searchValue < $array[ $ mid]){
$array = array_slice($array,0,$mid);
return binSearchWithArray($array,$searchValue);
}
else{
$array = array_slice($array,$mid+1,count($array));
return binSearchWithArray($array,$searchValue);
}
}
$searchValue를 반환합니다.' found
';

}
$time = 1;
//찾을 배열
$array = array(1,5,8,101,13,19,25,50,60,199,35);
//찾을 값
$searchValue = 13;
//배열 정렬, 이분법의 핵심
sort($array);
echo '찾을 값은 다음과 같습니다.',$searchValue,'

';

echo binSearchWithArray($array,$searchValue) ;

솔직히 이 질문들은 어렵지 않지만, 그래도 제가 알고 싶은 기능이 많아서 일부 질문에 대해서는 정보를 확인했다는 점을 인정합니다. IDE의 도움 없이는 기억할 수 없습니다. 이전에 어떤 개념을 알고 이해했다고 하더라도 참조로 전달하는 등 오랫동안 손대지 않으면 점차 잊어버리게 됩니다.
인터뷰 중에 펜으로 글을 쓰라는 요청을 받습니다. 짧은 시간에 펜으로 이 모든 것을 쓸 수 있는 사람은 거의 없을 것입니다. 특히 나중에 코드를 작성하는 사람은 필요하기 때문입니다. 생각하는 과정에서 논리에 허점이 있을 것입니다. 무엇이 잘못되었는지 이해하려면 코드를 실행해야 합니다. 컴퓨터로 작성하더라도 다음 코드 중 일부를 작성하는 데는 여전히 2~3시간이 걸렸습니다.
면접에서 보는 필기시험은 정말 출제되는 문제인 것 같아요. 저만 그렇게 느낀 건 아니겠죠? 저번에 텐센트에 면접보러 갔을 때 필기시험 문제 때문에 당황했어요. 그곳에 도착했을 때 마음은 텅 비어 있었습니다. 집에 돌아온 후, 나는 천천히 질문들을 떠올렸고 그 질문들은 모두 쓸 수 있다는 것을 깨달았습니다.

여러분 제 답변을 보시고 혹시 누락된 부분이나 오류가 있는지 확인해 보세요. 이런 내용은 전혀 쓸모가 없다고 생각하고 그냥 사용하는 것이 부적절하다고 생각합니다. 인터뷰 중 필기 시험 질문으로. 여러 회사에서 면접을 보시는 분들 모두 제 의견을 참고하셔서 좀 더 합리적인 평가 방법으로 바꾸셨으면 좋겠습니다.

원본 주소: http://bbs.csdn.net/topics/340149214

위에는 시나 레주가 출제했다고 하는 인터뷰 질문과 저의 답변, 그리고 내용을 포함한 필기 시험 문제에 대한 몇 가지 제안이 PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.