Java基本的程序结构设计 数组
声明数组:
int[] a;
int a[];
两种方式。一般选择第一种,比较一目了然。
初始化,必须指定长度:
int[] a = new int[10];
int[] a = {1,2,3};
初始化:
- package com.zjf;
 - import java.util.Arrays;
 - import com.zjf.spring.mybatis.model.Person;
 - public class Test {
 - public static void main(String[] args) {
 - //定义数组
 - int[] a = new int[3];
 - //默认初始化 打印查看为0
 - System.out.println(Arrays.toString(a));
 - //也可以存储对象
 - Person[] p = new Person[2];
 - //默认初始化为null
 - System.out.println(Arrays.toString(p));
 - }
 - }
 
结果:
[0, 0, 0]
[null, null]
数组拷贝
两种方式。
- package com.zjf;
 - import java.util.Arrays;
 - public class Test {
 - public static void main(String[] args) {
 - int[] a = {0,1,2,3,4,5,6,7,8,9};
 - int[] b = Arrays.copyOf(a, a.length);
 - int[] c = new int[a.length];
 - System.arraycopy(a, 0, c, 0, a.length);
 - System.out.println(Arrays.toString(b));
 - System.out.println(Arrays.toString(c));
 - }
 - }
 
结果:
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
数组排序:
- package com.zjf;
 - import java.util.Arrays;
 - import com.zjf.spring.mybatis.model.Person;
 - public class Test {
 - public static void main(String[] args) {
 - int[] a = {0,6,2,8,4,5,1,7,3,9};
 - Arrays.sort(a);
 - System.out.println(Arrays.toString(a));
 - Person p1 = new Person(2,"zjf",29,"beiing");
 - Person p2 = new Person(1,"xhj",29,"beiing");
 - Person[] p = {p1,p2};
 - Arrays.sort(p);
 - System.out.println(Arrays.toString(p));
 - }
 - }
 
结果:
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
Exception in thread "main" java.lang.ClassCastException: com.zjf.spring.mybatis.model.Person cannot be cast to java.lang.Comparable
at java.util.ComparableTimSort.countRunAndMakeAscending(Unknown Source)
at java.util.ComparableTimSort.sort(Unknown Source)
at java.util.ComparableTimSort.sort(Unknown Source)
at java.util.Arrays.sort(Unknown Source)
at com.zjf.Test.main(Test.java:13)
- package com.zjf;
 - import java.util.Arrays;
 - import java.util.Comparator;
 - import com.zjf.spring.mybatis.model.Person;
 - public class Test {
 - public static void main(String[] args) {
 - int[] a = { 0, 6, 2, 8, 4, 5, 1, 7, 3, 9 };
 - Arrays.sort(a);
 - System.out.println(Arrays.toString(a));
 - Person p1 = new Person(2, "zjf", 29, "beiing");
 - Person p2 = new Person(1, "xhj", 29, "beiing");
 - Person[] p = { p1, p2 };
 - Arrays.sort(p, new Comparator<Person>() {
 - public int compare(Person o1, Person o2) {
 - return o1.getId().compareTo(o2.getId());
 - }
 - });
 - System.out.println(Arrays.toString(p));
 - }
 - }
 
结果:
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
[id:1,name:xhj, id:2,name:zjf]
注:Arrays.sort使用的是快速排序算法。
Arrays的API:
| 
 方法摘要  | 
||
| 
 static 
  | 
 asList(T... a)   | 
|
| 
 static int  | 
 binarySearch(byte[] a, byte key)   | 
|
| 
 static int  | 
 binarySearch(char[] a, char key)   | 
|
| 
 static int  | 
 binarySearch(double[] a, double key)   | 
|
| 
 static int  | 
 binarySearch(float[] a, float key)   | 
|
| 
 static int  | 
 binarySearch(int[] a, int key)   | 
|
| 
 static int  | 
 binarySearch(long[] a, long key)   | 
|
| 
 static int  | 
 binarySearch(Object[] a, Object key)   | 
|
| 
 static int  | 
 binarySearch(short[] a, short key)   | 
|
| 
 static 
  | 
 binarySearch(T[] a, T key, Comparator<? super T> c)   | 
|
| 
 static boolean  | 
 deepEquals(Object[] a1, Object[] a2)   | 
|
| 
 static int  | 
 deepHashCode(Object[] a)   | 
|
| 
 static String  | 
 deepToString(Object[] a)   | 
|
| 
 static boolean  | 
 equals(boolean[] a, boolean[] a2)   | 
|
| 
 static boolean  | 
 equals(byte[] a, byte[] a2)   | 
|
| 
 static boolean  | 
 equals(char[] a, char[] a2)   | 
|
| 
 static boolean  | 
 equals(double[] a, double[] a2)   | 
|
| 
 static boolean  | 
 equals(float[] a, float[] a2)   | 
|
| 
 static boolean  | 
 equals(int[] a, int[] a2)   | 
|
| 
 static boolean  | 
 equals(long[] a, long[] a2)   | 
|
| 
 static boolean  | 
 equals(Object[] a, Object[] a2)   | 
|
| 
 static boolean  | 
 equals(short[] a, short[] a2)   | 
|
| 
 static void  | 
 fill(boolean[] a, boolean val)   | 
|
| 
 static void  | 
 fill(boolean[] a, int fromIndex, int toIndex, boolean val)   | 
|
| 
 static void  | 
 fill(byte[] a, byte val)   | 
|
| 
 static void  | 
 fill(byte[] a, int fromIndex, int toIndex, byte val)   | 
|
| 
 static void  | 
 fill(char[] a, char val)   | 
|
| 
 static void  | 
 fill(char[] a, int fromIndex, int toIndex, char val)   | 
|
| 
 static void  | 
 fill(double[] a, double val)   | 
|
| 
 static void  | 
 fill(double[] a, int fromIndex, int toIndex, double val)   | 
|
| 
 static void  | 
 fill(float[] a, float val)   | 
|
| 
 static void  | 
 fill(float[] a, int fromIndex, int toIndex, float val)   | 
|
| 
 static void  | 
 fill(int[] a, int val)   | 
|
| 
 static void  | 
 fill(int[] a, int fromIndex, int toIndex, int val)   | 
|
| 
 static void  | 
 fill(long[] a, int fromIndex, int toIndex, long val)   | 
|
| 
 static void  | 
 fill(long[] a, long val)   | 
|
| 
 static void  | 
 fill(Object[] a, int fromIndex, int toIndex, Object val)   | 
|
| 
 static void  | 
 fill(Object[] a, Object val)   | 
|
| 
 static void  | 
 fill(short[] a, int fromIndex, int toIndex, short val)   | 
|
| 
 static void  | 
 fill(short[] a, short val)   | 
|
| 
 static int  | 
 hashCode(boolean[] a)   | 
|
| 
 static int  | 
 hashCode(byte[] a)   | 
|
| 
 static int  | 
 hashCode(char[] a)   | 
|
| 
 static int  | 
 hashCode(double[] a)   | 
|
| 
 static int  | 
 hashCode(float[] a)   | 
|
| 
 static int  | 
 hashCode(int[] a)   | 
|
| 
 static int  | 
 hashCode(long[] a)   | 
|
| 
 static int  | 
||
| 
 static int  | 
 hashCode(short[] a)   | 
|
| 
 static void  | 
 sort(byte[] a)   | 
|
| 
 static void  | 
 sort(byte[] a, int fromIndex, int toIndex)   | 
|
| 
 static void  | 
 sort(char[] a)   | 
|
| 
 static void  | 
 sort(char[] a, int fromIndex, int toIndex)   | 
|
| 
 static void  | 
 sort(double[] a)   | 
|
| 
 static void  | 
 sort(double[] a, int fromIndex, int toIndex)   | 
|
| 
 static void  | 
 sort(float[] a)   | 
|
| 
 static void  | 
 sort(float[] a, int fromIndex, int toIndex)   | 
|
| 
 static void  | 
 sort(int[] a)   | 
|
| 
 static void  | 
 sort(int[] a, int fromIndex, int toIndex)   | 
|
| 
 static void  | 
 sort(long[] a)   | 
|
| 
 static void  | 
 sort(long[] a, int fromIndex, int toIndex)   | 
|
| 
 static void  | 
||
| 
 static void  | 
 sort(Object[] a, int fromIndex, int toIndex)   | 
|
| 
 static void  | 
 sort(short[] a)   | 
|
| 
 static void  | 
 sort(short[] a, int fromIndex, int toIndex)   | 
|
| 
 static 
  | 
 sort(T[] a, Comparator<? super T> c)   | 
|
| 
 static 
  | 
 sort(T[] a, int fromIndex, int toIndex, Comparator<? super T> c)   | 
|
| 
 static String  | 
 toString(boolean[] a)   | 
|
| 
 static String  | 
 toString(byte[] a)   | 
|
| 
 static String  | 
 toString(char[] a)   | 
|
| 
 static String  | 
 toString(double[] a)   | 
|
| 
 static String  | 
 toString(float[] a)   | 
|
| 
 static String  | 
 toString(int[] a)   | 
|
| 
 static String  | 
 toString(long[] a)   | 
|
| 
 static String  | 
||
| 
 static String  | 
 toString(short[] a)   | 
|
Java基本的程序结构设计 数组的更多相关文章
- Java基本的程序结构设计  字符类型
		
char类型 char是2个字节,和short一样. char用单引号来表示. char可以通过数字来表示,也可以通过字母来表示,也可以通过unicode编码单元来表示,特殊字符还可以通过\+字符来表 ...
 - Java基本的程序结构设计  大数操作
		
大数操作 BigInteger 不可变的任意精度的整数.所有操作中,都以二进制补码形式表示 BigInteger(如 Java 的基本整数类型).BigInteger 提供所有 Java 的基本整数操 ...
 - Java基本的程序结构设计  基本类型的输入输出
		
读取输入: java.util.Scanner 一个可以使用正则表达式来分析基本类型和字符串的简单文本扫描器. 了解: Scanner 使用分隔符模式将其输入分解为标记,默认情况下该分隔符模式与空白匹 ...
 - Java基本的程序结构设计  控制流程
		
控制流程 java的控制流程和C和C++基本一致,只是不能使用goto语句,不过break语句可以带标签,实现从内层循环跳出的目的.标签可以放在for或者while前面.如下: package com ...
 - Java基本的程序结构设计  整形和浮点型
		
整形: int 4字节 short 2字节 long 8字节 byte 1字节 int的大小差不多是20亿. 整形计算 如果两个int进行加减乘除数学运算的时候,最终的结果仍然是int,有可能出现了溢 ...
 - 《疯狂Java:突破程序员基本功的16课》读书笔记-第一章 数组与内存控制
		
很早以前就听过李刚老师的疯狂java系列很不错,所以最近找一本拿来拜读,再此做下读书笔记,促进更好的消化. 使用Java数组之前必须先对数组对象进行初始化.当数组的所有元素都被分配了合适的内存空间,并 ...
 - JAVA 基础编程练习题31 【程序 31 数组逆序】
		
31 [程序 31 数组逆序] 题目:将一个数组逆序输出. 程序分析:用第一个与最后一个交换. package cskaoyan; public class cskaoyan31 { @org.jun ...
 - 程序结构设计理论(Android)
		
程序结构设计理论(Android) 作者:邓能财 2019年9月24日 个人简介 姓名:邓能财 年龄:26 毕业学校:东华理工大学 院系:理学院 专业:信息与计算科学 邮箱:2420987186@qq ...
 - 《疯狂Java:突破程序员基本功的16课》读书笔记-第二章 对象与内存控制
		
Java内存管理分为两个方面:内存分配和内存回收.这里的内存分配特指创建Java对象时JVM为该对象在堆内存中所分配的内存空间.内存回收指的是当该Java对象失去引用,变成垃圾时,JVM的垃圾回收机制 ...
 
随机推荐
- ControlTemplate in WPF —— ListBox
			
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" x ...
 - web开发(四) 一次性验证码的代码实现
			
在网上看见一篇不错的文章,写的详细. 以下内容引用那篇博文.转载于<http://www.cnblogs.com/whgk/p/6426072.html>,在此仅供学习参考之用. 其实实现 ...
 - 配置linux系统时区---解决ntp同步完时间不准问题
			
ntp配置完成后时间仍然不准有下面两种情况: ntp服务端配置完ntp服务器后,查看时间和百度的时间不一样按照下面解决 ntp客户端同步完ntp服务器后,查看客户端的时间和百度不一致,按照下面解决 1 ...
 - ELK+Kafka日志收集环境搭建
			
1.搭建Elasticsearch环境并测试: (1)删除es的容器 (2)删除es的镜像 (3)宿主机调内存: 执行命令:sudo sysctl -w vm.max_map_count=655360 ...
 - selenium学习-模拟键盘按键操作
			
导入 from selenium.webdriver.common.keys import Keys 格式:Keys.XXX 一般这么用:send_keys(Keys.XXX) # coding= ...
 - 创建可执行bin安装文件
			
[应用场景] 简化操作,对于有些安装操作而言,需要包含安装脚本和脚本需要的文件两部分,封装成可执行bin文件之后就只有一个安装包了. 代码保护,在很多情况下,我们并不希望用户可以直接接触到代码部分,这 ...
 - mysql8无法用navicat连接(mysql8加密方式的坑)
			
关键词:mysql8无法用navicat连接,navicat无法连接mysql8,mysql8,mysql8的加密方式 [1]mysql8 的坑 密码加密规则 在MySQL 8.0.以上版本中,cac ...
 - numpy使用数组进行数据处理
			
numpy使用数组进行数据处理 meshgrid函数 理解: 二维坐标系中,X轴可以取三个值1,2,3, Y轴可以取三个值7,8, 请问可以获得多少个点的坐标? 显而易见是6个: (1,7)(2,7) ...
 - Qt两个类通过信号槽通信
			
qt需要通过信号槽来通信,connect的时候总是返回false,请教了公司的一个小哥,才解决了问题,虽然是个很白痴的问题. bool b = QObject::connect(m_pCollectO ...
 - 关于c++对拍的办法
			
众所周知,在\(oi\)学习以及考试中,对拍是一件非常重要的事. 有了对拍后,我们可以利用它发现代码上的一些非常难看出来的错误. 编写对拍程序一般有两个办法. 方案一 编写一个对拍的\(cpp\),并 ...