ホームページ > バックエンド開発 > PHPチュートリアル > 古典的な PHP 面接質問集、古典的な PHP テスト質問集_PHP チュートリアル

古典的な PHP 面接質問集、古典的な PHP テスト質問集_PHP チュートリアル

WBOY
リリース: 2016-07-13 10:02:12
オリジナル
1150 人が閲覧しました

古典的な PHP 面接質問集、古典的な PHP テスト質問集

この記事では、古典的な PHP 面接質問をより詳細に分析します。参考のためにみんなで共有してください。詳細は以下の通りです

インターネットで PHP の質問をいくつかしましたが、知らず知らずのうちにこの時点に到達しました...参考のために回答を投稿します。

1. PHP を使用して、前日の時刻を 2006-5-10 22:21:21 の形式で出力します (2 点)

リーリー

2. echo()、print()、print_r()の違い(3点)
echo と print は関数ではなく、言語構造です
int print(string $arg)、パラメータは 1 つだけ
echo arg1,arg2; は複数のパラメータを出力して void を返すことができます
echo と print は文字列のみを出力でき、構造体は出力できません
print_r は構造を出力できます
たとえば

リーリー

3. HTMLとPHPを使い分けできるテンプレート(1点)
賢い、phplib

4. バージョン管理に使用されるツールは何ですか? (1 点)
svn、git、CVS

5.文字列反転の実装方法(3つのポイント)
英語:
strrev($a)
中国語またはその他のテキスト:
中国語: GB2312、コードは GB2312 を使用してエンコードされています

リーリー

6. MYSQL データベースを最適化する方法。 (4 ポイント、さらに書くとさらに獲得)
文章的には:
1 インデックスを使用してクエリ効率を向上させます
2 クエリステートメントを最適化し、インデックスのヒット率を向上させます
関連するデータベース:
1 サブデータベースとテーブルを構築して、データベースのストレージと拡張機能を向上させます
2 必要に応じて別のストレージ エンジンを使用します

7. PHP の意味 (1 ポイントを獲得)
ハイパーテキスト前処理言語
ハイパーテキストプリプロセッサ

8. 現在時刻を取得するMYSQLの関数と日付をフォーマットする関数は何ですか?(2点)

リーリー

9. 中国語の文字列を文字化けせずにインターセプトする方法。 (3点)

リーリー

10. バージョン管理ソフトウェアを使用したことがありますか? (1 点) svn
ギット

11. テンプレート エンジンを使用したことがありますか? (1 点) 賢い


12. 最も誇りに思っている開発作業を簡単に説明してください (4 点)

XXX


13. トラフィックが多い Web サイトの場合、トラフィックの問題を解決するためにどのような方法を使用しますか?(4 つのポイント)

1 キャッシュを有効活用してキャッシュヒット率を高めます

2 負荷分散を使用する
3 CDN を使用して静的ファイルを保存し、高速化します
データベースの使用量を削減する 4 つのアイデア
5 統計上のボトルネックがどこにあるのかを確認します

14. PHPを使用して、クライアントIPとサーバーIPを表示するコードを記述します(1点)

$_SERVER["REMOTE_ADDR"]

$_SERVER["SERVER_ADDR"]

15. include ステートメントと require ステートメントの違いは何ですか? 同じファイルを複数回インクルードすることを避けるために、それらを (2 点) ステートメントに置き換えます。 失敗時:

include は警告を生成しますが、require はエラー割り込みを直接生成します

require は実行前にロードされます
インクルードは実行時にロードされます
一回だけ必要
include_once

16.SESSIONの生存時間(1分)を変更する方法
session_set_cookie_params

17. PHP研究所のホームページのようなアドレスがあります: http://www.bkjia.com/index.html そのコンテンツ(1ドルポイント)を入手するにはどうすればよいですか? file_get_contents
カール

18. HTTP 1.0 では、ステータス コード 401 の意味は (?)、プロンプト「ファイルが見つかりません」が返された場合、そのステートメントは (?) です。 無許可

リーリー

高速 CGI:


リーリー
19. PHP では、ヒアドキュメントは特殊な文字列であり、その終了マークは次のようになります。(1 ポイント)

ペアで登場


リーリー

20.asp、php、jspの長所と短所について話します(1点)

ASP は IIS に依存する必要があり、Microsoft によって開発された言語です
PHP と JSP は、Apache や nginx などの他のサーバーに依存できます

21. mvc についての理解について話します (1 点)

モデル: データ構造層
ビュー:
を表示 制御: 入力を受信して​​判断して処理します

22. 次の表を使用して、最も投稿数の多い 10 人の名前の SQL を作成します: メンバー (ID、ユーザー名、投稿、パス、電子メール) (2 点)
メンバーからトップ10のID、ユーザー名を選択 投稿の説明で注文

23. PHPにおける値渡しと参照渡しの違いを説明してください。いつ値で渡すのか、いつ参照で渡すのか (2​​ 点)

& は参照を渡すことを意味します

関数内でパラメータを参照渡しするとパラメータが変更されます
一般に、複数の出力パラメーターがある場合は、参照の使用を検討できます

24. PHPのerror_reportingの機能とは何ですか?(1点)
エラーの表示レベルを設定します

25. メールの形式が正しいかどうかを検証する関数を書いてください(2点)

リーリー
26. 取得したパラメータを含む、現在の実行スクリプトのパスを取得する方法を簡単に説明します。 (2点)

$argc -- パラメータの数を取得します

$argv -- パラメータリストを取得します

27.SESSIONの生存時間を変更する方法(1点)

session_set_cookie_params

28. JSフォームでダイアログボックスをポップアップさせる関数とは何ですか?(2点)

アラート()
確認()

プロンプト()

フォーカス()


29. JSのリダイレクト機能とは何ですか?(2点)

リーリー
30. foo() と @foo() の違いは何ですか? (1 点)

@ はすべての警告を表し、無視されます


31、如何声明一个名为”myclass”的没有方法和属性的类? (1分)

class myclass
{
}
ログイン後にコピー

32、如何实例化一个名为”myclass”的对象?(1分)

$myclass = new myclass();
ログイン後にコピー

33、你如何访问和设置一个类的属性? (2分)

<&#63;php
class A
{
 public $name = "A";
}
$a = new A();
n=a->name;
print_r($n);
ログイン後にコピー

34、mysql_fetch_row() 和mysql_fetch_array之间有什么区别? (1分)
mysql_fetch_array() 是 mysql_fetch_row() 的扩展版本。除了将数据以数字索引方式储存在数组中之外,还可以将数据作为关联索引储存,用字段名作为键名。

<&#63;php
mysql_connect("localhost", "mysql_user", "mysql_password") or
die("Could not connect: " . mysql_error());
mysql_select_db("mydb");
$result = mysql_query("SELECT id, name FROM mytable");
while (row=mysqlfetcharray(result, MYSQL_ASSOC)) {
printf ("ID: %s Name: %s", row["id"],row["name"]);
}
mysql_free_result($result);
ログイン後にコピー

35、GD库是做什么用的? (1分)

动态的开放的图片处理库

36、指出一些在PHP输入一段HTML代码的办法。(1分)

echo "{html}"
echo <<EOD
{html}
EOD;
ログイン後にコピー

37、下面哪个函数可以打开一个文件,以对文件进行读和写操作?(1分) c
(a) fget() (b) file_open() (c) fopen() (d) open_file()

38、下面哪个选项没有将 john 添加到users 数组中? (1分) b
(a) $users[] = ‘john';
(b) array_add($users,'john');
(c) array_push($users,‘john');
(d) $users ||= ‘john';

39、下面的程序会输入是否?(1分) 10

$num = 10;
function multiply(){
num=num * 10;
}
multiply();
echo $num;
&#63;>
ログイン後にコピー

40、使用php写一段简单查询,查出所有姓名为“张三”的内容并打印出来 (2分)
表名 UserName Tel Content Date
 张三 13333663366 大专毕业 2006-10-11
 张三 13612312331 本科毕业 2006-10-15
 张四 021-55665566 中专毕业 2006-10-15
请根据上面的题目完成代码:

$mysql_db=mysql_connect("local","root","pass");
@mysql_select_db("DB",$mysql_db);
$sql = sprintf("select * from %s where UserName = '%s'", 
 "表名", 
 "张三");
values=mysqlquery(sql);
while(item=mysqlfetchqueryarray(values))
{
 echo sprintf("用户名:%s, 电话 %s, 学历: %s, 毕业日期: %s", 
 item['UserName'],item['Tel'], item['Content'],item['Date']
 );
}
ログイン後にコピー

41、如何使用下面的类,并解释下面什么意思?(3)

class test{
function Get_test($num){
num=md5(md5(num)."En");
return $num;
}
}
$test = new test();
ret=test->Get_test(11);
print_r($ret);exit;
ログイン後にコピー

将num进行MD5编码之后生成的32位字符串a1和"En"联系起来之后再进行一次MD5编码

42、写出 SQL语句的格式 : 插入 ,更新 ,删除 (4分)
表名 UserName Tel Content Date
   张三 13333663366 大专毕业 2006-10-11
   张三 13612312331 本科毕业 2006-10-15
   张四 021-55665566 中专毕业 2006-10-15
(a) 有一新记录(小王 13254748547 高中毕业 2007-05-06)请用SQL语句新增至表中
insert into 表名 values('小王', '13254748547', '高中毕业', '2007-05-06')
(b) 请用sql语句把张三的时间更新成为当前系统时间
update 表名 set Date = GETDATE() where UserName = "张三"
(c) 请写出删除名为张四的全部记录
delete from 表明 where UserName = "张四"

43、请写出数据类型(int char varchar datetime text)的意思; 请问varchar和char有什么区别(2分)
int 整型
char 存储定长
varchar 存储变长
datetime 时间
text 存储变长的
varchar是变长
char(20) 定长

44、MySQ自增类型(通常为表ID字段)必需将其设为(?)字段(1分)
auto_increment
45、写出以下程序的输出结果 (1分)

$b=201;
$c=40;
a=b>$c&#63;4:5;
echo $a;
ログイン後にコピー

46、检测一个变量是否有设置的函数是否?是否为空的函数是?(2分)
isset()
empty()

47、取得查询结果集总数的函数是?(1分)

mysql_num_rows()
ログイン後にコピー

48、$arr = array('james', 'tom', 'symfony'); 请打印出第一个元素的值 (1分)

print_r($arr[0]);
reset($arr);
print_r(current($arr));
print_r(array_shift($arr));
ログイン後にコピー

49、请将41题的数组的值用','号分隔并合并成字串输出(1分)
implode

50、a='abcdef';请取出a的值并打印出第一个字母(1分)

$a[0];
substr($a, 0, 1);
ログイン後にコピー

51、PHP可以和sql server/oracle等数据库连接吗?(1分)
可以
有现成的库

52、请写出PHP5权限控制修饰符(3分)
public
private
protected

53、请写出php5的构造函数和析构函数(2分)

public function __construct()
{
}
public function __destruct()
{
}
ログイン後にコピー

编程题:

1. 写一个函数,尽可能高效的,从一个标准 url 里取出文件的扩展名
例如: http://www.sina.com.cn/abc/de/fg.php?id=1 需要取出 php 或 .php

<&#63;php
$url = "http://www.sina.com.cn/abc/de/fg.php&#63;id=1";
arr=parseurl(url);
pathArr=pathinfo(arr['path']);
print_r($pathArr['extension']);
ログイン後にコピー

3. 写一个函数,算出两个文件的相对路径
如 $a = '/a/b/c/d/e.php';
$b = '/a/b/12/34/c.php';
计算出 b相对于a 的相对路径应该是 http://www.bkjia.com/12/34/c.php将添上

<&#63;php
$a = '/a/b/c/d/e.php';
$b = '/a/b/12/34/c.php';
//获取path相对于conpath的相对路径
function sGetRelativePath(path,conpath)
{
 pathArr=explode("/",path);
 conpathArr=explode("/",conpath);
 $dismatchlen = 0;
 for(i=0;i < count(pathArr);i++)
 {
 if(conpathArr[i] != pathArr[i])
 {
  dismatchlen=count(pathArr) - $i;
  arrLeft=arrayslice(pathArr, $i);
  break;
 }
 }
 ret=strrepeat("../",dismatchlen).implode("/", $arrLeft);
 return $ret;
}
print_r(sGetRelativePath(b,a));
ログイン後にコピー

3.写一个函数,能够遍历一个文件夹下的所有文件和子文件夹。

<&#63;php
function aGetAllFile($folder)
{
 $aFileArr = array();
 if(is_dir($folder))
 {
 handle=opendir(folder);
 while((file=readdir(handle)) !== false)
 {
  //如果是.或者..则跳过
  if(file=="."||file == "..")
  {
  continue;
  }
  if(is_file(folder."/".file))
  {
  aFileArr[]=file; 
  }
  else if(is_dir(folder."/".file))
  {
  aFileArr[file] = aGetAllFile(folder."/".file);
  }
 }
 closedir($handle);
 }
 return $aFileArr;
}
$path = "/home/test/sql";
print_r(aGetAllFile($path));
ログイン後にコピー

希望本文所述对大家的php程序设计有所帮助。

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/970855.html技術記事 PHP の古典的な面接の質問集、PHP の古典的なテストの質問集 この記事では、PHP の古典的な面接の質問をより詳細に分析します。参考のためにみんなで共有してください。詳細は次のとおりです: インターネットで php の質問をいくつかしました...
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート