数组

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. webpack学习遇到大坑(纯属自己记录)

    分清webpack1与webpack2区别 1.webpack2的loader不能使用简写了,否则会报如下的错 正确如下: 2.node-sass安装失败,无法下载:Cannot download h ...

  2. 一站式Web开发套件BeetleX.WebFamily

    BeetleX.WebFamily是一款前后端分离的Web开发套件,但它并不依赖于nodejs/npm/webpack等相关工具:而使用自身实现的方式来完成前后端分离的Web应用开发:套件以组件的方式 ...

  3. Java学习的第三十四天

    1.今天复习完了第十二章 2.有很多的方法不知道什么意思,也记不清该用什么方法. 3.明天写例题.

  4. 2018-12-5 及 codeforces round 525v2

    突然发现五天没记录了,这五天学习完全没有按着正常规划进行,先罗列一下吧. 机器学习视频第一周的全部看完了. 算法导论看了几页. 参加了一次CF.rating只加了20,看来提高实力才是最关键的. C+ ...

  5. 【Android Studio】安卓开发初体验1——安装与试用

    安装 (安装预留硬盘(C盘)空余空间16G以上,8G以上内存) Intel用户: 安装Android Studio和AVD(安卓虚拟机 Android Virtual Device) 安装过程需要注意 ...

  6. leetcode147median-of-two-sorted-arrays

    题目描述 有两个大小分别为m和n的有序数组A和B.请找出这两个数组的中位数.你需要给出时间复杂度在O(log (m+n))以内的算法. There are two sorted arrays A an ...

  7. MarkDown使用教程(In Atom)

    程序猿都爱写博客,在写博客的过程中,大量运用的就是MarkDown语法了.MarkDown不只是用来写博客,日常生活中的感悟.工作中的心得体会.项目任务安排等等大篇幅的文章都可以用MarkDown来迅 ...

  8. mvc SelectList 给下拉框 @Html.DropDownList绑定值

    后台代码: public class DropController : Controller { // GET: Drop public ActionResult Index() { List< ...

  9. 前端性能优化之 gzip+cache-control

    刚刚在Node.js环境下使用gzippo模块进行了测试. 使用gzip的压缩率惊人的好,达到了50%以上. 再加上express的staticCache,配合cache-control max-ag ...

  10. TCP数据接收及快速路径和慢速路径

    概述 tcp握手完成后,收到数据包后,调用路径为tcp_v4_rcv->tcp_v4_do_rcv->tcp_rcv_established在tcp_rcv_established中处理T ...