zoukankan      html  css  js  c++  java
  • java 中形参与实参的转换

    java中有两个参数,一个是形参,一个是实参

    形参:在函数定义中,整个函数体内部都可以使用,离开了该函数就不能继续使用。

    实参:出现在主函数中,进入被调函数后,实参变量也就不能继续使用。

     1 public class Demo {
     2     /*
     3      * (int a,int b)  这里的a b就是形参
     4      */
     5     public static void exchange(int a,int b) {
     6         int temp=0;
     7         temp=a;
     8         a=b;
     9         b=temp;
    10         System.out.println("a="+a+" "+"b="+b);
    11     }
    12    
    13     public static void main(String[] args){
    14         int _a=1;
    15         int _b=2;
    16         // _a _b就是实参
    17         exchange(_a,_b);    
    18     }
    19 }
    20     

    按值传递:

     1 public class Demo {
     2 
     3     public static void transmit(int a) {
     4         a=1234;
     5         System.out.println("a="+a);
     6     }
     7    
     8     public static void main(String[] args){
     9         int _a=1;
    10         
    11         /*
    12          * transmit(_a) _a是所谓的实参. 调用函数transmit(a)时,a也就是所谓的形参(局部变量)!
    13          * 分配给a stack内存中的一块空间,空间名称为a, 值为_a=1; 也就是 a=_a 将_a的值赋予给a --> 所谓的按值传递
    14          * 实参传给形参多少 就是 多少
    15          */
    16         transmit(_a);
    17         
    18         System.out.println(_a);     //输出1
    19     }
    20 }

    内存解析:

    int _a=1; 基本变量--> 在stack中占用一块内存(基本变量只占用一块内存);

    transmit(_a); 调用方法public static void transmit(int a);

    方法transmit中的int a为形参也是局部变量 --> 在stack中也占用一块内存,位于_a的上方;

    然后输出a=1234;

    在执行完方法时,之前方法中的所有局部变量都要消失,他们所占用的空间也就消失; stack中也就不存在a 的内存;

    然后输出主函数的_a=1; 值传递不会改变实参的值,除非方法里面给实参赋予了新的值;

    main()也执行完毕,此时_a在stack中所占用的内存也消失;

  • 相关阅读:
    css实现文字相对于图片垂直居中
    node能做的性能优化
    vue.config.js中vue的配置
    react/vue项目腾讯云/阿里云服务器linux部署
    taro项目结构分析和坑
    vscode自动编译less
    css彩色字体
    微信小程序文件上传
    小程序html解析
    小程序表单
  • 原文地址:https://www.cnblogs.com/jllj/p/6405701.html
Copyright © 2011-2022 走看看