午夜福利院在线观看免费,天堂最新版在线,色噜噜精品一区二区三区,无码一区二区三区中文字幕,丝袜美腿一区二区三区

首頁(yè)>文檔>技術(shù)文檔>PHP怎么提升性能?幾種提升PHP腳本性能技巧

此組別內(nèi)的文章

需要支持?

如果通過(guò)文檔沒(méi)辦法解決您的問(wèn)題,請(qǐng)?zhí)峤还潍@取我們的支持!

PHP怎么提升性能?幾種提升PHP腳本性能技巧

這篇文章給大家分享的是提升PHP腳本性能的技巧,PHP作為現(xiàn)在比較流行的腳本語(yǔ)言之一,有很多公司都在在使用這種語(yǔ)言進(jìn)行網(wǎng)站開(kāi)發(fā)。而提升PHP腳本性能也是PHP開(kāi)發(fā)中很重要的部分,對(duì)此本文就給大家來(lái)分享幾個(gè)提升PHP腳本性能的技巧,但是要知道你的PHP腳本性能,很多時(shí)候依賴于你的php版本、你的web server環(huán)境和你的代碼的復(fù)雜度。

????優(yōu)化你代碼中的瓶頸

????Hoare曾經(jīng)說(shuō)過(guò)“過(guò)早優(yōu)化是一切不幸的根源”。當(dāng)你想要讓你的網(wǎng)站更快運(yùn)轉(zhuǎn)的時(shí)候,你才應(yīng)該去做優(yōu)化的事情。當(dāng)你要改變你代碼之前,你需要做的事是什么原因引起了系統(tǒng)緩慢?你可以通過(guò)以下指導(dǎo)和其他方式優(yōu)化你的php,可能是數(shù)據(jù)庫(kù)原因也可能是網(wǎng)路原因!通過(guò)優(yōu)化你的php代碼,你能嘗試著找出你的系統(tǒng)瓶頸。

????升級(jí)你的php版本

????你的團(tuán)隊(duì)成員提出,這些年php引擎已經(jīng)有很多象征性的性能提升。如果你的web server仍然運(yùn)行著比較老的版本,如php3或者php4。那么在你嘗試著優(yōu)化你代碼之前,應(yīng)該先深入調(diào)查一下版本之間的升級(jí)情況。

????使用緩存

????利用緩存模塊(如Memcache)或者模板系統(tǒng)(如Smarty)進(jìn)行緩存處理。我們可以緩存數(shù)據(jù)庫(kù)結(jié)果和提取頁(yè)面結(jié)果的方式來(lái)提升網(wǎng)站性能。

????使用輸出緩沖區(qū)

????當(dāng)你的腳本嘗試著渲染的時(shí)候,php會(huì)使用內(nèi)存緩存區(qū)保存所有的數(shù)據(jù)。緩存區(qū)可能讓你的頁(yè)面看起來(lái)很慢,原因是緩沖區(qū)填滿所有要響應(yīng)的數(shù)據(jù)之后再把結(jié)果響應(yīng)給用戶。幸運(yùn)的是,你能夠做一下改變,迫使php強(qiáng)行在緩沖區(qū)填滿之前把數(shù)據(jù)響應(yīng)給用戶,這樣就會(huì)讓你的網(wǎng)站看起來(lái)更快一些。

  • 輸出緩存控制

????避免寫(xiě)幼稚的setters和getters

????當(dāng)你寫(xiě)php類的時(shí)候,你可以直接操作對(duì)象屬性,這樣能幫助你節(jié)省時(shí)間和提升你的腳本性能。而不是那種讓人感到幼稚可笑的setters和getters。下面是一些案例:dog類通過(guò)使用setName()和getName()方式來(lái)操作name屬性。

class dog {
  public $name = '';
 
  public function setName($name) {
    $this->name = $name;
  }
 
  public function getName() {
    return $this->name;
  }
}

????注意:setName()和getName()除了存儲(chǔ)和返回name屬性外,沒(méi)做任何工作。

$rover = new dog();
$rover->setName('rover');
echo $rover->getName();

????直接設(shè)置和訪問(wèn)name屬性,性能能提升100%,而且也能縮減開(kāi)發(fā)時(shí)間!

$rover = new dog();
$rover->name = 'rover';
echo $rover->name;

????沒(méi)有原因不要copy變量

????有時(shí)初級(jí)phper,為了使代碼更加“干凈”,常常把已經(jīng)定義的變量重新賦值給另一個(gè)變量。這實(shí)際上就導(dǎo)致了雙重內(nèi)存的消耗(當(dāng)改變變量的時(shí)候),這就導(dǎo)致腳本的性能下降。比如一個(gè)用戶把一個(gè)512KB的變量在額外插入給另一個(gè)變量,那么就會(huì)導(dǎo)致1MB的內(nèi)存被消耗掉。

$description = strip_tags($_POST['description']);
echo $description;

????上面的代碼沒(méi)有任何原因,復(fù)制了一遍變量。你僅需要使用內(nèi)聯(lián)的方式簡(jiǎn)單輸出變量,而不用額外的消耗內(nèi)存。

echo strip_tags($_POST['description']);

????避免循環(huán)做SQL操作

????經(jīng)常犯的錯(cuò)誤是把一個(gè)SQL 操作放置到一個(gè)循環(huán)中,這就導(dǎo)致頻繁的訪問(wèn)數(shù)據(jù)庫(kù),更重要的是,這會(huì)直接導(dǎo)致腳本的性能低下。以下的例子,你能夠把一個(gè)循環(huán)操作重置為一個(gè)單一的SQL語(yǔ)句。

foreach ($userList as $user) {
  $query = 'INSERT INTO users (first_name,last_name) VALUES("' . $user['first_name'] . '", "' . $user['last_name'] . '")';
  mysql_query($query);
}

  過(guò)程:

INSERT INTO users (first_name,last_name) VALUES("John", "Doe")

????替換這種循環(huán)方案,你能夠拼接數(shù)據(jù)成為一個(gè)單一的數(shù)據(jù)庫(kù)操作。

$userData = array();
foreach ($userList as $user) {
    $userData[] = '("' . $user['first_name'] . '", "' . $user['last_name'] . '")';
 }
$query = 'INSERT INTO users (first_name,last_name) VALUES' . implode(',', $userData);
mysql_query($query);

  過(guò)程:

INSERT INTO users (first_name,last_name) VALUES("John", "Doe"),("Jane", "Doe")... 

? ? 以上就是關(guān)于PHP怎樣提升腳本性能的幾種技巧了,需要的朋友可以了解看看,這些技巧有一定的參考參加。最后,希望本文能對(duì)大家有幫助,想要了解更多大家可以關(guān)注其它的相關(guān)文章。

0 條回復(fù) A文章作者 M管理員
    暫無(wú)討論,說(shuō)說(shuō)你的看法吧
QQ客服
  • QQ176363189 點(diǎn)擊這里給我發(fā)消息
旺旺客服
  • 速度網(wǎng)絡(luò)服務(wù)商 點(diǎn)這里給我發(fā)消息
電子郵箱
  • sudu@yunjiasu.cc
微信客服
  • suduwangluo