形参实参 (总结)

1.形参:用来接收调用该方法时传递的参数。只有在被调用的时候才分配内存空间,一旦调用结束,就释放内存空间。因此仅仅在方法内有效。

2.实参:传递给被调用方法的值,预先创建并赋予确定值。

3.传值调用:传值调用中传递的参数为基本数据类型,参数视为形参。

4.传引用调用:传引用调用中,如果传递的参数是引用数据类型,参数视为实参。在调用的过程中,将实参的地址传递给了形参,形参上的改变都发生在实参上。

1.基础数据类型(传值调用)



2.引用数据类型(引用调用)
传引用,方法体内改变形参引用,不会改变实参的引用,但有可能改变实参对象的属性值。

举两个例子:

(1)方法体内改变形参引用,但不会改变实参引用 ,实参值不变。

  
Java代码
  1. public class TestFun2 {   
  2.    public static void testStr(String str){   
  3.    str="hello";//型参指向字符串 “hello”   
  4.    }   
  5.    public static void main(String[] args) {   
  6.    String s="1" ;   
  7.    TestFun2.testStr(s);   
  8.    System.out.println("s="+s); //实参s引用没变,值也不变   
  9.    }   
 public class TestFun2 {  
    public static void testStr(String str){  
    str="hello";//型参指向字符串 “hello”  
    }  
    public static void main(String[] args) {  
    String s="1" ;  
    TestFun2.testStr(s);  
    System.out.println("s="+s); //实参s引用没变,值也不变  
    }  
}

执行结果打印:s=1

(2)方法体内,通过引用改变了实际参数对象的内容,注意是“内容”,引用还是不变的。

   
Java代码
  1. public class TestFun4 {   
  2.     public static void testStringBuffer(StringBuffer sb){   
  3.     sb.append("java");//改变了实参的内容   
  4.     }   
  5.     public static void main(String[] args) {   
  6.     StringBuffer sb= new StringBuffer("my ");   
  7.     new TestFun4().testStringBuffer(sb);   
  8.     System.out.println("sb="+sb.toString());//内容变化了   
  9.     }   
  10.     } 
public class TestFun4 {  
    public static void testStringBuffer(StringBuffer sb){  
    sb.append("java");//改变了实参的内容  
    }  
    public static void main(String[] args) {  
    StringBuffer sb= new StringBuffer("my ");  
    new TestFun4().testStringBuffer(sb);  
    System.out.println("sb="+sb.toString());//内容变化了  
    }  
    }
 

执行结果,打印:sb=my java 。

所以比较参数是String和StringBuffer 的两个例子就会理解什么是“改变实参对象内容”了。

总结:

1.java的基本数据类型是传值调用,对象引用类型是传引用。

2.当传值调用时,改变的是形参的值,并没有改变实参的值,实参的值可以传递给形参,但是,这个传递是单向的,形参不能传递回实参。

3.当引用调用时,如果参数是对象,无论对对象做了何种操作,都不会改变实参对象的引用,但是如果改变了对象的内容,就会改变实参对象的内容。
### 指针形参实参的定义 实参(argument)全称为“实际参数”,是在调用函数时传递给函数的参数,可以是常量、变量、表达式、函数等,在进行函数调用时,它们都必须具有确定的值,以便把这些值传送给形参形参(parameter)全称为“形式参数”,由于它不是实际存在变量,所以又称虚拟变量,是在定义函数名和函数体的时候使用的参数,目的是用来接收调用该函数时传入的参数。在调用函数时,实参将赋值给形参,必须注意实参的个数、类型应与形参一一对应,并且实参必须要有确定的值[^3]。 ### 指针形参实参的使用 以下是指针形参实参在C语言中的使用示例: ```c #include <stdio.h> // 定义一个函数,使用指针作为形参 void swap(int *x, int *y) { int temp; temp = *x; *x = *y; *y = temp; } int main() { int a = 5, b = 10; // 使用指针作为实参 swap(&a, &b); printf("a = %d, b = %d\n", a, b); return 0; } ``` 在上述代码中,`swap`函数的形参`x`和`y`是指针类型,用于接收实参传递的地址。在`main`函数中,通过`&a`和`&b`获取变量`a`和`b`的地址,并将其作为实参传递给`swap`函数。在`swap`函数内部,通过解引用操作`*x`和`*y`来访问和修改实参所指向的变量的值。 ### 指针形参实参的区别 - **内存分配**:当形参实参是指针类型时,实参是实际存在的指针变量,它存储了一个有效的内存地址;而形参是在函数调用时才分配内存的指针变量,它接收实参传递的地址值。函数运行时,形参实参指向同一个内存地址,通过形参对该地址内容的修改会影响到实参所指向的内容。 - **生命周期**:实参的生命周期由其定义的位置决定,在函数调用前后都存在;而形参的生命周期仅限于函数的执行期间,函数执行结束后,形参所占用的内存会被释放。 - **数据传递**:普通的实参传递是值传递,即把实参的值复制一份给形参形参的改变不会影响实参;而指针作为实参传递的是地址,函数可以通过形参指针直接操作实参所指向的内存,从而改变实参所指向的数据的值。 ### 相关知识 - **指针传递的作用**:指针传递可以让函数直接操作实参所指向的内存,实现对实参数据的修改,常用于函数需要返回多个值或对大型数据结构进行操作的场景,避免了数据的复制,提高了效率。 - **指针传递的风险**:如果在函数中不小心修改了指针形参的值(即改变了它指向的地址),并不会影响实参指针的值,因为传递的只是地址的副本。另外,如果指针形参为空指针(`NULL`),在解引用时会导致程序崩溃,因此在使用指针形参之前,最好先检查其是否为`NULL`。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值