首页 > 编程语言 >java -- System类和冒泡排序

java -- System类和冒泡排序

时间:2023-04-06 19:44:05浏览次数:37  
标签:arr java -- 元素 System 冒泡排序 int 数组 public

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;
    }
}

标签:arr,java,--,元素,System,冒泡排序,int,数组,public
From: https://www.cnblogs.com/paopaoT/p/17293929.html

相关文章

  • java调用本机的命令 如ping、打开文本等
    最近接触到用java代码调用主机的命令部分感觉有点意思整理总结一下环境jdk1.8 操作系统win10,不用引入其他的包jdk自带的api就可以一、java调用ping命令importjava.io.BufferedReader;importjava.io.InputStreamReader;importjava.nio.charset.Charset;//调用本机ping......
  • FolderBrowserDialog类实现选择打开文件
    privatevoidbutton1_Click(objectsender,EventArgse){FolderBrowserDialogdilog=newFolderBrowserDialog();dilog.Description="请选择文件夹";if(dilog.ShowDialog()==DialogResult.OK||dilog.ShowDialo......
  • redis基础数据结构详解
    一.redis为什么快基于内存的存储虽然是单线程,但是采取了多路复用,可以高效的处理网络并发良好的数据结构设计二.redis基础数据结构redis有五种基础的数据结构string,list,set,zset,hashredis所有的数据结构的key都是string类型,我们所说的数据结构都是指value的数据结构......
  • STATA 值标签相关操作
    labeldir//显示所有值标签对应的变量名labellist//显示所有带有值标签的变量名,并且显示具体的值标签及对应值labellistorigin//显示指定带有值标签的变量史,并且显示具体的值标签及对应值//使用举例:usece11,clearlist//+------------------------------------......
  • 大数据经典论文解读 - Metastore
    MetastoreMegastore:Providingscalable,highlyavailablestorageforinteractiveservices在Bigtable上支持SQL,实现分布式数据库:跨数据中心的多副本同步数据复制支持为多数据表的字段建立Schema,且通过SQL接口访问支持数据库的二级索引支持数据库的事务Megastore是......
  • DS4700/DS4800 存储巡检
    DS4800——(M02,连B控1口)192.168.128.100ping192.168.128.102DS4700——(O07,M04)port1B控192.168.128.102/241.安装点击0035.exe,简体中文(ok),next,next,accept(next),选择路径(next),Typical(next),Automaticallystartmonitor(next),install,Done2.连接3.查看......
  • flask源码分析
    目录请求上下文分析(源码:request原理)导出项目的依赖函数和方法threading.local对象偏函数flask整个生命执行流程(1.1.4版本为例)wtforms请求上下文分析(源码:request原理)导出项目的依赖之前的pipfreeze>requeirments.txt会把当前解释器环境下的所有第三方依赖都导出来......
  • vue动态添加表单validateField验证
    1<template>2<el-formref="form":model="form":rules="rules"label-width="100px">3<divv-for="(input,index)ininputs":key="index">4<el-form-......
  • IBM V5000巡检
    1.连接默认为192.168.70.121(本机要设置成一样的网段)2.登录网页1F-D01需要使用旧版火狐浏览器,1F-E08,E09使用谷歌就行输入默认登录用户:superuser密码:password3.登录界面如下4.第二个-35.第三个-1-4第四个-1-2-3第五个-1-4 ......
  • 配电网分布式电源和储能选址定容 以配电网总成本最低为目标函数,其中包括年运行成本
    配电网分布式电源和储能选址定容以配电网总成本最低为目标函数,其中包括年运行成本,设备维护折损成本、环境成本;以系统潮流运行为约束条件,采用粒子群算法求解,实现光伏、风电、储能设备的规划。YID:4980674139963843......