日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

python函数定义和调用_函数定义和调用

發(fā)布時間:2024/7/23 python 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python函数定义和调用_函数定义和调用 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

定義函數(shù)

在JavaScript中,定義函數(shù)的方式如下:

function abs(x) {

if (x >= 0) {

return x;

} else {

return -x;

}

}

上述abs()函數(shù)的定義如下:

function指出這是一個函數(shù)定義;

abs是函數(shù)的名稱;

(x)括號內(nèi)列出函數(shù)的參數(shù),多個參數(shù)以,分隔;

{ ... }之間的代碼是函數(shù)體,可以包含若干語句,甚至可以沒有任何語句。

請注意,函數(shù)體內(nèi)部的語句在執(zhí)行時,一旦執(zhí)行到return時,函數(shù)就執(zhí)行完畢,并將結(jié)果返回。因此,函數(shù)內(nèi)部通過條件判斷和循環(huán)可以實現(xiàn)非常復(fù)雜的邏輯。

如果沒有return語句,函數(shù)執(zhí)行完畢后也會返回結(jié)果,只是結(jié)果為undefined。

由于JavaScript的函數(shù)也是一個對象,上述定義的abs()函數(shù)實際上是一個函數(shù)對象,而函數(shù)名abs可以視為指向該函數(shù)的變量。

因此,第二種定義函數(shù)的方式如下:

var abs = function (x) {

if (x >= 0) {

return x;

} else {

return -x;

}

};

在這種方式下,function (x) { ... }是一個匿名函數(shù),它沒有函數(shù)名。但是,這個匿名函數(shù)賦值給了變量abs,所以,通過變量abs就可以調(diào)用該函數(shù)。

上述兩種定義完全等價,注意第二種方式按照完整語法需要在函數(shù)體末尾加一個;,表示賦值語句結(jié)束。

調(diào)用函數(shù)

調(diào)用函數(shù)時,按順序傳入?yún)?shù)即可:

abs(10); // 返回10

abs(-9); // 返回9

由于JavaScript允許傳入任意個參數(shù)而不影響調(diào)用,因此傳入的參數(shù)比定義的參數(shù)多也沒有問題,雖然函數(shù)內(nèi)部并不需要這些參數(shù):

abs(10, 'blablabla'); // 返回10

abs(-9, 'haha', 'hehe', null); // 返回9

傳入的參數(shù)比定義的少也沒有問題:

abs(); // 返回NaN

此時abs(x)函數(shù)的參數(shù)x將收到undefined,計算結(jié)果為NaN。

要避免收到undefined,可以對參數(shù)進行檢查:

function abs(x) {

if (typeof x !== 'number') {

throw 'Not a number';

}

if (x >= 0) {

return x;

} else {

return -x;

}

}

arguments

JavaScript還有一個免費贈送的關(guān)鍵字arguments,它只在函數(shù)內(nèi)部起作用,并且永遠指向當(dāng)前函數(shù)的調(diào)用者傳入的所有參數(shù)。arguments類似Array但它不是一個Array:

'use strict'

----

function foo(x) {

console.log('x = ' + x); // 10

for (var i=0; i

console.log('arg ' + i + ' = ' + arguments[i]); // 10, 20, 30

}

}

foo(10, 20, 30);

利用arguments,你可以獲得調(diào)用者傳入的所有參數(shù)。也就是說,即使函數(shù)不定義任何參數(shù),還是可以拿到參數(shù)的值:

function abs() {

if (arguments.length === 0) {

return 0;

}

var x = arguments[0];

return x >= 0 ? x : -x;

}

abs(); // 0

abs(10); // 10

abs(-9); // 9

實際上arguments最常用于判斷傳入?yún)?shù)的個數(shù)。你可能會看到這樣的寫法:

// foo(a[, b], c)

// 接收2~3個參數(shù),b是可選參數(shù),如果只傳2個參數(shù),b默認(rèn)為null:

function foo(a, b, c) {

if (arguments.length === 2) {

// 實際拿到的參數(shù)是a和b,c為undefined

c = b; // 把b賦給c

b = null; // b變?yōu)槟J(rèn)值

}

// ...

}

要把中間的參數(shù)b變?yōu)椤翱蛇x”參數(shù),就只能通過arguments判斷,然后重新調(diào)整參數(shù)并賦值。

rest參數(shù)

由于JavaScript函數(shù)允許接收任意個參數(shù),于是我們就不得不用arguments來獲取所有參數(shù):

function foo(a, b) {

var i, rest = [];

if (arguments.length > 2) {

for (i = 2; i

rest.push(arguments[i]);

}

}

console.log('a = ' + a);

console.log('b = ' + b);

console.log(rest);

}

為了獲取除了已定義參數(shù)a、b之外的參數(shù),我們不得不用arguments,并且循環(huán)要從索引2開始以便排除前兩個參數(shù),這種寫法很別扭,只是為了獲得額外的rest參數(shù),有沒有更好的方法?

ES6標(biāo)準(zhǔn)引入了rest參數(shù),上面的函數(shù)可以改寫為:

function foo(a, b, ...rest) {

console.log('a = ' + a);

console.log('b = ' + b);

console.log(rest);

}

foo(1, 2, 3, 4, 5);

// 結(jié)果:

// a = 1

// b = 2

// Array [ 3, 4, 5 ]

foo(1);

// 結(jié)果:

// a = 1

// b = undefined

// Array []

rest參數(shù)只能寫在最后,前面用...標(biāo)識,從運行結(jié)果可知,傳入的參數(shù)先綁定a、b,多余的參數(shù)以數(shù)組形式交給變量rest,所以,不再需要arguments我們就獲取了全部參數(shù)。

如果傳入的參數(shù)連正常定義的參數(shù)都沒填滿,也不要緊,rest參數(shù)會接收一個空數(shù)組(注意不是undefined)。

因為rest參數(shù)是ES6新標(biāo)準(zhǔn),所以你需要測試一下瀏覽器是否支持。請用rest參數(shù)編寫一個sum()函數(shù),接收任意個參數(shù)并返回它們的和:

'use strict';

----

function sum(...rest) {

???

}

----

// 測試:

var i, args = [];

for (i=1; i<=100; i++) {

args.push(i);

}

if (sum() !== 0) {

console.log('測試失敗: sum() = ' + sum());

} else if (sum(1) !== 1) {

console.log('測試失敗: sum(1) = ' + sum(1));

} else if (sum(2, 3) !== 5) {

console.log('測試失敗: sum(2, 3) = ' + sum(2, 3));

} else if (sum.apply(null, args) !== 5050) {

console.log('測試失敗: sum(1, 2, 3, ..., 100) = ' + sum.apply(null, args));

} else {

console.log('測試通過!');

}

小心你的return語句

前面我們講到了JavaScript引擎有一個在行末自動添加分號的機制,這可能讓你栽到return語句的一個大坑:

function foo() {

return { name: 'foo' };

}

foo(); // { name: 'foo' }

如果把return語句拆成兩行:

function foo() {

return

{ name: 'foo' };

}

foo(); // undefined

要小心了,由于JavaScript引擎在行末自動添加分號的機制,上面的代碼實際上變成了:

function foo() {

return; // 自動添加了分號,相當(dāng)于return undefined;

{ name: 'foo' }; // 這行語句已經(jīng)沒法執(zhí)行到了

}

所以正確的多行寫法是:

function foo() {

return { // 這里不會自動加分號,因為{表示語句尚未結(jié)束

name: 'foo'

};

}

練習(xí)

定義一個計算圓面積的函數(shù)area_of_circle(),它有兩個參數(shù):

r: 表示圓的半徑;

pi: 表示π的值,如果不傳,則默認(rèn)3.14

'use strict';

function area_of_circle(r, pi) {

----

return 0;

----

}

// 測試:

if (area_of_circle(2) === 12.56 && area_of_circle(2, 3.1416) === 12.5664) {

console.log('測試通過');

} else {

console.log('測試失敗');

}

小明是一個JavaScript新手,他寫了一個max()函數(shù),返回兩個數(shù)中較大的那個:

'use strict';

function max(a, b) {

----

if (a > b) {

return

a;

} else {

return

b;

}

----

}

console.log(max(15, 20));

但是小明抱怨他的瀏覽器出問題了,無論傳入什么數(shù),max()函數(shù)總是返回undefined。請幫他指出問題并修復(fù)。

總結(jié)

以上是生活随笔為你收集整理的python函数定义和调用_函数定义和调用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。