DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 從階乘函數對比Javascript和C#的異同
從階乘函數對比Javascript和C#的異同
編輯:關於JavaScript     
JavaScript代碼塊
復制代碼 代碼如下:
                  
<script type="text/javascript">
function factorial(num) {
if (num <= 1) {
return 1;
} else {
return num * arguments.callee(num - 1);
}
}
var trueFactorial = factorial;
factorial = function () {
return 0;
}
alert(trueFactorial(5)); //120
alert(factorial(5)); //0
</script>

C#代碼塊
復制代碼 代碼如下:
protected void Page_Load(object sender, EventArgs e)
{
TestFactorial();
}
public delegate int factorialDelegate(int num); //定義遞歸函數委托
private void TestFactorial()
{
factorialDelegate fdelegate = factorial; //請注意與javascript函數對比
factorialDelegate trueFactorial = fdelegate;
fdelegate = returnZero;
int num1 = trueFactorial(5); //120
int num2 = fdelegate(5); //0
}
private int returnZero(int num)
{
return 0;
}
private int factorial(int num)
{
if (num <= 1)
{
return 1;
}
else
{
return num * factorial(num - 1);
}
}

從上面,可以看出:
1、javascript中的函數都不需要設定函數是否有返回值,既然如此那麼函數的返回值類型當然也就沒有必要設置了。
2、在javascript中的函數竟然是一個對象,這個我們接觸的強類型的語言(C、C++、C#)有很大的不同。
3、javascript中有一個類數組對象arguments ,包含著傳入函數中的所有參數。而且這個對象還有一個名叫callee的屬性,該屬性是一個指針,指向擁有這個arguments對象的函數。看一下,C#代碼塊,委托trueFactorial的執行和函數factorial緊緊地耦合在一起。我們沒有辦法消除這種緊密耦合的現象。而在上面javascript代碼塊中,當變量trueFactorial獲得了factorial的值。然後,我們又簡單地將一個返回0的函數賦值給了factorial變量。如果像原來那樣不使用arguments.callee,調用trueFactorial()就會返回0。在解除了函數體內的代碼與函數名的耦合狀態之後,trueFactorial()仍然能夠正常計算階乘。至於factorial(),他現在只是一個返回0的函數。

參考書籍《Javascript高級程序設計》
部分文字來自以上書籍
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved