java Object类型的变量被调用的时候,该变量的参照被复制,然后被传递

本文通过示例代码解释了Java中Object类型的变量作为参数传递时,实际上是引用的复制,而非值的拷贝。在Main.java中创建Sample对象s并调用modify方法修改其num属性,最后输出20,证明了这一特性。
摘要由CSDN通过智能技术生成

Object类型的变量被调用的时候,该变量的参照被复制,然后被传递

两个文件

Sample.java

Main.java

-----------------------------------------------------------------------------------------------------

①Sample.java

package chapter621;

public class Sample {
    int num;

    public Sample(int num) {
        this.num = num;
    }

Main.java

package chapter621;

public class Main {
    public static void main(String[] args) {
        Sample s = new Sample(10);
        modify(s);
        System.out.println(s.num);
    }

    private static void modify(Sample s) {
        s.num *=

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java的泛型是为了实现类型安全而引入的特性。泛型变量只能调用Object类继承或重写的方法是因为在编译时,泛型的实际类型是未知的。编译器无法确定泛型变量的具体类型,所以只能把泛型变量当作Object类型来对待。 Object类是所有类的基类,所以泛型变量默认继承了Object类的方法,包括toString()、hashCode()和equals()等常用方法。因此,无论泛型变量的实际类型是什么,都可以通过Object类的方法来进行操作。这样可以保证在编译时不会出现类型错误,提高了代码的稳定性和可靠性。 如果泛型变量可以调用任意方法,那么在使用时就无法进行类型检查。这样可能会导致运行时错误,破坏了类型安全性。为了保证类型安全性,Java只允许泛型变量调用Object类继承或重写的方法。 为了解决泛型类型的不确定性,Java提供了通配符(Wildcard)和上下界限定(Upper Bound、Lower Bound)等机制,可以对泛型类型进行限制和约束,从而提供更灵活、更安全的泛型编程方式。使用通配符和边界限定,可以实现对特定类型的操作,避免了类型转换错误和运行时异常的风险。 总之,Java的泛型变量只能调用Object类继承或重写的方法,是为了保证类型安全性和提高代码的稳定性。通过泛型的类型擦除机制和通配符、边界限定等特性,可以实现更安全、更灵活的泛型编程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值