⑴ 我是學計算機軟體專業的,馬上面臨分方向了,為什麼他們都這么鄙視php呢難道PHP的發展真的就那麼垃圾
PHP也只是工具,實現項目的一個角色而已。垃圾與否要看用的人怎麼樣了。
網路淘寶都在用PHP,你說網路淘寶垃圾嗎?
www..com/index.php
http://www.taobao.com/index_global.php
⑵ php有垃圾回收機制嗎
析構函數會在到某個對象的所有引用都被刪除或者當對象被顯式銷毀時執行(php手冊 語言參考->類與對象->構造函數和析構函數)。利用這一點,就可以知道php什麼時候執行了垃圾回收。通常垃圾回收都是在程序結束階段,但是如果讓系統知道這個變數以後不會使用了,php就會啟動垃圾回收的。
⑶ 什麼是php垃圾回收機制
以下摘自網路:
對象引用計數器機制回收:
php 5.3之前使用的垃圾回收機制是單純的「引用計數」,也就是每個內存對象都分配一個計數器,當內存對象被變數引用時,計數器+1;當變數引用撤掉後,計數器-1;當計數器=0時,表明內存對象沒有被使用,該內存對象則進行銷毀,垃圾回收完成。
「引用計數」存在問題,就是當兩個或多個對象互相引用形成環狀後,內存對象的計數器則不會消減為0;這時候,這一組內存對象已經沒用了,但是不能回收,從而導致內存泄露。
php5.3開始,使用了新的垃圾回收機制,在引用計數基礎上,實現了一種復雜的演算法,來檢測內存對象中引用環的存在,以避免內存泄露。
示例代碼:
class A{
private $b;
function __construct(){
$this->b = new B($this);
}
function __destruct(){
//echo "A destruct\n";
}
function out(){
echo 'oooo',"\n";
}
}
class B{
private $a;
function __construct($a){
$this->a = $a;
}
function __destruct(){
//echo "B descturct\n";
}
}
for($i=0;;$i++){
$a = new A();
if($i00 == 0){
echo memory_get_usage()."\n";
}
}
引起計數器+1的操作:
$a=new A();
$b=&$a;
引起計數器-1的操作:
unset($a);
引起計數器值0對象並釋放內存:
$a=null;
內存相關的函數:
memory_get_usage()返回當前分配給你的 PHP 腳本的內存量,單位是位元組(byte)
memory_get_peak_usage()返回分配給 PHP 內存的峰值
mysql_free_result() 手動釋放mysql結果集內存
gc_enable();//開啟gc自動回收
gc_collect_cycles();//執行一次回收周期
gc_disable();//關閉gc自動回收周期
xdebug_debug_zval(變數名)//載入完xdebug後,可以用這個函數查看變數的狀態
請採納!
⑷ ThinkPHP是垃圾寫的嗎
是,灰常垃圾寫的
⑸ 簡單說明PHP的垃圾收集機制是怎樣的
PHP的基本GC概念
PHP語言同其他語言一樣,具有垃圾回收機制。那麼今天我們要為大家講解的內容就是關於PHP垃圾回收機制的相關問題。希望對大家有所幫助。PHP
strtotime應用經驗之談PHP memory_get_usage()管理內存PHP unset全局變數運用問題詳解PHP
unset()函數銷毀變數教你快速實現PHP全站許可權驗證一、PHP 垃圾回收機制(Garbage Collector 簡稱GC)
在PHP中,沒有任何變數指向這個對象時,這個對象就成為垃圾。PHP會將其在內存中銷毀;這是PHP的GC垃圾處理機制,防止內存溢出。當一個PHP線程結束時,當前佔用的所有內存空間都會被銷毀,當前程序中所有對象同時被銷毀。GC進程一般都跟著每起一個SESSION而開始運行的.gc目的是為了在session文件過期以後自動銷毀刪除這些文件.二、__destruct
/unset __destruct() 析構函數,是在垃圾對象被回收時執行。
unset 銷毀的是指向對象的變數,而不是這個對象。三、 Session
與PHP垃圾回收機制由於PHP的工作機制,它並沒有一個daemon線程來定期的掃描Session信息並判斷其是否失效,當一個有效的請求發生時,PHP
會根據全局變數 session.gc_probability和session.gc_divisor的值,來決定是否啟用一個GC,
在默認情況下,session.gc_probability=1, session.gc_divisor
=100也就是說有1%的可能性啟動GC(也就是說100個請求中只有一個gc會伴隨100個中的某個請求而啟動).PHP垃圾回收機制的工作就是掃描所有的Session信息,用當前時間減去session最後修改的時間,同session.gc_maxlifetime參數進行比較,如果生存時間超過gc_maxlifetime(默認24分鍾),就將該session刪除。
但是,如果你Web伺服器有多個站點,多個站點時,GC處理session可能會出現意想不到的結果,原因就是:GC在工作時,並不會區分不同站點的session.那麼這個時候怎麼解決呢?
1. 修改session.save_path,或使用session_save_path()讓每個站點的session保存到一個專用目錄,
2. 提供GC的啟動率,自然,PHP垃圾回收機制的啟動率提高,系統的性能也會相應減低,不推薦。
3. 在代碼中判斷當前session的生存時間,利用session_destroy()刪除。
引用計數基本知識
每個php變數存在一個叫做"zval"的變數容器中.一個zval變數容器,除了包含變數的類型和值,還包括兩個位元組的額外信息.第一個是"is_ref",是個bool值,用來標識這個變數是否是屬於引用集合(reference
set).通過這個位元組,php引擎才能把普通變數和引用變數區分開.由於php允許用戶通過使用&來使用自定義引用,zval變數容器中還有一個內部引用計數機制,來優化內存使用.第二個額外位元組是"refcount",用來表示指向這個zval變數容器的變數(也稱符號即symbol)個數.
當一個變數被賦常量值時,就會生成一個zval變數容器,如下例所示:
?
1
2
3
4
<?php
$a = "new string";
?>
在上例中,新的變數是a,是在當前作用域中生成的.並且生成了類型為string和值為"new
string"的變數容器.在額外的兩個位元組信息中,"is_ref"被默認設置為false,因為沒有任何自定義的引用生成."refcount"被設定為1,因為這里只有一個變數使用這個變數容器.調用xdebug查看一下變數內容:
?
1
2
3
4
5
<?php
$a = "new string";
xdebug_debug_zval('a');
?>
以上代碼會輸出:
?
1
a: (refcount=1, is_ref=0)='new string'
對變數a增加一個引用計數
?
1
2
3
4
5
6
<?php
$a = "new string";
$b = $a;
xdebug_debug_zval('a');
?>
以上代碼會輸出:
?
1
a: (refcount=2, is_ref=0)='new string'
這時,引用次數是2,因為同一變數容器被變數a和變數b關聯.當沒必要時,php不會去復制已生成的變數容器.變數容器在"refcount"變成0時就被銷毀.當任何關聯到某個變數容易的變數離開它的作用域(比如:函數執行結束),或者對變數調用了unset()函數,"refcount"就會減1,下面例子就能說明:
?
1
2
3
4
5
6
7
<?php
$a = "new string";
$b = $c = $a;
xdebug_debug_zval('a');
unset($b, $c);
xdebug_debug_zval('a');
?>
以上代碼會輸出:
?
1
a: (refcount=3, is_ref=0)='new string' a: (refcount=1, is_ref=0)='new string'
如果我們現在執行unset($a),$包含的類型和值的這個容器就會從內存刪除
復合類型(compound types)
當考慮像array和object這樣的復合類型時,事情會稍微有些復雜.與標量(scalar)類型的值不同,array和object類型的變數把它們的成員或屬性存在自己的符號表中.這意味著下面的例子將生成三個zval變數容器
?
1
2
3
4
5
<?php
$a = array('meaning' => 'life', 'number' => 42);
xdebug_debug_zval('a');
?>
以上代碼輸出:
?
1
a: (refcount=1, is_ref=0)=array ('meaning' => (refcount=1, is_ref=0)='life', 'number' => (refcount=1, is_ref=0)=42)
這三個zval變數容器是:a,meaning,number.增加和減少refcount的規則和上面提到的一樣
特例,添加數組本身作為數組元素時:
?
1
2
3
4
5
6
7
<?php
$a = array('one');
$a[] = &$a;
xdebug_debug_zval('a');
?>
以上代碼輸出的結果:
?
1
a: (refcount=2, is_ref=1)=array (0 => (refcount=1, is_ref=0)='one', 1 => (refcount=2, is_ref=1)=...)
可以看到數組a和數組本身元素a[1]指向的變數容器refcount為2
當對數組$a調用unset函數時,$a的refcount變為1,發生了內存泄漏
清理變數容器的問題
盡管不再有某個作用域中的任何符號指向這個結構(就是變數容器),由於數組元素"1"仍然指向數組本身,所以這個容器不能被消除.因為沒有另外的符號指向它,用戶沒有辦法清除這個結構,結果就會導致內存泄漏.慶幸的是,php將在請求結束時清除這個數據結構,但是php清除前,將耗費不少內存空間
回收周期
5.3.0PHP使用了新的同步周期回收演算法,來處理上面所說的內存泄漏問題
首先,我們先要建立一些基本規則:
如果一個引用計數增加,它將繼續被使用,當然就不再垃圾中.如果引用技術減少到零,所在的變數容器將被清除(free).就是說,僅僅在引用計數減少到非零值時,才會產生垃圾周期(grabage
cycle).其次,在一個垃圾周期中,通過檢查引用計數是否減1,並且檢查哪些變數容器的引用次數是零,來發現哪部分是垃圾
為避免不得不檢查所有引用計數可能減少的垃圾周期,這個演算法把所有可能根(possible roots
都是zval變數容器),放在根緩沖區(root buffer)中(用紫色標記),這樣可以同時確保每個可能的垃圾根(possible
garbage root)在緩沖區只出現一次.僅僅在根緩沖區滿了時,才對緩沖區內部所有不同的變數容器執行垃圾回收操作。
腳本之家查來的
⑹ 看到有人說 PHP 是個垃圾語言,建議學習 Node.js、python、Java,此話怎講
這點事情就讓你受刺激啊 你也太容易受刺激了 不要相信他胡扯 語言的優劣怎麼能用垃圾這個詞 Facebook是用PHP寫的
⑺ PHP既然這么爛,那它是怎麼火起來的
我認為 PHP 被黑的主要原因,不是語言本身。而是一堆連我也看不慣的——為了速成而學習 PHP的人。
可怕的是,即使是速成的 PHP 程序員,也能寫出一個跑得起來的程序,這才是致命的。於是乎,這些人不斷鼓吹自己能力,以為寫一個跑得起的程序就無法無天,成為了大神。正是因為速成的,沒有去深入了解,導致這些人就算是一個寫了十幾年的代碼的人,見識依舊淺薄。對於此,我表示十分惋惜。比如這位:
完全不要用YII框架吧,這就是個垃圾。-CSDN論壇-CSDN.NET-中國最大的IT技術社區
可能正是這樣一種環境,決定了有很大一部分 PHP 開發人員的素質並不高。於是乎,各種人的吐槽目標由會嘰嘰喳喳、會咬人的超 Low PHP 開發人員轉向了不會說話的 PHP 語言本身。
PHP 心想 —— 怪我咯。
實際上,任何一門語言都有無數槽點。PHP 的槽點其實一些其他語言也會有。只是由於 PHP 被一些逗比神論撒開了後,變的樹大招風而已。
效率?這個問題會隨著語言解釋器進步而不斷進步,這種吐槽可以有,因為會不斷鼓勵其高效發展。
函數命名問題?這個吐槽也可以有,畢竟歷史遺留擺在那的,不過 PHP 有很多新的這些函數的別名,算是解決這種問題吧。
變數名的 $ 符號?這個吐槽我只能說不算是吐槽,沒了這個符號,PHP 的某一特色就沒了。
至於非同步、多線程等等,這種吐槽在很久以前有存在的價值,現在還是省省吧。
還有一堆吐槽都是針對開發人員的,和 PHP 本身無關。
回到問題本身,為啥 PHP 能火:
答案很簡單,很多人吐槽的問題就是 PHP 能火的原因。
也因此得出,其實有些非理性吐槽純屬嫉妒。
總而言之,理性看待。世界在發展,科學在進步,將來會怎樣,誰也說不住。
⑻ PHP已經死,PHP早就不行了.現在的PHP只能做垃圾站!!
php有很多不足,它之所以能夠流行我感覺主要是因為:
1.開發和部署成本都比較低,隨便一個虛擬主機就可以運行,ruby on rails ,python就不行.
2.大量的開源項目,能滿足用戶方方面面的需求,像wordpress drupal elgg phpbb .....
3.有大量從事php的程序員,企業招聘比較方便
所以我個人覺得,至少從目前來看,php還具有一定的優勢
⑼ 覺得使用ThinkPHP 好煩啊,文檔看都看不到,程序運行錯誤都不知道報的哪門子錯誤,覺得很垃圾
這類框架一般多少都會採用MVC設計模式,將業務邏輯、數據和界面顯示分離處理.所以一般會採用類化的方式,將訪問路由到不同的控制器處理並進行視圖輸出.但不管怎麼樣,都是有章可循的.ThinkPHP不算復雜吧.但說垃圾就不對了.只是你對這種設計模式不熟悉不喜歡而已.你只要跟蹤下執行流程,幾下子就找出頭緒了.它本身是一個框架,而且框架功能都是包裝起來的.然後根據需求不斷增加控制和視圖來豐富網站功能.耐心點,這裡面能學到好多東西呢.
⑽ thinkphp被噴了,真的很爛嗎
沒有哪個產品是完美無缺的,也沒有哪個產品能夠滿足所有人的需求。
在你沒有使用任何php框架的時候,忽然有人告訴你有一個thinkphp可以提高你的開發效率,你會不會覺得很興奮呢?
可是今天忽然有人給你推薦了另外一個PHP框架,你發現它比thinkphp更加好用,那你自然就覺得thinkphp垃圾了。
thinkphp爛不爛並不是重點,重點是你用著上不上手,如果你用著上手,那就用著唄,你管誰噴不噴呢,自己覺得好用就得。
我現在用的PHP框架幾乎沒有什麼人使用,作者也很少更新,兩年多我就見他更新了一回,而這次更新也沒有什麼明確的說明,我下載下來發現也就是後台模板換了一下。
但我仍然喜歡用這個框架,原因很簡單,我通過閱讀他給出的示例,就能夠理解這套框架應該如何去使用,官方的文檔也非常簡單,沒一句廢話,都是直入主題,而這正是我需要的,雖然它並不流行,那有什麼關系呢?用的人多了,我反倒會擔心,因為說不定哪天就暴出個什麼BUG讓我被黑掉了。