Ⅰ java中,數組可以怎麼賦值,幾種賦值方法
public class TempArray {
public static void main(String[] args) {
//聲禪叢孝明數值型數組
int[] array = {1, 2};
int[] array2 = new int[4];
//新增一個數組長度
array = Arrays.Of(array, array.length+1);
//將3這個數值賦值個數組索引 2 的位置,也就是最後面追加
array[array.length-1] = 3;
System.out.println(array2.length); //Result: 4
上面用的是數組,你也可以用 ArrayList 數組列表,是List的一個實現。
Ⅱ JAVA中靜態變數如何動態賦值
寫一個方法,然後用方法的參數t2給t1賦值,另一個類val用的時候,先用demo的一個對象,調用方法,修改t1
Ⅲ JAVA里怎麼把這個數組賦值給另一個數組
有兩種方法
第一種用for循環:
int[]x={1,2};
int[]y=newint[2];
for(inti=0;i<x.length;i++){
y[i]=x[i];
第二種用java提供的array
int[]x={1,2};
int[]y=newint[2];
System.array(x,0,y,0,x.length);//變數依次是(原數組,從原數組第幾位開始,目標數組,從第幾位開始粘貼,復制長度)
Ⅳ 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〕,由於 r>127,所以 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=a>>b;
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 為什麼數字賦值char可以
因為賦值的char類型會自動轉化為int類型的。所以是可以的。