数组

Java数组:用于存储同一种数据类型的多个数据。

Java数组本身是一种数据类型——引用类型。

类(String、Scanner等大写字母开头的类型)也属于引用类型,int、double等基本类型不是引用类型。

数组的定义

// C语言风格
int a[] = { 1, 2, 3 }; // Java风格(面向对象风格,推荐!)
int[] b = { 4, 5, 6 };

静态初始化和动态初始化

也就是“手动赋值”、“系统赋值”:

public class 静态初始化和动态初始化 {
public static void main(String[] args) {
int[] _静态初始化 = new int[] { 1, 2, 3 };
int[] _静态初始化_简化 = { 1, 2, 3 };
char[] _动态初始化 = new char[3];
}
}

动态初始化的场合,系统赋什么值?

大分类 小分类 系统赋值
基本类型 整数类型 0
基本类型 浮点类型 0 .0
基本类型 字符类型 '\u0000'
基本类型 布尔类型 FALSE
引用类型 类、接口、数组 null

遍历数组

数组通过“索引(index)”访问,从0开始,最大为“数组长度-1”。

int[] c = new int[5];

// ↓↓↓写入
for (int i = 0; i < c.length; i++) {
c[i] = i * 2;
} // ↓↓↓输出
for (int i = 0; i < c.length; i++) {
System.out.println(c[i]);
}

Java 5之后,加入了“foreach循环”,代码更简洁。

int[] d = { 1, 2, 3, 4, 5 };

// foreach循环遍历数组:只读
for (int n : d) {
System.out.println(n);
}

该循环体中,对n赋值是可以的,但只是对临时变量赋值,无法改写数组中的实际值。

数组的应用:冒泡排序

核心思想:

  • 一个数和其它数比较(循环)

  • 每个数都要做这种比较(再一层循环)


虎老狮口诀

冒泡排序三步走:

循环、

交换、

回一手

(回一手是在内层循环-i,主要是为了减少无畏的比较次数,提高效率,不回也行)

public class BubbleSort {
public static void main(String[] args) {
int[] arr = { 1, 2, 3, 4, 5 };
int temp;
for (int i = 0; i < arr.length; i++) {
// 注意,内存循环要-1,否则比较时[j+1]会越界
for (int j = 0; j < arr.length - 1 - i; j++) {
if (arr[j] < arr[j + 1]) {
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
for (int n : arr) {
System.out.println(n);
}
}
}

Arrays类

Arrays类提供了大量的静态方法,实现数组的常见操作。

import java.util.Arrays;
public class TestArrays类 {
public static void main(String[] args) {
int[] arr = { 2, 1, 5, 4, 3 };
// Arrays.sort(数组):升序排列
Arrays.sort(arr);
// *Java 8的并行排序,支持多核CPU,更快
Arrays.parallelSort(arr);
// Arrays.toString(数组):数组转为字符串
String s = Arrays.toString(arr);
System.out.println("排序后:" + s);
}
}

Java基础教程——数组的更多相关文章

  1. Java基础教程:Lambda表达式

    Java基础教程:Lambda表达式 本文部分内容引用自OneAPM:http://blog.oneapm.com/apm-tech/226.html 引入Lambda Java 是一流的面向对象语言 ...

  2. Java基础教程:多线程基础(1)——基础操作

    Java:多线程基础(1) 实现多线程的两种方式 1.继承Thread类 public class myThread extends Thread { /** * 继承Thread类,重写RUN方法. ...

  3. Java基础教程:反射基础

    Java基础教程:反射基础 引入反射 反射是什么 能够动态分析类能力的程序称为反射. 反射是一种很强大且复杂的机制. Class类 在程序运行期间,Java运行时系统始终为所有对象维护一个被称为运行时 ...

  4. Java基础教程:面向对象编程[2]

    Java基础教程:面向对象编程[2] 内容大纲 访问修饰符 四种访问修饰符 Java中,可以使用访问控制符来保护对类.变量.方法和构造方法的访问.Java 支持 4 种不同的访问权限. default ...

  5. Java基础教程:面向对象编程[1]

    Java基础教程:面向对象编程 内容大纲 Java语言概述 Java语言特点 1.Java为纯面向对象的语言,它能够直接反映现实生活中的对象.总之,Everything is object! 2.平台 ...

  6. Java基础教程:HashTable与HashMap比较

    Java基础教程:HashTable与HashMap比较 1.  关于HashMap的一些说法: a)  HashMap实际上是一个“链表散列”的数据结构,即数组和链表的结合体.HashMap的底层结 ...

  7. Java基础教程:JDBC编程

    Java基础教程:JDBC编程 1.什么是JDBC JDBC 指 Java 数据库连接,是一种标准Java应用编程接口( JAVA API),用来连接 Java 编程语言和广泛的数据库. JDBC A ...

  8. Java基础教程:对象比较排序

    Java基础教程:对象比较排序 转载请标明出处:http://blog.csdn.net/wangtaocsdn/article/details/71500500 有时候需要对对象列表或数组进行排序, ...

  9. Java基础教程:面向对象编程[3]

    Java基础教程:面向对象编程[3] 内容大纲 基础编程 获取用户输入 java.util.Scanner 是 Java5 的新特征,我们可以通过 Scanner 类来获取用户的输入.我们可以查看Ja ...

随机推荐

  1. 批量安装Zabbix_Agent

    使用自动化部署工具Ansible批量部署zabbix_agent. 1. 安装Ansible yum –y install ansible 内网情况下,现在ansible及其依赖的rpm包,添加到yu ...

  2. Linux 网络编程的5种IO模型:多路复用(select/poll/epoll)

    Linux 网络编程的5种IO模型:多路复用(select/poll/epoll) 背景 我们在上一讲 Linux 网络编程的5种IO模型:阻塞IO与非阻塞IO中,对于其中的 阻塞/非阻塞IO 进行了 ...

  3. Hadoop高可用

    一.原因 - NameNode是HDFS的黑心配置HDFS有事hadoop的核心组件 NameNode 在Hadoop及群众至关重要 - NameNode的宕机导致集群的不可用 二.解决方案 其中 N ...

  4. 教你如何 分析 Android ANR 问题

    ANR介绍 ANR 的全称是 Application No Responding,即应用程序无响应,具体是一些特定的 Message (Key Dispatch.Broadcast.Service) ...

  5. 微信小程序获取普通二维码

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  6. 一次webapi Post请求失败记录

    //点击添加按钮 $("#add").click(function () { //layer.msg("添加"); var data = { "stu ...

  7. HTML生成横向的PDF

    HTML生成PDF请参照:https://www.cnblogs.com/yunfeiyang-88/p/10984740.html 如要生成横向的PDF:在html模板的style标签里面加入@pa ...

  8. Cocos Creator与VS Code整合代码提示问题

    Cocos Creator与VS Code整合开发配置 在Cocos Creator中依次点击下面框中的菜单 VS Code工作流 配置Cocos Creator的默认编辑器 Cocos Creato ...

  9. JS函数命名规范

    语法规范: 任何合法的javascript标识符都可以作为函数的名称. 约定俗成的内容:(非ECMAScript语法,但是为了便于开发者理解和识别,约定的函数命名规范.) 命名方法: 小驼峰式命名法 ...

  10. 手把手教你使用Vuex(四)

    3.Action Action类似于mutation,不同之处在于: Action提交的是mutation,而不是直接变更状态 Action可以包含任何异步操作 可以理解为将mutations里面处理 ...