在主函数中定义一个变量,然后在方法调用并处理该变量,最后再在主函数中调用处理后的变量。
我们来看如下的一段代码:
class Demo1
{
//方法(f=f+1)
public static void add(int f)
{
f=f+1;
System.out.println("经过处理的值:"+f);
}
//主函数
public static void main(String[] args)
{
int f=0;
System.out.println("原始值:"+f);
add(f);
System.out.println("最终值:"+f);
}
}
在主函数中定义一个变量f等于0,调用方法add(int f),可以看出在方法中处理f,使得f=f+1即f=1,之后在主函数中输出f的最终值。
在我这个java小白的思考理解中,最终值f应该等于1,然而。。。理想跟现实总是有一定的差距,请看如下结果图:
发生了什么?
漫长的查资料过程。。。
有人说,”方法中的变量是局部变量,只能在这个方法中使用。”作为小白的我认为这句话有道理,但是似乎不太符合题意。很难受我还是没有找到正确的说法。。。
所幸,找到了解决的办法!像java这么优秀的语言~~~
请看如下代码:
class Demo1
{
public static void add(int[] f)
{
f[0]=f[0]+1;
System.out.println("==="+f[0]);
}
public static void main(String[] args)
{
int[] f=new int[1];
f[0]=0;
System.out.println(f[0]);
add(f);
System.out.println(f[0]);
}
}
将刚才的f改为数组的形式,定义一个一维数组,令f[0]=0,还是同样的代码,接下来,我们见证奇迹!
最终值为1
成功在主函数中输出了在方法中处理过的变量!
magic~
虽然解决了这个问题,但是我还是没有搞懂这其中的原理,后续如果了解到了再回来补充吧。