最近接觸到用java代碼調用主機的命令部分感覺有點意思整理總結一下 環境jdk1.8 操作系統win10,不用引入其他的包jdk自帶的api就可以 一、java調用ping命令 import java.io.BufferedReader; import java.io.InputStreamRead ...
System
java.lang.System
類中提供了大量的靜態方法,可以獲取與系統相關的信息或系統級操作。System類私有修飾構造方法,不能創建對象,直接類名調用。
exit
// 終止當前運行的 Java 虛擬機,非零表示異常終止
public static void exit(int status)
currentTimeMillis
// 返回當前時間(以毫秒為單位)
public static long currentTimeMillis()
在控制台輸出1-10000,計算這段代碼執行了多少毫秒
public static void main(String[] args) {
//獲取當前時間毫秒值
System.out.println(System.currentTimeMillis());
//計算程式運行時間
long start = System.currentTimeMillis();
for (int i = 1; i <= 10000; i++) {
System.out.println(i);
}
long end = System.currentTimeMillis();
System.out.println("共耗時毫秒:" + (end - start));
}
arrayCopy
// 從指定源數組中複製一個數組
public static void arrayCopy(Object src, int srcPos, Object dest, int destPos, int length)
// Object src:要複製的數據源數組
// int srcPost:數據源數組的開始索引
// Object dest:複製後的目的數組
// int destPos:目的數組開始索引
// int length:要複製的數組元素的個數
將源數組中從1索引開始,複製3個元素到目的數組中
public static void main(String[] args){
int[] src = {1,2,3,4,5};
int[] dest = {6,7,8,9,0};
//將源數組中從1索引開始,複製3個元素到目的數組中
System.arraycopy(src,1,dest,0,3);
for(int i = 0 ; i < dest.length;i++){
System.out.println(dest[i]);
}
已知數組長度為10,存儲5個元素,其餘元素為null值,在指定索引為2的位置處添加一個元素"張三" 其餘元素依次後移
public class Test {
public static void main(String[] args) {
String[] arr = {"小一","大二","李四","王五","劉六",null,null,null,null,null};
// 首先計算數組中要移動元素的個數 移動個數 = 真實存儲元素個數-指定索引
int index = 2;
int moveNum =5-index;
// 如果需要移動的個數大於0則進行數組複製
if(moveNum>0){
System.arraycopy(arr,index,arr,index+1,moveNum);
}
System.out.println("列印移動後的數組");
System.out.println(Arrays.toString(arr));
// 將指定索引出的元素設置為張三
arr[index] = "張三";
System.out.println("列印修改後的數組");
System.out.println(Arrays.toString(arr));
}
}
數組中存儲n個元素,將指定索引處的元素刪除,並將後面的元素依次進1,將最後的一個元素置為null值
public class Test {
public static void main(String[] args) {
String[] arr = {"小一","大二","張三","李四","王五","劉六",};
//將2索引元素刪除 後面元素依次進1 將最後的元素的值 設置為null
int index = 2;
//計算移動的元素的個數
int moveNum = arr.length - index -1;
//如果計算的結果大於0則複製數組
if(moveNum>0){
System.arraycopy(arr,index+1,arr,index,moveNum);
}
//列印複製後的數組 Arrays.toString(數組) 將傳入的數組轉換為字元串
System.out.println(Arrays.toString(arr));
//將最後一個元素的值 置為null;
arr[arr.length-1] = null;
//列印將最後一個元素設置為null的數組
System.out.println(Arrays.toString(arr));
}
}
gc
// 運行垃圾回收器
public static void gc()
// JVM將從堆記憶體中清理對象,清理對象的同時會調用對象的finalize()方法
// JVM的垃圾回收器是通過另一個線程開啟的,因此程式中的效果並不明顯
public class Person {
protected void finalize() throws Throwable {
System.out.println("對象被回收");
}
public static void main(String[] args){
new Person();
new Person();
new Person();
new Person();
new Person();
new Person();
System.gc();
}
冒泡排序
數組的排序,是將數組中的元素按照大小進行排序,預設都是以升序的形式進行排序,數組排序的方法有很多
排序,都要進行數組 元素大小的比較,再進行位置的交換
冒泡排序法是採用數組中相鄰元素進行比較換位
public static void main(String[] args) {
public static void main(String[] args) {
//定義一個數組
int[] arr = {7, 6, 5, 4, 3};
System.out.println("排序前:" + arrayToString(arr));
// 這裡減1,是控制每輪比較的次數
for (int x = 0; x < arr.length - 1; x++) {
// -1是為了避免索引越界,-x是為了調高比較效率
for (int i = 0; i < arr.length - 1 - x; i++) {
if (arr[i] > arr[i + 1]) {
int temp = arr[i];
arr[i] = arr[i + 1];
arr[i + 1] = temp;
}
}
}
System.out.println("排序後:" + arrayToString(arr));
}
//把數組中的元素按照指定的規則組成一個字元串:[元素1, 元素2, ...]
public static String arrayToString(int[] arr) {
StringBuilder sb = new StringBuilder();
sb.append("[");
for (int i = 0; i < arr.length; i++) {
if (i == arr.length - 1) {
sb.append(arr[i]);
} else {
sb.append(arr[i]).append(", ");
}
}
sb.append("]");
String s = sb.toString();
return s;
}
}