目錄
一、函數的形參與實參
二、參數傳遞
#三、理解參數
四、将对象属性用作实参
五、参数默认值
六、参数的收集与展开
总结
首頁 web前端 js教程 一文詳解JavaScript函數中的參數

一文詳解JavaScript函數中的參數

Aug 03, 2022 pm 07:49 PM
javascript 自訂函數 函數參數

函數參數是函數內部跟函數外部溝通的橋樑。以下這篇文章就來帶大家了解JavaScript函數中的參數,希望對大家有幫助!

一文詳解JavaScript函數中的參數

一、函數的形參與實參

函數的參數會出現在兩個地方,分別是函數定義處和函數呼叫處,這兩個地方的參數是有差別的。

  • 形參(形式參數)

    在函數定義中出現的參數可以看做是一個佔位符,它沒有數據,只能等到函數被呼叫時接收傳遞進來的數據,所以稱為形式參數,簡稱形參。

  • 實參(實際參數)

    函數被呼叫時給出的參數包含了實實在在的數據,會被函數內部的程式碼使用,所以稱為實際參數,簡稱實參。

形參和實參的區別和聯繫

  • #1) 形參變數只有在函數被呼叫時才會分配內存,呼叫結束後,立刻釋放內存,所以形參變數只有在函數內部有效,不能在函數外部使用。

  • 2) 實參可以是常數、變數、表達式、函數等,無論實參是何種類型的數據,在進行函數呼叫時,它們都必須有確定的值,以便把這些值傳送給形參,所以應該事先用賦值、輸入等辦法使實參獲得確定值。

  • 3) 實參和形參在數量上、類型上、順序上必須嚴格一致,否則會發生「類型不符」的錯誤。當然,如果能夠進行自動類型轉換,或者進行了強制類型轉換,那麼實參類型也可以不同於形參類型。

  • 4) 函數呼叫中發生的資料傳遞是單向的,只能把實參的值傳遞給形參,而不能把形參的值反向地傳遞給實參;換句話說,一旦完成資料的傳遞,實參和形參就再也沒有瓜葛了,所以,在函數呼叫過程中,形參的值發生改變並不會影響實參。

  • 5) 形參和實參雖然可以同名,但它們之間是相互獨立的,互不影響,因為實參在函數外部有效,而形參在函數內部有效。

形參和實參的功能是傳遞數據,發生函數呼叫時,實參的值會傳遞給形參。

二、參數傳遞

函數允許我們將資料傳遞進去,透過傳遞的資料從而影響函數執行結果,使函數更靈活、多用性更強。

function foo(a, b) {
    console.log([a, b]);
}

foo(1, 2); // 输出 [1, 2]
登入後複製

這個例子中,ab 屬於函數中的局部變量,只能在函數中存取。呼叫函數時,傳遞的資料會根據位置來匹配對應,分別賦值給 ab

建立函數時,function 函數名稱 後面括號中設定的參數稱為形參#;呼叫函數時,函數名稱後面括號中傳入的參數稱為實參。在上述範例中,ab 是形參,傳入的 12 是實參。

因為形參是已宣告的變量,所以不能再用 letconst 重複宣告。

function foo(a, b) {
    let a = 1; // 报错,a 已声明
    const b = 1; // 报错,b 已声明
}
登入後複製

JavaScript 中所有函數傳遞都是按值傳遞的,不會按引用傳遞。所謂的值,就是指直接保存在變數上的值,如果把物件當作參數傳遞,那麼這個值就是這個物件的引用,而不是物件本身。這裡其實是一個隱式的賦值過程,所以給函數傳遞參數時,就相當於從一個變數賦值到另一個變數

原始值:

function add(num) {
    return num + 1;
}

let count = 5;
let result = add(count); // 此处参数传递的过程可以看作是 num = count

console.log(count); // 5
console.log(result); // 6
登入後複製

引用值:

function setName(obj) {
    obj.name = "小明";
}

let person = {};

setName(person); // 此处参数传递的过程可以看作是 obj = person;
console.log(person); // {name: "小明"}
登入後複製

#三、理解參數

JavaScript 中的函數既不會偵測參數的類型,也不會偵測傳入參數的數量。定義函數時設定兩個形參,不代表呼叫時必須傳入兩個參數。實際呼叫時不管是傳了一個還是三個,連不傳參數都不會報錯。

所有函數(非箭頭)中都有一個名為arguments 的特殊的類別陣列物件(不是Array 的實例),它保存著所有實參的副本,我們可以透過它按照陣列的索引存取方式取得所有實參的值,也可以存取它的arguments.length 屬性來決定函數實際呼叫時傳入的參數個數。

例如:

function foo(a, b) {
	console.log(arguments[0]);
    console.log(arguments[1]);
    console.log(arguments.length);
}

foo(10, 20); // 依次输出 10、20、2
登入後複製

上面範例中,foo() 函數的第一個參數是a,第二個參數是b ,可以透過arguments[x] 的方式來分別取得同樣的值。因此,你甚至可以在宣告函數時不設定形參。

function foo() {
	console.log(arguments[0]);
    console.log(arguments[1]);
}

foo(10, 20); // 依次输出 10、20
登入後複製

由此可見,JavaScript 函數的形參只是方便使用才寫出來的。想傳多少個參數都不會產生錯誤。

还有一个要注意的是,arguments 可以跟形参一起使用,并且 arguments 对象中的值会和对应的形参保持同步。例如:

function foo(a) {
	arguments[0] ++;
    console.log(a);
}

foo(10); // 输出 11
//------------------------------------
function foo2(a) {
	a++;
    console.log(arguments[0]);
}

foo2(10); // 输出 11
登入後複製

当修改 arguments[0] 或 a 的值时,另一个也被改变了。这并不意味着它们访问同一个内存地址,毕竟我们传入的是一个原始值。它们在内存中还是分开的,只是由于内部的机制使它们的值保持了同步。

另外,如果缺少传参,那这个形参的值就不会和 arguments 对象中的对应值进行同步。例如下面这个例子,只传了一个参数,那么arguments 中只有一个实参值,这时候在函数中把 arguments[1] 设置为某个值,这个值并不会同步给第二个形参,例如:

function foo(a,b) {
    arguments[1] = 2;
    console.log(b);
}

foo(1); // 输出 undefined
登入後複製

这个例子中,形参 b 没有传入实参,它的值会默认为 undefined。但如果:

foo(1, undefined); // 输出 2
登入後複製

手动传入 undefined 时, arguments 数组中会出现一个值为 undefined 的元素,依然能和 b 的值进行同步。

严格模式下,arguments 对象中的值和形参不会再同步,当然,如果传入的是引用值,它们依然会互相影响,但这只是引用值的特性而已。因此,在开发中最好不要依赖这种同步机制,也就是说不要同时使用形参和它在arguments 对象中的对应值。

箭头函数中没有 arguments

如果函数是使用箭头语法定义的,那么函数中是没有 arguments 对象的,只能通过定义的形参来访问。

let foo = () => {
    console.log(arguments[0]);
}foo(); // 报错,arguments 未定义
登入後複製

在某些情况可能会访问到 arguments

function fn1(){
    let fn2 = () => {
    	console.log(arguments[0]);
    }
    
    fn2();
}fn1(5);
登入後複製

但这个 arguments,并不是箭头函数的,而是属于外部普通函数的,当箭头函数中访问 arguments 时,顺着作用域链找到了外部函数的arguments

四、将对象属性用作实参

当一个函数包含的形参有多个时,调用函数就成了一种麻烦,因为你总是要保证传入的参数放在正确的位置上,有没有办法解决传参顺序的限制呢?

由于对象属性是无序的,通过属性名来确定对应的值。因此可以通过传入对象的方式,以对象中的属性作为真正的实参,这样参数的顺序就无关紧要了。

function foo(obj) {
    console.log(obj.name, obj.sex, obj.age);
}

foo({ sex: '男', age: 18, name: '小明' }); // 小明 男 18
登入後複製

五、参数默认值

如果调用函数时缺少提供实参,那么形参默认值为 undefined

有时候我们想要设置特定的默认值,在 ES6 之前还不支持显式地设置默认值的时候,只能采用变通的方式:

function sayHi(name) {
    name = name || 'everyone';
    
	console.log( 'Hello ' + name + '!');
}

sayHi(); // 输出 'Hello everyone!'
登入後複製

通过检查参数值的方式判断有没有赋值,上面的做法虽然简便,但缺点在于如果传入的实参对应布尔值为 false ,实参就不起作用了。需要更精确的话可以用 if 语句或者三元表达式,判断参数是否等于 undefined,如果是则说明这个参数缺失 :

// if 语句判断
function sayHi(name) {
	if (name === undefined) {
		name = 'everyone';
	}
    
	console.log( 'Hello ' + name + '!');
}

// 三元表达式判断
function sayHi(name) {
	name =  (name !== undefined) ? name : 'everyone';
	
    console.log( 'Hello ' + name + '!');
}
登入後複製

ES6 就方便了许多,因为它支持了显式的设置默认值的方式,就像这样:

function sayHi(name = 'everyone') { // 定义函数时,直接给形参赋值
	console.log( 'Hello ' + name + '!');
}

sayHi(); // 输出 'Hello everyone!' 
sayHi('Tony'); // 输出 'Hello Tony!' 
sayHi(undefined); // 输出 'Hello everyone!'
登入後複製

这些结果表明了,它也是通过参数是否等于 undefined 来判定参数是否缺失的。

默认值不但可以是一个值,它还可以是任意合法的表达式,甚至是函数调用:

function sayHi(name = 'every'+'one') {
	console.log( 'Hello ' + name + '!');
}

sayHi(); // 输出 'Hello everyone!' 
//--------------------------------------
function foo() {
    console.log('调用foo');
    return 'Tony';
}

function sayHi(name = foo()) {
	console.log( 'Hello ' + name + '!');
}
		  
sayHi(); // 输出 '调用foo'
         // 输出 'Hello Tony!' 

sayHi(undefined); // 输出 '调用foo'
                  // 输出 'Hello Tony!' 

sayHi('John'); // 输出 'Hello John!'
登入後複製

可以看到,函数参数的默认值只有在函数调用时,参数的值缺失或者是 undefined 才会求值,不会在函数定义时求值。

参数默认值的位置

通常我们给参数设置默认值,是为了调用函数时可以适当省略参数的传入,这里要注意的是,有多个参数时,设置了默认值的参数如果不是放在尾部,实际上它是无法省略的。

function fn(x = 1, y) {
	console.log([x, y]);
}

fn(); // 输出 [1, undefined]
fn(2); // 输出 [2, undefined]
fn(, 2); // 报错,语法错误(这里不支持像数组那样的空槽)
fn(undefined, 2); // 输出 [1, 2] (那还不如传个 1 方便呢!)
登入後複製

上面例子中,给形参 x 设置的默认值就显得没有任何意义了。因此,设置默认值的参数放在尾部是最好的做法:

function fn(x, y = 2) {
	console.log([x, y]);
}

fn(); // 输出 [undefined, 2]
fn(1); // 输出 [1, 2]
fn(1, 1) // 输出 [1, 1]
登入後複製

参数的省略问题

在多个参数设置了默认值的情况下,那么问题又来了,你并不能省略比较靠前的参数,而只给最后的一个参数传入实参。

function fn(x, y = 2, z = 3) {
	console.log([x, y, z]);
}

fn(1, , 10) // 报错
登入後複製

前面我们知道,可以通过传入对象的这种方式去避免参数顺序的限制。那参数默认值如何实现呢?用 ||if 语句或者三元表达式去判断也是解决办法,但这样就显得有些落后了。接下来要讨论的是另外两种 ES6 中的全新方式。

参数默认值和 Object.assign() 结合使用

function fn(obj = {}) {
    let defaultObj = {
        x: undefined,
        y: 2,
        z: 3
    }
    
    let result = Object.assign(defaultObj, obj);
    
	console.log([result.x, result.y, result.z]);
}

fn(); // 输出 [undefined, 2, 3]
fn({ x: 1, z: 10 }); // 输出 [1, 2, 10]
登入後複製

上面的例子中,在函数中定义了一个对象 defaultObj ,变通地利用其中的属性作为参数的默认值,然后利用 Object.assagin() 把传入的对象和默认对象进行合并,defaultObj 中的属性会被 obj 的相同属性覆盖,obj 中如果有其他属性会分配给 defaultObj 。这里用一个变量接收返回的合并对象。

同时形参 obj 也设置了默认值为一个空对象,防止函数调用时不传任何参数,因为这会导致 Object.assign() 接收的第二个参数是 undefined ,从而产生报错。

参数默认值和解构赋值结合使用

函数调用时,实参和形参的匹配实际上是一个隐式的赋值过程,所以,参数传递也可以进行解构赋值:

function fn({ x, y = 2, z = 3 }) {
    console.log([x, y, z]);
}

fn({}); // 输出 [undefined, 2, 3]
fn({ x: 1, z: 10 }); // 输出 [1, 2, 10]
登入後複製

在这个例子中,使用的只是对象的解构赋值默认值,还没有使用函数参数的默认值。如果函数调用时不传任何参数,也会产生报错,因为这导致了参数初始化时解构赋值失败,相当于执行了 {x, y = 2, z = 3} = undefined 这样的代码。

同样的,你可以利用参数默认值的语法,给 {x, y = 2, z = 3} 设置一个默认的解构对象,使得不传参函数也能够顺利执行:

function fn({ x, y = 2, z = 3 } = {}) {
    console.log([x, y, z]);
}

fn(); // 输出 [undefined, 2, 3]
登入後複製

这里出现了双重的默认值,可能有些绕,那么用一段伪代码来解释以上的参数初始化过程就是:

if( 实参 === {...} ) { // 当 fn({...});     
    { x, y = 2, z = 3 } = {...};
                        
} else if ( 实参 === undefined ){ // 当 fn();
    { x, y = 2, z = 3 } = {};

}
登入後複製

双重默认值有一点细节需要特别注意,就是解构赋值默认值和函数参数默认值的差别,看下面例子:

function fn ({ x = 1 } = {}, { y } = { y: 2 }){
    console.log(x, y);
}

fn(); // 输出 1 2
fn({ x: 10 }, { y: 20 }); // 输出 10 20
fn({},{}); // 1 undefined
登入後複製

这个函数中,有两组参数采用了解构赋值的方式,看似 x 和 y 都设置了默认值,虽然是不同的两种形式,但显然不是任何情况下结果都相同的。当传入的参数是{}时,y 并没有获取到默认值 2 ,为什么会这样呢?结合前面的伪代码例子来看:

fn({ x: 10 }, { y: 20 }); // 初始化时: { x = 1 } = { x: 10 }, { y } = { y: 20 }

fn({},{}); // 初始化时: { x = 1 } = {}, { y } = {}
登入後複製

当传入的参数是{}时,函数参数没有缺失也不是 undefined ,所以函数参数默认值是不起作用的。同时 {} 里面也没有 x 和 y 的对应值,x 得到的 1 是解构赋值默认值,而 y 由于没有设置解构赋值默认值,所以它默认是 undefined

参数默认值的作用域与暂时性死区

还有一个小细节,一旦有参数设置了默认值,那么它们会形成自己的作用域(包裹在(...)中),因此不能引用函数体中的变量:

function foo(a = b) {
    let b = 1;
}

foo(); // 报错,b 未定义
登入後複製

但这个作用域只是临时的,参数初始化完毕后,这个作用域就不存在了。

它也符合普通作用域的规则:

let b = 2;

function foo(a = b) {
    let b = 1;
    return a;
}

foo(); // 2
登入後複製

上面例子中,存在一个全局变量 b,那么形参 a 会获取到全局变量 b 的值。

当然,如果形参作用域中存在一个形参 b 的话,它优先获取到的是当前作用域的:

let b = 2;

function foo(b = 3 ,a = b) {
    return a;
}

foo(); // 3
登入後複製

给多个参数设置默认值,它们会按顺序初始化的,遵循“暂时性死区”的规则,即前面的参数不能引用后面的参数:

function foo(a = b, b = 2) {
    return a + b;
}

foo(); // 报错,b 在初始化之前不能访问
登入後複製

六、参数的收集与展开

剩余参数

ES6 提供了**剩余参数(rest)**的语法(...变量名),它可以收集函数多余的实参(即没有对应形参的实参),这样就不再需要使用 arguments 对象来获取了。形参使用了 ... 操作符会变成一个数组,多余的实参都会被放进这个数组中。

剩余参数基本用法:

function sum(a, ...values) {
 
    for (let val of values) {
        a += val;
    }
    
    return a;
}

sum(0, 1, 2, 3); // 6
登入後複製

上面例子中,在参数初始化时,首先根据参数位置进行匹配,把 0 赋值给 a ,然后剩余的参数 1、2、3 都会被放进数组 values 中。

下面是分别用 arguments 对象和剩余参数来获取参数的对比例子:

// arguments 的写法
function sortNumbers() {
	return Array.prototype.slice.call(arguments).sort();
}

// 剩余参数的写法
const sortNumbers = (...numbers) => {
    return numbers.sort();
}
登入後複製

可以看出剩余参数的写法更加简洁。尽管 arguments 是一个类数组,也是可迭代对象,但它终究不是数组。它不支持数组方法,当我们使用 arguments 时,如果想要调用数组方法,就必须使用Array.prototype.slice.call先将其转为数组。

而剩余参数它不同于 arguments 对象,它是真正的 Array 实例,能够很方便地使用数组方法。并且箭头函数也支持剩余参数。

另外,使用剩余参数不会影响 arguments 对象的功能,它仍然能够反映调用函数时传入的参数。

  • 剩余参数的位置

剩余参数必须是最后一个形参,否则会报错。

// 报错
function fn1(a, ...rest, b) {
	console.log([a, b, rest]);
} 

// 正确写法
function fn2(a, b, ...rest) {
    console.log([a, b, rest]);
}

fn2(1, 2, 3, 4) // 输出 [1, 2, [3, 4]]
登入後複製

展开语法

前面我们知道了如何把多余的参数收集为一个数组,但有时候我们需要做一些相反的事,例如要把一个数组中的元素分别传入给某个函数,而不是传入一个数组,像这样:

function sum(...values) {
    let sum = 0;
    
    for (let val of values) {
        sum += val;
    }
    
    return sum;
}

let arr = [1, 2, 3, 4];

sum(arr); // "01,2,3,4"
登入後複製

上面例子的函数会把所有传进来的数值累加,如果直接传入一个数组,就得不到我们想要的结果。

例子中传入一个数组, values 的值会变成 [[1, 2, 3, 4]],导致数组 values 中只有一个元素,而这个元素的类型是数组。那么函数返回值就是数值 0 和数组 [1, 2, 3, 4]相加的结果了,两者各自进行了类型的隐式转换变成字符串,然后再相加,是一个字符串拼接的效果。

要实现把数组拆解传入给函数,首先不可能一个个传入参数——sum(arr[0], arr[1], arr[2], arr[3]);,因为不是任何时候都知道数组中有多少个元素的,而且数组中可能会非常多的元素,手动传是不明智的。

比较可行的是借助 apply() 方法:

sum.apply(null, arr); // 10
登入後複製

但这还不是最优解,那么重点来了!

ES6 新增的**展开语法(spread)**可以帮助我们面对这种情况。它也是使用 ...变量名 的语法,虽然跟剩余参数语法一样,但是用途完全相反,它能够把一个可迭代对象拆分成逗号分隔的参数序列。

在函数调用时,它的应用是这样子的:

sum(...arr); // 10

// 相当于 sum(1,2,3,4);
登入後複製

它甚至可以随意搭配常规值使用,没有前后位置限制,还可以同时传入多个可迭代对象:

sum(-1, ...arr); // 9
sum(...arr, 5); // 15
sum(-1, ...arr, 5); // 14
sum(-1, ...arr, ...[5, 6, 7]); // 27
登入後複製

展开操作符 ... 相当于替我们完成了手动分别传参的操作,函数只知道接收的实参是单独的一个个值,不会因为展开操作符的存在而产生其他影响。

上面的示例虽然都是针对于数组的,但展开语法能做的还不止这些,其他可迭代对象例如字符串、字面量对象都可以展开,深入了解请参见 → 展开语法

总结

  • 形参是函数中已声明的局部变量,传递给函数的实参会被赋值给形参,函数参数传递实际上是一个隐式的赋值过程。

  • 形参和实参的数量可以不相等:

    ● 缺失实参的形参会得到默认值 undefined

    ● 额外的实参,可以通过 arguments 对象访问,箭头函数除外。

  • 可以通过传入对象的方式让传参顺序不再重要,让对象中的属性作为真正的实参。

  • ES6 的参数默认值——函数调用时参数的值缺失或者是 undefined ,才会获取默认值。

    ● 设置默认值的形参只有放在最后一位才可以省略传参。

    ● 形参设置默认值不能引用函数体中的变量,但可以引用前面的形参和外部变量。

    ● 通过 Object.assign() 或者解构赋值实现默认值,能让传参的方式更加灵活。

  • 剩余参数和 arguments 的主要区别:

    ● 剩余参数只包含那些没有对应形参的实参,而 arguments 对象包含了传给函数的所有实参。

    ● 剩余参数是真正的 Array 实例,而 arguments 只是类数组对象。

  • 剩余参数和展开语法都采用 ... 操作符,在函数的相关场景中:

    ● 出现在函数形参列表的最后,它是剩余参数。

    ● 出现在函数调用时,它是展开语法。

【相关推荐:javascript学习教程

以上是一文詳解JavaScript函數中的參數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

C++ 函式參數傳遞方式與執行緒安全的關係 C++ 函式參數傳遞方式與執行緒安全的關係 Apr 12, 2024 pm 12:09 PM

函數參數傳遞方式與線程安全:值傳遞:建立參數副本,不影響原始值,通常線程安全。引用傳遞:傳遞位址,允許修改原始值,通常不線程安全。指針傳遞:傳遞指向位址的指針,類似引用傳遞,通常不線程安全。在多執行緒程式中,應慎用引用和指標傳遞,並採取措施防止資料競爭。

C++ 函式參數詳解:不定參數傳遞的實作方式與優缺點 C++ 函式參數詳解:不定參數傳遞的實作方式與優缺點 Apr 28, 2024 am 09:48 AM

C++不定參數傳遞:透過...運算子實現,可接受任意數量的附加參數,優點包括靈活性、可擴展性和簡化程式碼,缺點包括效能開銷、除錯困難和類型安全。常見實戰案例包括printf()和std::cout,它們使用va_list處理可變數量的參數。

簡易JavaScript教學:取得HTTP狀態碼的方法 簡易JavaScript教學:取得HTTP狀態碼的方法 Jan 05, 2024 pm 06:08 PM

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

如何在JavaScript中取得HTTP狀態碼的簡單方法 如何在JavaScript中取得HTTP狀態碼的簡單方法 Jan 05, 2024 pm 01:37 PM

JavaScript中的HTTP狀態碼取得方法簡介:在進行前端開發中,我們常常需要處理與後端介面的交互,而HTTP狀態碼就是其中非常重要的一部分。了解並取得HTTP狀態碼有助於我們更好地處理介面傳回的資料。本文將介紹使用JavaScript取得HTTP狀態碼的方法,並提供具體程式碼範例。一、什麼是HTTP狀態碼HTTP狀態碼是指當瀏覽器向伺服器發起請求時,服務

C++ 函式參數詳解:傳出機制的本質與注意事項 C++ 函式參數詳解:傳出機制的本質與注意事項 Apr 27, 2024 pm 12:00 PM

C++函式參數傳遞方式有兩種:傳值呼叫(不影響實參)和傳引用呼叫(影響實參)。傳出參數透過傳引用或指標實現,函數可以透過修改參數引用或指標指向的變數來傳遞值給呼叫方。使用時需要注意:傳出參數必須明確聲明,只能對應一個實參,不能指向函數內局部變量,傳指針呼叫需謹慎避免野指​​針。

數組可以當函數參數嗎? 數組可以當函數參數嗎? Jun 04, 2024 pm 04:30 PM

是的,在許多程式語言中,數組可以作為函數參數,函數將對其中儲存的資料執行操作。例如C++中的printArray函數可以列印數組中的元素,而Python中的printArray函數可以遍歷數組並列印其元素。這些函數對陣列所做的修改也會反映在呼叫函數中的原始數組中。

PHP 函數參數型別有哪些? PHP 函數參數型別有哪些? Apr 10, 2024 pm 04:21 PM

PHP函數參數類型包括標量類型(整數、浮點數、字串、布林值、空值)、複合型別(陣列、物件)和特殊型別(回呼函數、可變參數)。函數可自動轉換不同類型參數,但也可透過類型聲明強制特定類型,以防止意外轉換並確保參數正確性。

如何選擇 C++ 函數參數的傳遞方式? 如何選擇 C++ 函數參數的傳遞方式? Apr 12, 2024 am 11:45 AM

在C++中選擇函數參數傳遞方式時,有四種選擇:按值傳遞、按引用傳遞、按指標傳遞和按const引用傳遞。按值傳遞建立參數值的副本,不會影響原始參數;按引用傳遞參數值的引用,可以修改原始參數;按指針傳遞參數值的指針,允許透過指針修改原始參數值;按const引用傳遞參數值的const引用,只能存取參數值,不能修改。

See all articles