java中变量运算细节 (2)

简介:

/*
目的:测试变量的运算方式
结果:byte a, b, c;
       a = b+c;
       或者 a = b+10
       形如这种形式的算式, 等式的右边的运算结果默认的都是int型的!因为等式右边有变量, 编译器无法确定变量的内容
       ,因为它是变量!所以相加之后得到的int再默认强制转换成byte可能会损失精度.
       而形如 a=4+5;这种常量的赋值,虽然 4 和 5 都默认的是int, 但都是常量,它们的值是确定的!所以如果 4+5的值超过了
       byte的最大值的范围, 那就会编译出错!(也就是等式右边都是常量运算,编译器是可以判断的!)
        
    形如 byte a = 9, b=12;
    或者 a+=b; a+=10; 这样的赋值运算编译器底层都是做了强制转换运算的!
    也就是说 a+=b 等价于 a = (byte)(a+b); 而不是 a = a+b;
*/
 
public class VarDemo{
   public static void main(String args[]){
           StringBuffer str =  new StringBuffer("a");
       String newStr = new String(str.append(1123));
       System.out.println(str.append(new myClass()));
        
       //这样写编译就是对的了!why?
       int a, b, c;
       b = 10;
       c = 14;
       a = b+c;
        
       int a1;
       byte b1, c1;
       b1 = Byte.MAX_VALUE;
       c1 = 34;
       a1 = b1+c1;
       System.out.println(b1 + " " + a1);
       
       /*
         这样写是编译错的!why?
         byte a3;
         byte b3;
         b3 = 12;
         a3 = b3 + 6;
         System.out.println(b3 + " " + a3);
       */  
 
       /*
         这样写是编译却是对的!why?
         byte a3=4;
         byte b3;
         b3 = 12;
         a3 += b3;
         System.out.println(b3 + " " + a3);
       */         
       
       /*
           这样写编译是错的!why?
           byte av=100+200;
       */
       
       /*
           这样写编译就是对的了!why?
           byte a1;
           a1=4+5;
       */
 
       /*
          这样写编译是错的!why?       
          byte a1;
          byte b1, c1;
          b1=Byte.MAX_VALUE;
          c1=34;
          a1=b1+c1;
       */
        
        
        
       /*
       这样写是编译错的!why?
       short a2, b2, c2;
       b2=10;
       c2=34;
       a2=b2+c2;
       */
   }
}
 
class myClass{
    int x;
    String str;
    public myClass(){
        x=4234;
        str = new String("hujunzheng");
    }
     
    public String  toString(){
       return " " + x + " " + str;
    }
}

目录
相关文章
|
14天前
|
存储 Java 开发者
【Java新纪元启航】JDK 22:解锁未命名变量与模式,让代码更简洁,思维更自由!
【9月更文挑战第7天】JDK 22带来的未命名变量与模式匹配的结合,是Java编程语言发展历程中的一个重要里程碑。它不仅简化了代码,提高了开发效率,更重要的是,它激发了我们对Java编程的新思考,让我们有机会以更加自由、更加创造性的方式解决问题。随着Java生态系统的不断演进,我们有理由相信,未来的Java将更加灵活、更加强大,为开发者们提供更加广阔的舞台。让我们携手并进,共同迎接Java新纪元的到来!
41 11
|
1月前
|
Java
【Java基础面试十一】、int和Integer有什么区别,二者在做==运算时会得到什么结果?
这篇文章解释了Java中`int`基本数据类型和其包装类`Integer`之间的区别,并指出在进行`==`运算时,`Integer`会拆箱为`int`类型,然后比较它们的值是否相等。
【Java基础面试十一】、int和Integer有什么区别,二者在做==运算时会得到什么结果?
|
1月前
|
Java
【Java基础面试七】、请介绍一下实例变量的默认值
这篇文章介绍了Java中实例变量的默认值:引用数据类型的默认值是null,而基本数据类型的默认值根据其类型分别是0、0L、0.0F、0.0、'\u0000'和false。
【Java基础面试七】、请介绍一下实例变量的默认值
|
17天前
|
存储 Java 程序员
优化Java多线程应用:是创建Thread对象直接调用start()方法?还是用个变量调用?
这篇文章探讨了Java中两种创建和启动线程的方法,并分析了它们的区别。作者建议直接调用 `Thread` 对象的 `start()` 方法,而非保持强引用,以避免内存泄漏、简化线程生命周期管理,并减少不必要的线程控制。文章详细解释了这种方法在使用 `ThreadLocal` 时的优势,并提供了代码示例。作者洛小豆,文章来源于稀土掘金。
|
30天前
|
存储 安全 Java
Java 中的 ThreadLocal 变量
【8月更文挑战第22天】
33 4
|
30天前
|
安全 Java 编译器
Java 中的 volatile 变量
【8月更文挑战第22天】
21 4
|
8天前
|
JavaScript 前端开发 Java
通过JUnit5访问Java静态、私有、保护变量和方法
在《通过Gtest访问C++静态、私有、保护变量和方法》一文中介绍了如何通过Gtest访问C++静态、私有、保护变量和方法,本文介绍如何通过Junit5访问Java静态、私有、保护变量和方法。
13 0
|
1月前
|
存储 Java 测试技术
Java零基础(15) - Java变量
【8月更文挑战第15天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
25 3
|
1月前
|
存储 Java 测试技术
Java零基础教学(14):Java变量详解
【8月更文挑战第14天】Java零基础教学篇,手把手实践教学!
12 2
|
1月前
|
Java 数据安全/隐私保护
03 Java流程控制-分支(if+switch+变量类型)
03 Java流程控制-分支(if+switch+变量类型)
23 5