日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

java如何创造一个整数的类_【技术干货】Java 面试宝典:Java 基础部分(1)

發布時間:2025/3/20 java 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java如何创造一个整数的类_【技术干货】Java 面试宝典:Java 基础部分(1) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

原標題:【技術干貨】Java 面試寶典:Java 基礎部分(1)

Java基礎部分:

基礎部分的順序:基本語法,類相關的語法,內部類的語法,繼承相關的語法,異常的語法,線程的語法,集合的語法,io 的語法,虛擬機方面的語法。

1、一個".java"源文件中是否可以包括多個類(不是內部類)?有什么限制?

可以有多個類,但只能有一個 public 的類,并且 public 的類名必須與文件名相一致。

2、Java 有沒有 goto?

goto是Java 中的保留字,現在沒有在 Java 中使用。

3、說說 & 和 && 的區別。

&和&&都可以用作邏輯與的運算符,表示邏輯與(and),當運算符兩邊的表達式的結果都為 true 時,整個運算結果才為 true,否則,只要有一方為 false,則結果為 false。

&&還具有短路的功能,即如果第一個表達式為 false,則不再計算第二個表達式,例如,對于 if(str != null && !str.equals(“”))表達式,當 str 為 null 時,后面的表達式不會執行,所以不會出現 NullPointerException如果將&&改為&,則會拋出 NullPointerException 異常。If(x==33 & ++y>0) y 會增長,If(x==33 && ++y>0)不會增長。

&還可以用作位運算符,當&操作符兩邊的表達式不是 boolean 類型時,&表示按位與操作,我們通常使用 0x0f 來與一個整數進行&運算,來獲取該整數的最低 4 個 bit 位,例如,0x31 & 0x0f 的結果為 0x01。

備注:這道題先說兩者的共同點,再說出 && 與 & 的特殊之處,并列舉一些經典的例子來表明自己理解透徹深入、實際經驗豐富。

4、在 Java 中如何跳出當前的多重嵌套循環?

在 Java 中,要想跳出多重循環,可以在外面的循環語句前定義一個標號,然后在里層循環體的代碼中使用帶有標號的 break 語句,即可跳出外層循環。例如,

ok:

for(int i=0;i<10;i++) {

for(int j=0;j<10;j++) {

System.out.println(“i=” + i + “,j=” + j);

if(j == 5) break ok;

}

}

另外,我個人通常并不使用標號這種方式,而是讓外層的循環條件表達式的結果可以受到里層循環體代碼的控制,例如,要在二維數組中查找到某個數字。

int arr[][] = {{1,2,3},{4,5,6,7},{9}};

boolean found = false;

for(int i=0;i

for(int j=0;j

System.out.println("i=" + i + ",j=" + j);

if(arr[i][j] == 5) {

found = true;

break;

}

}

}

5、switch 語句能否作用在 byte 上,能否作用在 long 上,能否作用在 String 上?

在 switch(expr1)中,expr1 只能是一個整數表達式或者枚舉常量(更大字體),整數表達式可以是 int基本類型或 Integer 包裝類型,由于,byte,short,char 都可以隱含轉換為 int,所以,這些類型以及這些類型的包裝類型也是可以的。顯然,long 和 String 類型都不符合 switch 的語法規定,并且不能被隱式轉換成 int類型,所以,它們不能作用于 swtich 語句中。

6、short s1 = 1; s1 = s1 + 1;有什么錯? short s1 = 1; s1 += 1;有什么錯?

對于 short s1 = 1; s1 = s1 + 1; 由于 s1+1 運算時會自動提升表達式的類型,所以結果是 int 型,再賦值給 short 類型 s1 時,編譯器將報告需要強制轉換類型的錯誤。

對于 short s1 = 1; s1 += 1;由于 += 是 java 語言規定的運算符,java 編譯器會對它進行特殊處理,因此可以正確編譯。

7、char 型變量中能不能存貯一個中文漢字?為什么?

char 型變量是用來存儲 Unicode 編碼的字符的,unicode 編碼字符集中包含了漢字,所以,char 型變量中當然可以存儲漢字啦。不過,如果某個特殊的漢字沒有被包含在 unicode 編碼字符集中,那么,這個 char型變量中就不能存儲這個特殊漢字。補充說明:unicode 編碼占用兩個字節,所以,char 類型的變量也是占用兩個字節。

備注:后面一部分回答雖然不是在正面回答題目,但是,為了展現自己的學識和表現自己對問題理解的透徹深入,可以回答一些相關的知識,做到知無不言,言無不盡。

8、用最有效率的方法算出 2 乘以 8 等於幾?

2 << 3,

因為將一個數左移 n 位,就相當于乘以了 2 的 n 次方,那么,一個數乘以 8 只要將其左移 3 位即可,而位運算 cpu 直接支持的,效率最高,所以,2 乘以 8 等於幾的最效率的方法是 2 << 3。

9、請設計一個一百億的計算器。

首先要明白這道題目的考查點是什么,一是大家首先要對計算機原理的底層細節要清楚、要知道加減法的位運算原理和知道計算機中的算術運算會發生越界的情況,二是要具備一定的面向對象的設計思想。

首先,計算機中用固定數量的幾個字節來存儲的數值,所以計算機中能夠表示的數值是有一定的范圍的,為了便于講解和理解,我們先以 byte 類型的整數為例,它用 1 個字節進行存儲,表示的最大數值范圍為-128 到+127。-1 在內存中對應的二進制數據為 11111111,如果兩個-1 相加,不考慮 Java 運算時的類型提升,運算后會產生進位,二進制結果為 1,11111110,由于進位后超過了 byte 類型的存儲空間,所以進位部分被舍棄,即最終的結果為 11111110,也就是-2,這正好利用溢位的方式實現了負數的運算。-128 在內存中對應的二進制數據為 10000000,如果兩個-128 相加,不考慮 Java 運算時的類型提升,運算后會產生進位,二進制結果為 1,00000000,由于進位后超過了 byte 類型的存儲空間,所以進位部分被舍棄,即最終的結果為 00000000,也就是 0,這樣的結果顯然不是我們期望的,這說明計算機中的算術運算是會發生越界情況的,兩個數值的運算結果不能超過計算機中的該類型的數值范圍。由于 Java 中涉及表達式運算時的類型自動提升,我們無法用 byte 類型來做演示這種問題和現象的實驗,大家可以用下面一個使用整數做實驗的例子程序體驗一下:

int a = Integer.MAX_VALUE;

int b = Integer.MAX_VALUE;

int sum = a + b;

System.out.println(“a=”+a+”,b=”+b+”,sum=”+sum);

先不考慮 long 類型,由于 int 的正數范圍為 2 的 31 次方,表示的最大數值約等于 2*1000*1000*1000,也就是 20 億的大小,所以,要實現一個一百億的計算器,我們得自己設計一個類可以用于表示很大的整數,并且提供了與另外一個整數進行加減乘除的功能,大概功能如下:

()這個類內部有兩個成員變量,一個表示符號,另一個用字節數組表示數值的二進制數。

()有一個構造方法,把一個包含有多位數值的字符串轉換到內部的符號和字節數組中。

()提供加減乘除的功能。

public class BigInteger{

int sign;

byte[] val;

public Biginteger(String val){

sign = ;val = ;

}

public BigInteger add(BigInteger other) {

}

public BigInteger subtract(BigInteger other) {

}

public BigInteger multiply(BigInteger other){

}

public BigInteger divide(BigInteger other){

}

}

備注:要想寫出這個類的完整代碼,是非常復雜的,如果有興趣的話,可以參看 jdk 中自帶的java.math.BigInteger 類的源碼。面試的人也知道誰都不可能在短時間內寫出這個類的完整代碼的,他要的是你是否有這方面的概念和意識,他最重要的還是考查你的能力,所以,你不要因為自己無法寫出完整的最終結果就放棄答這道題,你要做的就是你比別人寫得多,證明你比別人強,你有這方面的思想意識就可以了,畢竟別人可能連題目的意思都看不懂,什么都沒寫,你要敢于答這道題,即使只答了一部分,那也與那些什么都不懂的人區別出來,拉開了距離,算是矮子中的高個,機會當然就屬于你了。另外,答案中的框架代碼也很重要,體現了一些面向對象設計的功底,特別是其中的方法命名很專業,用的英文單詞很精準,這也是能力、經驗、專業性、英語水平等多個方面的體現,會給人留下很好的印象,在編程能力和其他方面條件差不多的情況下,英語好除了可以使你獲得更多機會外,薪水可以高出一千元。

10、使用 final 關鍵字修飾一個變量時,是引用不能變,還是引用的對象不能變?

使用 final 關鍵字修飾一個變量時,是指引用變量不能變,引用變量所指向的對象中的內容還是可以改變的。例如,對于如下語句:

final StringBuffer a=new StringBuffer("immutable");

執行如下語句將報告編譯期錯誤:

a=new StringBuffer("");

但是,執行如下語句則可以通過編譯:

a.append(" broken!");

有人在定義方法的參數時,可能想采用如下形式來阻止方法內部修改傳進來的參數對象:

public void method(final StringBuffer param){

}

實際上,這是辦不到的,在該方法內部仍然可以增加如下代碼來修改參數對象:

param.append("a");

11、"=="和 equals 方法究竟有什么區別?

(單獨把一個東西說清楚,然后再說清楚另一個,這樣,它們的區別自然就出來了,混在一起說,則很難說清楚)

==操作符專門用來比較兩個變量的值是否相等,也就是用于比較變量所對應的內存中所存儲的數值是否相同,要比較兩個基本類型的數據或兩個引用變量是否相等,只能用==操作符。

如果一個變量指向的數據是對象類型的,那么,這時候涉及了兩塊內存,對象本身占用一塊內存(堆內存),變量也占用一塊內存,例如 Objet obj = new Object();變量 obj 是一個內存,new Object()是另一個內存,此時,變量 obj 所對應的內存中存儲的數值就是對象占用的那塊內存的首地址。對于指向對象類型的變量,如果要比較兩個變量是否指向同一個對象,即要看這兩個變量所對應的內存中的數值是否相等,這時候就需要用==操作符進行比較。

equals 方法是用于比較兩個獨立對象的內容是否相同,就好比去比較兩個人的長相是否相同,它比較的兩個對象是獨立的。例如,對于下面的代碼:

String a=new String("foo");

String b=new String("foo");

兩條 new 語句創建了兩個對象,然后用 a,b 這兩個變量分別指向了其中一個對象,這是兩個不同的對象,它們的首地址是不同的,即 a 和 b 中存儲的數值是不相同的,所以,表達式 a==b 將返回 false,而這兩個對象中的內容是相同的,所以,表達式 a.equals(b)將返回 true。

在實際開發中,我們經常要比較傳遞進行來的字符串內容是否等,例如, String input = …;input.equals(“quit”),許多人稍不注意就使用==進行比較了,這是錯誤的,隨便從網上找幾個項目實戰的教學視頻看看,里面就有大量這樣的錯誤。記住,字符串的比較基本上都是使用 equals 方法。

如果一個類沒有自己定義 equals 方法,那么它將繼承 Object 類的 equals 方法,Object 類的 equals 方法的實現代碼如下:

boolean equals(Object o){

return this==o;

}

這說明,如果一個類沒有自己定義 equals 方法,它默認的 equals 方法(從 Object 類繼承的)就是使 用==操作符,也是在比較兩個變量指向的對象是否是同一對象,這時候使用 equals 和使用==會得到同樣的結果,如果比較的是兩個獨立的對象則總返回 false。如果你編寫的類希望能夠比較該類創建的兩個實例對象的內容是否相同,那么你必須覆蓋 equals 方法,由你自己寫代碼來決定在什么情況即可認為兩個對象的內容是相同的。

12、靜態變量和實例變量的區別?

在語法定義上的區別:靜態變量前要加 static 關鍵字,而實例變量前則不加。

在程序運行時的區別:實例變量屬于某個對象的屬性,必須創建了實例對象,其中的實例變量才會被分配空間,才能使用這個實例變量。靜態變量不屬于某個實例對象,而是屬于類,所以也稱為類變量,只要程序加載了類的字節碼,不用創建任何實例對象,靜態變量就會被分配空間,靜態變量就可以被使用了。

總之,實例變量必須創建對象后才可以通過這個對象來使用,靜態變量則可以直接使用類名來引用。

例如,對于下面的程序,無論創建多少個實例對象,永遠都只分配了一個 staticVar 變量,并且每創建一個實例對象,這個 staticVar 就會加 1;但是,每創建一個實例對象,就會分配一個 instanceVar,即可能分配多個 instanceVar,并且每個 instanceVar 的值都只自加了 1 次。

public class VariantTest{

public static int staticVar = 0;

public int instanceVar = 0;

public VariantTest(){

staticVar++;

instanceVar++;

System.out.println(“staticVar=” + staticVar + ”,instanceVar=” + instanceVar);

}

}

備注:這個解答除了說清楚兩者的區別外,最后還用一個具體的應用例子來說明兩者的差異,體現了自己有很好的解說問題和設計案例的能力,思維敏捷,超過一般程序員,有寫作能力。

13、是否可以從一個 static 方法內部發出對非 static 方法的調用?

不可以。因為非 static 方法是要與對象關聯在一起的,必須創建一個對象后,才可以在該對象上進行方法調用,而static 方法調用時不需要創建對象,可以直接調用。也就是說,當一個 static 方法被調用時,可能還沒有創建任何實例對象,如果從一個 static 方法中發出對非 static 方法的調用,那個非 static 方法是關聯到哪個對象上的呢?這個邏輯無法成立,所以,一個 static 方法內部發出對非 static 方法的調用。

14、Integer 與 int 的區別是什么?

int 是 java 提供的 8 種原始數據類型之一。Java 為每個原始類型提供了封裝類,Integer 是 java 為 int 提供的封裝類。int 的默認值為 0,而 Integer 的默認值為 null,即 Integer 可以區分出未賦值和值為 0 的區別,int 則無法表達出未賦值的情況,例如,要想表達出沒有參加考試和考試成績為 0的區別,則只能使用 Integer。在 JSP 開發中,Integer 的默認為 null,所以用 el 表達式在文本框中顯示時,值為空白字符串,而 int 默認的默認值為 0,所以用 el 表達式在文本框中顯示時,結果為 0,所以,int 不適合作為 web 層的表單數據的類型。

在 Hibernate 中,如果將 OID 定義為 Integer 類型,那么 Hibernate 就可以根據其值是否為 null 而判斷一個對象是否是臨時的,如果將 OID 定義為了 int 類型,還需要在 hbm 映射文件中設置其 unsaved-value 屬性為 0。

另外,Integer 提供了多個與整數相關的操作方法,例如,將一個字符串轉換成整數,Integer 中還定義了表示整數的最大值和最小值的常量。

15、Math.round(11.5)等於多少? Math.round(-11.5)等於多少?

Math 類中提供了三個與取整有關的方法:ceil、floor、round,這些方法的作用與它們的英文名稱的含義相對應,例如,ceil 的英文意義是天花板,該方法就表示向上取整,Math.ceil(11.3)的結果為12,Math.ceil(-11.3)的結果是-11;floor 的英文意義是地板,該方法就表示向下取整,Math.ceil(11.6)的結果為11,Math.ceil(-11.6)的結果是-12;最難掌握的是 round 方法,它表示“四舍五入”,算法為 Math.floor(x+0.5),即將原來的數字加上 0.5 后再向下取整,所以,Math.round(11.5)的結果為 12,Math.round(-11.5)的結果為-11。

總結

以上就是今天的內容了,如果對你有所幫助,希望你能夠關注、點贊、轉發一鍵三連支持一下。

需要完整學習線路和配套課堂筆記,請回復111。返回搜狐,查看更多

責任編輯:

總結

以上是生活随笔為你收集整理的java如何创造一个整数的类_【技术干货】Java 面试宝典:Java 基础部分(1)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。