javascript函数的形参与实参

形参,是在定义函数时使用的参数,目的是用来接收调用该函数时传进来的实际参数。 
实参:是在调用时传递给函数的参数 
例如

function myfun(a,b,c){
    ...  
}
myfun(1,2,3);

这里a,b,c就是形参。1,2,3为实参。 
形参和实参是不同的变量,他们在内存中处于不同的位置,形参在函数运行结束时将被释放。

主要有两点需要注意的

1 . 如果实参是引用类型(object,array等),那么对相对的形参进行更改,是否会影响到实参的值

var obj = {
    name:'obj',
    age:12
}
function myfunc(objtemp){
    objtemp.name='func';
    alert(objtemp.age); //12
}
myfunc(obj);
alert(obj.name);  //func

那么最后一句:alert(obj.name);会输出什么呢,答案是func。 
函数参数传递包含两种方式:值传递和引用传递。 
值传递:形参是实参值的一个副本,对形参的改变不会影响实参 
引用传递:形参实际上是对实参引用变量的复制,导致这实参、形参都指向同一个对象实体。形参改变会同时改变实参的值。 
可以这样理解:myfunc(obj);可以看作是

objtemp = obj;
objtemp.name = 'func';
alert(objtemp.age);

举例说明:

var arr= ['obj1','obj2','obj3']
function myfunc(arrtemp){
    arrtemp[1] = 'myfunc';
    alert(arrtemp);  
}
myfunc(arr);  //obj1,myfunc,obj3
alert(arr[1]); //myfunc

2 . 形参与局部变量重名情况的处理。

function myfunc(a){
    alert(a);        //hello
    var a = a+'world';
    var b = a; 
    alert(a);        //helloworld
    alert(b);        //helloworld
}
myfunc("hello");

由于“变量声明提升”,当执行到第一个alert(a)时,形参a已经存在。局部变量a只声明而未赋值,内存中还未创建局部变量a。这时候alert(a),a 表示形参,所以输出“hello”。 
执行var a = a+’world’;时,右边的a是形参,左边的a是局部变量。这两个a互不干扰。但这一句执行完成后,局部变量a已经覆盖了形参a。所以后面的b=a时,a为局部变量。

综合来说,当局部变量未声明或只声明而未赋值时,内存中还没有这个变量,这时候调用的同名变量是形参。当局部变量赋值完成后,内存中已经存在这个变量,并且覆盖了同名的形参。后面再调用该变量时,就指的的局部变量了。 

转载地址:https://blog.csdn.net/liu_shi_jun/article/details/51967436

猜你喜欢

转载自blog.csdn.net/weixin_40818589/article/details/81283740