「java赋值op」Java赋值方法
今天给各位分享java赋值op的知识,其中也会对Java赋值方法进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
- 1、在java中 变量之间是如何赋值的
- 2、java语言有几种数据类型?怎样申明和赋值??
- 3、java中数组赋值的方法是什么?
- 4、java中的op运算符怎么理解!
- 5、Java 小编程 char op = args[1].charAt(0) ;op是什么意思, args[1].charAt(0) 这句话是什么意思?
在java中 变量之间是如何赋值的
一、基本类型数据赋值
实验1 :定义一个int 类型变量a = 3,并将a 赋值给int b,然后将a ,赋值为5,那么b 的值是3 还是5 呢?
int a = 3;
int b = a ;
a = 5 ;
System.out.println(" a = " + a+" b = "+b );
运行程序 ,打印结果为 :
a = 5 b =3
我们看到,b并没有随a的改变而改变。基本数据类型是值赋值。
二、String类型数据赋值
实验2:定义一个String类型变量s1 赋值为“a”,并将s1赋值给String s2 ;然后将s1赋值为“b”,那么s2的值是 “a”还是 “b”?
String s1 = "a" ;
String s2 = s1;
s1 = "b" ;
System.out.println("s1 = "+s1+" s2 = "+ s2);
运行程序 ,打印结果为 :
s1 = b s2 =a
我们看到,s2并没有随s1的改变而改变。
三、自定义数据类型赋值
实验3: 创建一个TUser u1 ,并将u1赋值给TUser u2 ,将 u1重新赋值 ,u2会随着u1改变而改变吗 ?
TUser u1 = new TUser();
u1.setId(1);
TUser u2 = u1 ;
u1 = new TUser();
u1.setId(2);
System.out.println("ui :"+u1 + "\t\n" +"u2 : "+ u2);
运行程序,打印结果为:
u1 :TUser(id=2)
u2 : TUser(id=1)
我们看到u2并没有随着u1的改变而改变。
如果我们不改变u1指向的地址,而是改变u1指向地址所对应的数据(即将 u1 = new TUser(); 注释掉)。那么u1,u2 打印的记过将都会是 TUser(id=2)
通过以上三个实验我们发现:
变量之间的赋值,可以说没有所谓的值赋值和地址赋值。
简而言之,将一个变量a赋值给另一个变量b,是将这个变量a的值,拷贝一份给变量b(如果a是引用类型,就拷贝引用,如果是基本类型,就拷贝原始值)
java语言有几种数据类型?怎样申明和赋值??
一、基本数据类型
整型:byte、short、int、long (在计算机中以二进制补码格式存储)
浮点型:float、double (在计算机中以IEEE754格式存储)
字符型:char (在计算机中以unicode码格式存储)
布尔型:boolean (只有true和false两个值)
二、 1.长整型:long
定义:long a=100;int b=a; (编译出错)
给a重新赋值:long a=2147483648; (编译出错)
定义:long a=2147483648L;(正确,说明此时可以是long型的取值范围)
说明在long型的数据后不加L/l时,数据仍为long型,但其取值范围却是int型的取值范围;数据后加L/l时,取值范围才是long型的取值范围。
2.浮点型:long
定义:float a=19; 输出a时为19.0
定义:float a=19.1; (编译出错)
定义:float a=19.1f; (正确)
说明在 float型的数据后不加F/f,则数据不能有小数位,但输出时,能够输出一位小数;若在float型的数据后加上F/f,则数据可以有小数位;
三、类型转换(注:boolean型不会发生类型转换,基本类型和复合类型不能相互转换)
1.自动转换
1)赋值转换:用于短字节的数据类型转换成长字节的数据类型(byte型的数据不能转换成char型,short型和char型数据也不能相互转换)
2)单目运算符提升
++、——运算符不会自动提升,+(正)、-(负)会将byte、short、char型的数据自动转换成int型的数据
3)双目运算符提升
如果有一个操作数是double型的,则把另一个转换成double型;否则如果有一个操作数是float型的,则把另一个转换成float型;否则 如果有一个操作数是long型的,则把另一个转换成long型;否则两个操作数都转换成int型。
4)三目运算符op1 ? op2 : op3其中op1必须是boolean型的,而op2和op3两操作数必须是能够自动转换成相同类型的数据,op2和op3会自动提升为两操作数中字节较长的一个,并且结果为提升后的类型。
如:byte a1=20;
short a2=10;
boolean b=true;
short c = b ?
a1 : a2;
结果为short型的数据c
2.强制转换
例子:
int a;
byte b=(byte)a;
定义:a=-126;
(分析:int形的数据有4个字节,而byte形的数据只有1个字节,所以只取int型数据的最后一个字节)
a的原码: 10000000,00000000,00000000,01111110
补码: 11111111,11111111,11111111,10000010
法一:r=(10000010)=130 (此时将 10000010 看成是纯的二进制数去计算,而不考虑它的符号位); byte型数据范围〔-128,127〕,由于 r127,所以 r=r-M (若整型数据值域[-L,R],则M=L+R+1),如果r还不在byte型数据的取值范围内,则继续 r=r-M 直至r在其取值范围内,取得r后,即为byte型的 b .此处r=-126,所以输出b为-126.
法二:直接将int型数据的最后一个字节看成是byte型数据的补码形式,在将补码转换成原码,即得到 b
四、逻辑运算符
1.和|| (的优先级要高于||的)
特点:只要左操作数已经得出整个表达式的值,就不再计算右操作数的之值,左右操作数必须为boolean型的。
例子:
boolean test1= ++x==-1 ++x==1 || ++x=2;
boolean test2= ++y==-1 || ++y==1 ++y=2;
System.out.println(x+" "+test1);
System.out.println(y+" "+test2);
结果:1 false
2 true
2.和| (逻辑位运算符)
特点:先把两个操作数的值计算出来,然后再进行逻辑运算
int x=-1,y=-1;
boolean test1= ++x==-1 ++x==1 | ++x=2;
boolean test2= ++y==-1 | ++y==1 ++y=2;
System.out.println(x+" "+test1);
System.out.println(y+" "+test2);
结果: 2 false
2 true
五、移位运算
(左移)高位丢失、低位以0填充
(右移) 低位丢失、高位以符号位填充
(无符号位右移) 低位丢失、高位以0填充
此运算符不会对左右两操作数作算术提升,但会对左操作数进行单独提升,若为byte、short、char、int型,则得到结果为int型,若为long型,则结果为long型,但左右操作数均不能为浮点型,否则出错。
当左操作数为int型时,右操作数的低5位才有用,这样可以防止移位超过int型所具有的位数,当左操作数为long型时,右操作数的低6位才有用。
例子:
int a=-2;
short b=-10;
int c=ab;
b的补码:11111111,11111111,11111111,11110110
取b的最后5位, r=(10110)=22;
a的补码:11111111,11111111,11111111,11111110
将a向右移动22位,再在高位补上1,得到 11111111,11111111,11111111,11111111 ,转换成原码得到 c=-1
六、赋值运算
1.简单赋值运算
表达式: 变量=表达式
左操作数可以事先没有赋值
表达式的类型必须和变量的类型相同,或能赋值转换成变量的类型,
2.组合赋值运算
表达式:变量 op= 表达式
int a=10;
double b=23.3;
a*=b;
左操作数事先一定要赋值
左边的类型和右边的类型不一定要相同,此处a*b得到的是double型的,组合运算符会自动把double型的值转换成int型的值存入变量a中。
java中数组赋值的方法是什么?
public class TempArray {
public static void main(String[] args) {
//声明数值型数组
int[] array = {1, 2};
int[] array2 = new int[4];
//新增一个数组长度
array = Arrays.copyOf(array, array.length+1);
//将3这个数值赋值个数组索引 2 的位置,也就是最后面追加
array[array.length-1] = 3;
System.out.println(array2.length); //Result: 4
上面用的是数组,你也可以用 ArrayList 数组列表,是List的一个实现。
Java是一种可以撰写跨平台应用软件的面向对象的程序设计语言。
Java 技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于PC、数据中心、游戏控制台、科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。
Java由四方面组成:
1.Java编程语言,即语法。
2.Java文件格式,即各种文件夹、文件的后缀。
3.Java虚拟机(JVM),即处理*.class文件的解释器。
4.Java应用程序接口(Java API)。
java中的op运算符怎么理解!
a*=xxx 相当于 a = a*xxx
这些运算符都可以这么理解,唯一不同的地方就是,这样做以后会进行类型转换
比如int a=1; a*=0.5 这按照 a=a*0.5来计算的话需要转成int类型才可以赋值给a,但是使用 *= 运算符的话就直接把结果强行转换成int类型了,这是一个不同处
另一个不同处就是 a=a*0.5 这种运算符会先拿出a来,然后进行运算在放回a里去,而*=运算符是直接拿a做运算的,而不是把a拿出来在做运算,这也是为什么会进行强制的类型转换的原因
Java 小编程 char op = args[1].charAt(0) ;op是什么意思, args[1].charAt(0) 这句话是什么意思?
op是定义的一个char类型的变量,args[]是保存运行程序前给它的参数的数组,args[1].charAt(0)意思是获取数组下标为1的元素的第一个字符,变量op指向这个字符。
java赋值op的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于Java赋值方法、java赋值op的信息别忘了在本站进行查找喔。