有時候使用可變變數名是很方便的。就是説,一個變數的變數名可以動態的設定和使用。一個普通的變數通過宣告來設定,例如:

一個可變變數獲取了一個普通變數的值作為這個可變變數的變數名。在上面的例子中 hello 使用了兩個美元符號($)以後,就可以作為一個可變變數的變數了。例如:

這時,兩個變數都被定義了:$a 的內容是 “hello” 並且 $hello 的內容是 “world” 。因此,以下語句:

與以下語句輸出完全相同的結果:

它們都會輸出:hello world 。
要將可變變數用於陣列,必須解決一個模稜兩可的問題。這就是當寫下 $$a[1] 時,解析器需要知道是想要 $a[1] 作為一個變數呢,還是想要 $$a 作為一個變數並取出該變數中索引為 [1] 的值。
解決此問題的語法是,對第一種情況用 ${$a[1]},對第二種情況用 ${$a}[1] 。
類的屬性也可以通過可變屬性名來訪問。可變屬性名將在該呼叫所處的範圍內被解析。例如,對於 $foo->$bar 表示式,
則會在本地範圍來解析 $bar 並且其值將被用於 $foo 的屬性名。
對於 $bar 是陣列單元時也是一樣。