ホームページ >php教程 >php手册 >PHPマスターになるにはどうすればよいですか? 「遅延」プログラミングを学ぶ

PHPマスターになるにはどうすればよいですか? 「遅延」プログラミングを学ぶ

WBOY
WBOYオリジナル
2016-06-21 09:00:221003ブラウズ

PHP は効率的なネットワーク プログラミング言語であり、柔軟な記述と高速な操作という利点により、すぐに Web プログラマーに好まれる言語になりました。少し前の権威ある調査によると、現在、Web サイトの 31.6% が主要なサーバー側プログラミング言語として PHP を使用しています。

しかし、PHP プログラミングのマスターになるのは簡単ではありません。多くの人が想像しているほどではありません。複雑な問題を解決するための簡単なコードをいくつか書くことができれば、あなたは PHP プログラミングのマスターです。真の PHP マスターには、他の多くの問題も考慮する必要があります。次の 3 つのガイドラインは、成熟した PHP プログラマーがプログラミングにおいて最初に従うべきガイドラインです。

1. 怠惰は金なり

2. 美しいコードを書く

3. プログラミングの速度ではなく、プログラムの速度を追求

1. 怠惰は金なり

あなたは怠惰なプログラマーですか?このアイデアはとても奇妙です!なぜなら、おそらく世界で最も忙しい人々はコンピュータープログラマーだからです。しかし、プログラマは忙しすぎるからこそ、プログラミングする際に怠けることを学ぶ必要があります。

プログラマーの場合、怠惰な方法が 2 つあります。1 つは、他の人の既成のプログラム コードを大胆に使用し、それらのコードを自分のプログラムまたはプロジェクトに統合することです。 2 つ目は、関数ライブラリを構築するための便利なコードを作成することです。これにより、将来プログラムを作成するときに簡単に使用できるようになり、繰り返しの作業が大幅に軽減され、自然と面倒な作業が軽減されます。
これら 2 つの遅延メソッドは、PHP プログラマーに非常に適しています。

まず、PHP は自由でオープンな環境で生まれ、成長した言語です。世界中には、PHP の完成度を目指して絶えず努力しているプログラマーが何千人もいます。また、彼らは自分の創意工夫や自分が書いたコードを他の人と共有することにも意欲を持っています。 PHP の Web サイト、メーリング リスト、ニュース グループからは、毎日多くの優れたプログラム コードを見つけることができます。これを言っても、他の人がコードを書いてくれるのを一日中待つことを勧めているわけではありませんが、「偉人の肩の上に立って」、他の人のプログラム コードをスマートに適用する「使用原則」を全面的に推進することはできます。多くの時間を節約できます。次に、PHP では独自の関数ライブラリを簡単に構築できるため、将来プログラムを作成する際に多くの手間を省くことができます。

以下の著者は、いくつかの一般的な関数を紹介します。これらの関数の一部はインターネット上のオープン ソース プロジェクトから提供されており、一部はメーリング リストから選択されています。それらを自分のライブラリに追加できれば、遅かれ早かれその恩恵を受けることになるでしょう。

1. 一般的なデータベース処理機能

他の CGI 機能と比較して、PHP の利点の 1 つは、非常に強力なデータベース処理機能を備えていることです。しかし、PHP では、さまざまなデータベースを処理するためにいくつかの特殊な関数が使用されており、一般的なデータベース処理関数が不足しています。これにより、プログラム コードの移植性が大幅に低下し、プログラミング初心者の友人にも多大な不便をもたらします。

インターネットでは、多くのプログラマーがクラスをカプセル化することでこの問題を解決しました。彼らは、Linux の世界で人気のある Mysql であっても、Windows プラットフォームで広く普及している SqlServer であっても、あらゆる一般的なデータベースを処理するための統合関数を作成しました。個人的には、これらの関数をとても気に入っています。使用しているデータベースを考慮するだけでなく、データベース接続やデータベース ハンドルなどの複雑なことを考慮することなく、「query」や「next_record」などの単純な関数を直接使用できるからです。 。

これらの関数が必要な場合は、次の URL にアクセスして入手できます:

http://phplib.netuse.de/
http://phpclasses.UpperDesign .com /browse.html/package/20
http://phpdb.linuxbox.com/

2. 変数デバッグ機能

PHP プログラムのデバッグは常に刺激的な作業です。重要なのは、VB などの高級言語のような統合されたコンパイルおよびデバッグ環境がなく、Perl のような Linux または DOS 環境で直接実行できないことです。実際、echo ステートメントを柔軟に使用することで、PHP のデバッグを完了できます。

次の関数を使用すると、プログラム内の任意の変数の型と値をいつでも確認できます。

function ss_array_as_string (&$array, $column = 0) {
$str = "Array(n";
while(list($var, $val) = each( $array)){
for ($i = 0; $i $str .= "    ";
> $str .= $var. ==>;
$str .= ss_as_string($val, $column+1)."
}
for ($i = 0; $i
$column; $i++){
$str .= "    ";
$str.)を返す, $column = 0); (empty($object->classname)) {
return "$object";
}
else {
$str = $object- >classname."( n";
while (list(,$var) = each($object->persistent_slots)) {
for ($i = 0; $i       $str .= "    ";
     }
     global $$var;
     $str .= $var. ==> ;
     $str .= ss_as_string($$var, column+1)." n";
    }
    for ($i = 0; $i < $column; $i++){
     $str .= "&nbsp;&nbsp;&nbsp;&nbsp;";
    }
    return $str.);
  }
 }
 function ss_as_string (&$thing, $column = 0) {
   if (is_object($thing)) {
    return ss_object_as_string($thing, $column);
   }
   elseif (is_array($thing)) {
    return ss_array_as_string($thing, $column);
   }
   elseif (is_double($thing)) {
    return "Double(".$thing.")";
   }
   elseif (is_long($thing)) {
    return "Long(".$thing.")";
   }
   elseif (is_string($thing)) {
    return "String(".$thing.")";
   }
   else {
    return "Unknown(".$thing.")";
   }
 }

  需要的时候,在程序中简单地加入下面的一条代码即可查看程序中的所使用的变量(包括数组和对象)的类型和值:

echo ss_as_string($my_variable);

  使用下面的语句,我们可以直接查看程序中所有的变量的值:

echo ss_as_string($GLOBALS);

  3. 控制Log信息的函数

  调试PHP程序的另外一种重要的方法就是查看Log信息。如果能够方便地控制Log信息的级别以及Log信息的显示内容,将会给程序调试带来更多的便利。下面的几个函数可以方便地实现这个功能。

$ss_log_level = 0;
$ss_log_filename = /tmp/ss-log;
$ss_log_levels = array(
 NONE => 0,
 ERROR => 1,
 INFO => 2,
 DEBUG => 3);
function ss_log_set_level ($level = ERROR) {
 global $ss_log_level;
 $ss_log_level = $level;
}
function ss_log ($level, $message) {
 global $ss_log_level, $ss-log-filename;
 if ($ss_log_levels[$ss_log_level] < $ss_log_levels[$level]) {
  // 不显示Log信息
  return false;
 }
 $fd = fopen($ss_log_filename, "a+");
 fputs($fd, $level. - [.ss_timestamp_pretty().] - .$message."n");
 fclose($fd);
 return true;
}
function ss_log_reset () {
 global $ss_log_filename;
 @unlink($ss_log_filename);
}

  在上面的函数中,有四个Log级别变量。运行PHP程序时,只有当Log的级别低于预设的级别值时,Log信息才可以被记录和显示出来。例如,在程序中加入如下的一条语句:

ss_log_set_level(INFO);

  那么,运行PHP程序时,只有ERROR和INFO级别的LOG信息才能被记录和显示出来,DEBUG级的信息则被忽略了。除此之外,我们还可以设定显示的信息内容,其语句如下:

ss_log(ERROR, "testing level ERROR");
ss_log(INFO, "testing level INFO");
ss_log(DEBUG, "testing level DEBUG");

  你也可以随时使用下面的语句清空LOG信息:

ss_log_reset();

  4.速度测试函数

  为了优化代码,我们 需要一种可以测试代码运行时间的方法,从而来选择最优的代码。下面的函数可以测试运行代码所需的时间:

function ss_timing_start ($name = default) {
 global $ss_timing_start_times;
 $ss_timing_start_times[$name] = explode( , microtime());
}
function ss_timing_stop ($name = default) {
 global $ss_timing_stop_times;
 $ss_timing_stop_times[$name] = explode(, microtime());
}
function ss_timing_current ($name = default) {
 global $ss_timing_start_times, $ss_timing_stop_times;
 if (!isset($ss_timing_start_times[$name])) {
  return 0;
 }
 if (!isset($ss_timing_stop_times[$name])) {
  $stop_time = explode(, microtime());
 }
 else {
  $stop_time = $ss_timing_stop_times[$name];
 }
 $current = $stop_time[1] - $ss_timing_start_times[$name][1];
 $current += $stop_time[0] - $ss_timing_start_times[$name][0];
 return $current;
}

  现在可以轻松地检查任何一段代码的执行时间了,甚至我们可以同时使用多个计时器,只需在使用上述的几个函数时设定不同的参数作为计时器的名称就可以了。

  5.调试和优化数据库的操作

  对于数据库来说,运行速度是至关重要的。尽管很多书籍和文章都讲授了一些快速运行数据库的方法,但是所有的方法都必须经过实践的检验。下面我们将把PHPLib函数库中的query()函数和上面介绍的几个函数综合起来编写成新的query()函数,和原先的函数相比,这个函数增加了运行时间的监测功能。

function query($Query_String, $halt_on_error = 1) {
 $this->connect();
 ss_timing_start();
 $this->Query_ID = @mysql_query($Query_String,$this->Link_ID);
 ss_timing_stop();
 ss_log(INFO, ss_timing_current(). Secs - .$Query_String);
 $this->Row = 0;
 $this->Errno = mysql_errno();
 $this->Error = mysql_error();
 if ($halt_on_error && !$this->Query_ID) {
  $this->halt("Invalid SQL: ".$Query_String);
 }
 return $this->Query_ID;
}

  二、编写漂亮的代码

  1.将后台程序与前端程序分开

  在编写PHP程序时,有些代码是用来处理一些事务,例如操作数据库、进行数学运算等,而另外的一些代码则只是事务处理的结果显示出来,例如一些使用echo语句将结果以HTML的格式显示在Web浏览器上的PHP代码以及那些直接嵌入PHP程序的HTML代码。首先我们应该清晰地区分这两种代码,把前者称为后台程序,把后者称为前端程序。

  因为PHP是一种嵌入式编程语言,也就是说,所有的PHP代码都可以嵌入到HTML代码之中,这为程序的编写带来了许多便利之处。但是,“物极必反”,如果在一段较长的程序中将PHP代码和HTML代码混合编写,这将使程序杂乱无章,不利于程序的维护和阅读。所以我们需要尽可能地将这些程序中混杂于HTML代码中的PHP代码移植出来,在专门的文件中将这些代码封装成函数,然后在HTML代码中使用include语句来包含这些文件,在适当的位置调用这些函数即可。

  这种做法一方面使HTML代码和PHP代码都简单易读,另一方面因为HTML代码需要不断更新,而这种分离的方法可以确保后台程序不会被破坏。

  同前端程序不同,后台程序更多追求的是稳定、结构化,极少更改,所以应该认真地设计和管理。其实,在设计台程序时,投入大量时间是值得的,“现在栽树,以后乘凉”,在以后的设计工作中将可以轻松地使用现在编写的后台程序。

  2.灵活使用包含文件

  正如前面所说的那样,后台程序应当安排在一系列的包含文件中。包含文件可以通过include语句在需要时动态装入,也可以在php.ini文件中通过使用auto_prepend_file指令预先自动装入。

  如果使用后一种方法的话,虽然取得了一劳永逸的好处,但是也有一些缺点值得我们注意。下面的一段代码向我们展示了解析一个庞大的包含文件需要一定的时间:

require(timing.inc);
ss_timing_start();
include(test.inc);
ss_timing_stop();
echo
.ss_timing_current().
;
?>

  在上面的代码中,test.inc是一个1000行的包含文件,运行的结果显示,解析这个包含文件花费了0.6秒钟,对于一个大型网站来说,这个速度并不是可以忽略不记的。

  使用包含文件的另外一个缺点是:如果一个文件中的一个语句发生错误,将会使整个网站的PHP程序都无法运行。所以使用起来也及其小心。

  其实,对包含文件稍做处理,即可以使包含文件只在需要时进行解析。下面的代码使abc.inc文件只在程序需要时才作解析:

if ( defined( __LIBA_INC) ) return;
define( __LIBA_INC, 1 );
/*
* 代码...
*/
?>

  3.使用面向对象的编程方法

  PHP也是一种面向对象的语言,面向对象的编程方法是优秀的程序员们非常推崇的一种软件设计方法,在PHP编程中可以充分发挥面向对象语言的优势,对编程中的对象进行封装。在前面的代码中,我们使用了面向对象的方法,例如在管理数据库时,我们将query()函数封装进数据库类中,这极大地方便了代码的管理,增加了程序的可读性。

  三、追求程序速度,而不是编程的速度

  在网站建设中,程序运行速度和网页下载速度都是关系成败的重要因素。作为一名Web程序员,应该更加注意代码的运行速度。下面介绍的几种方法都在不同程度上提高了代码的运行速度。

  1.使用内嵌的HTML代码,而不是PHP的echo语句。

  因为PHP是一门嵌入式Web编程语言,可以将HTML代码和PHP代码相互嵌入。但是很多程序员担心在HTML代码中过多的使用""嵌入PHP代码会多次调用PHP解释器,从而降低了PHP代码的运行速度,所以宁愿使用PHP的echo语句来输出HTML代码,而不直接使用HTML代码。但事实却恰恰相反。每一个PHP页面只调用一次PHP解释器来解释所有的PHP代码,所以,只在需要时才嵌入PHP代码,而大多数的时候直接使用HTML代码输入结果,不但不会降低程序的运行速度,而且因为减少了对echo语句的解析,往往可以提高代码的运行速度。

  下面的一段代码证明了我们的结论。在这段代码中,我们使用了前面介绍的时间测试函数。

  使用str-replace而不是ereg-replace

  习惯使用Perl进行编程的程序员更加愿意使用ereg_replace完成字符串替换工作,因为在PHP中ereg_replace的用法和Perl中模式匹配的用法相近。但是,下面的这段代码证明,使用str_replace 代替 ereg_replace将可以大大提高代码的运行速度。

  测试str_replace和ereg_replace的运行速度

//这段代码测试str_replace的运行速度

emphasis; ?>

for ($i=0; $i<1000; $i++) {
 str_replace(i>, b>, $string). ;
}
?>

//这段代码测试ereg_replace的运行速度

for ($i=0; $i<1000; $i++) {
 ereg_replace(<([/]*)i>, <\1b>, $string).
;
}
?>

//打印结果
结论

使用str_replace的时间 -
使用ereg_pattern的时间 -

上記のコードを実行すると、結果は次のようになります。

str_replace を使用する時間 - 0.089757
ereg_pattern を使用する時間 - 0.248881

実行結果から、str_replace が使用されていることがわかります。 ereg_replace を文字列置換関数として置き換えます。これにより、コードの実行速度が大幅に向上します。

3. 文字列の引用符に注意してください

PHP は、他の多くのプログラミング言語と同様に、二重引用符 ("") を使用して文字列を引用することも、一重引用符 () を使用することもできます。ただし、PHP では、二重引用符を使用して文字列を引用すると、PHP パーサーはまず文字列内に変数への参照があるかどうかを分析し、変数がある場合はその変数を置き換えます。一重引用符の場合は、それほど複雑ではありません。一重引用符で囲まれたすべての文字列が直接表示されます。明らかに、PHP プログラミングでは、二重引用符よりも一重引用符を使用して文字列変数を引用する方が高速です。

4. データベースでの共同操作の使用を避ける

他の Web プログラミング言語と比較して、PHP のデータベース機能は非常に強力です。ただし、PHP でデータベースを実行するのは依然として非常に時間と労力がかかるため、Web プログラマはデータベース クエリ操作を最小限に抑え、データベースに適切なインデックスを確立する必要があります。もう 1 つの注意すべき点は、PHP を使用してデータベースを操作する場合、複数のデータ テーブルの結合操作を使用しないようにすることです。結合操作はデータベースのクエリ機能を強化しますが、サーバーの負荷が大幅に増加します。

この問題を説明するために、次の簡単な例を見てみましょう。

データベースに 2 つのデータ テーブル foo と big_foo を作成しました。データテーブル foo には、1 から 1000 までのすべての自然数を含むフィールドが 1 つだけあります。データ テーブル big_foo にもフィールドは 1 つしかありませんが、1 から 1,000,000 までのすべての自然数が含まれています。したがって、サイズの点では、big_foo は foo とそれ自体を組み合わせたものと等しくなります。

$db->query("select * from foo");
0.032273 秒
$db->next_record()
0.00048999999999999 秒
$db- >query("foo 値に挿入 (NULL)");
0.019506 秒
$db->query("select * from foo as a, foo as b"); 🎜> $db->query("select * from foo as a, foo as b where a.id > b.id");
14.645251 秒
$db->query("select * from foo as a, foo as b where a.id = b.id");
0.041269 秒
$db->query("select * from big_foo");
25.393672 秒

演算上から 結果として、1,000 レコードを持つ 2 つのデータ テーブルを結合する方が、1,000,000 レコードを持つ大きなデータ テーブルを単独で操作するよりもそれほど高速ではないことがわかります。

5. include と require の違いに注意してください

PHP プログラミングでは、include() と require() は同じ機能ですが、include() の使用方法にはいくつかの違いがあります。 is は条件付きで組み込まれる関数ですが、require() は無条件で組み込まれます。たとえば、次の例では、変数 $somgthing が true の場合、ファイル somefile がインクルードされます。 >}

しかし、$something の値が何であっても、次のコードはファイル somefile をファイルに含めます:

if($something){
require ("somefile") ;
}

次の興味深い例は、これら 2 つの関数の違いを完全に示しています。

$i = 1;
while ($i require("somefile.$i");
$i++; 🎜>
このコードでは、プログラムはループするたびに同じファイルをインクルードします。明らかに、これはプログラマーの本来の意図ではありません。コードから、このコードが各ループに異なるファイルを含めることを望んでいることがわかります。この関数を完了したい場合は、 include() 関数を使用する必要があります:

$i = 1;
while ($i < 3) {
include(" somefile.$i" );
$i++;
}

6. echo と print の違いに注意

PHP における echo と print の機能は、基本的には同じですが、両者には微妙な違いがあります。たとえば、次のコードを実行すると、変数 $res の値は 1 になります。


$ret = print "Hello World";

これは、print は一部の複雑な式で使用できるが、echo は使用できないことを意味します。同様に、コード内の echo ステートメントは値を返す必要がないため、print ステートメントよりもわずかに高速に実行されます。





声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。