在java中实现C#语法里的按引用传递参数的方法
在C#中,在次函数中调用时改变了其中的数值,主函数中也将发生改变
ref 关键字使参数按引用传递。其效果是,当控制权传递回调用方法时,在方法中对参数所做的任何更改都将反映在该变量中。若要使用 ref 参数,则方法定义和调用方法都必须显式使用 ref 关键字
out 关键字会导致参数通过引用来传递。这与 ref 关键字类似,不同之处在于 ref 要求变量必须在传递之前进行初始化。若要使用 out 参数,方法定义和调用方法都必须显式使用 out 关键字。
Java里面不像C#那样,Java只有对象类型参数才是传地址的,Java的基础类型变量做参数的时候,都只是传值。
解决方法是,用Java的类做函数的参数类型。
如下是我写的一个例子说明:
文件名:byRefVariable.java
//--------------------------------------
public class byRefVariable{
public static void main(String args[]) {
obj test=new obj();
System.out.println("没有把test作实参传递给changeIt方法之前的test.var的值="+test.var);
changeIt(test);//坐实参传递到一个函数!
System.out.println("test作实参传递给changeIt之后"+test.var);
}
public static void changeIt(obj a) {
a.var=12580;
}
}
class obj //我在这里定义了一个类。
{ int var=0;}
以上就是小编为大家带来的在java中实现C#语法里的按引用传递参数的方法的全部内容了,希望对大家有所帮助,多多支持脚本之家~
相关文章
Java CharacterEncodingFilter案例详解
这篇文章主要介绍了Java CharacterEncodingFilter案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下2021-08-08
Windows安装Kafka(kafka_2.12-3.9.1)配置Kafka的过程及遇到的问题解决方案
文章详细介绍了如何在Windows系统上安装和配置Kafka,包括下载、解压、配置日志目录、修改配置文件、初始化存储目录、生成集群ID、配置KRaft模式、格式化日志目录以及启动Kafka的步骤,本文给大家介绍的非常详细,感兴趣的朋友一起看看吧2025-11-11
SpringBoot整合Apache Spark实现一个简单的数据分析功能
ApacheSpark是一个开源的大数据处理框架,它提供了丰富的功能和API,用于分布式数据处理、数据分析和机器学习等任务,下面我们就来看看SpringBoot如何整合Apache Spark实现一个简单的数据分析功能吧2025-11-11


最新评论