Java数组的一些使用方法及堆栈存储
数组
用于存储一组同一数据类型数据的容器
数组会对放入其中的数据自动编号,编号是从0开始的---下标
定义格式
数据类型[] 数组名 = new 数据类型[数组的大小];---可以先声明再初始化
int[] arr = new int[5];---定义了一个最多能存储5的整数的数组
arr[3] = 4;
arr[3]---通过数组名[下标]的形式来获取数组元素或者给对应的位置赋值
数据类型[] 数组名 = new 数据类型[]{元素1,元素2……};
int[] arr = new int[]{2,5,1,6,8};---在定义好数组中的初始元素的同时定义好了数组的大小,不能在改变大小
数据类型[] 数组名 = {元素1,元素2……};---不可以先声明再初始化
int[] arr = {2,5,3,6,1,8,9};
内存
栈内存、堆内存、方法区、本地方法栈(和其他语言交互)、寄存器(汇编)
栈内存
可以用于存储变量,栈内存对存入其中的变量不会自动赋值,变量在使用完成之后会立即移出栈内存释放空间
堆内存
用于存储对象的,堆内存对于存入其中的元素会自动的赋予初始值---byte/short/int-0,long-0L;float-0.0f,double-0.0,char- ‘\u0000’,boolean-false,引用数据类型的默认值都是null,对象使用完成之后不会立即移出堆内存,而是在不定的某个时刻被回收
数组的应用
1. 获取数组元素---数组名[下标]
2. 获取数组的长度---数组名.length
3. 遍历数组---通过获取对应下标来获取对应位置上的元素----O(n)
for(int i : arr){----增强for循环。把数组中的每个元素作为单独的变量来使用
System.out.println(i);
}
4. 数组元素排序
Arrays.sort(arr);---会自动对数组排序,默认是升序排列
5. 获取数组元素的最值---遍历
6. 获取元素的位置---遍历
如果元素有序,可以使用折半查找---O(log2n)
7. 数组的反转
8. 数组的扩容--数组的复制
int[] arr = {1,2,4,6,1};
int[] arr2 = new int[8];
System.arraycopy(源数组,源数组中的起始下标,目标数组,存放的起始下标,复制的元素的个数);
源数组 = Arrays.copyOf(源数组,扩容之后的长度);
arr = Arrays.copyOf(arr,2);
int[] arr2 = new int[2];
if(扩容之后的长度 < arr.length){
System.arraycopy(arr,0,arr2,0,扩容之后的长度)
} else {
System.arraycopy(arr,0,arr2,0,arr.length)
}
arr = arr2;
注意:
如果下标超过范围,编译无错,运行时会出现ArrayIndexOutOfBoundsException---下标越界异常
Java数组的一些使用方法及堆栈存储的更多相关文章
- Java数组的十大方法
Java数组的十大方法 以下是Java Array的前10种方法.他们是来自stackoverflow的投票最多的问题. 0.声明一个数组 String[] aArray = new String[5 ...
- Java数组操作十大方法 (转)
定义一个Java数组 String[] aArray = new String[5]; String[] bArray = {"a","b","c&q ...
- (PASS)JAVA数组去重 三种方法 (不用集合)
第一种方法(只学到数组的看): 定义一个新的数组长度和旧数组的长度一样,存储除去重复数据的旧数组的数据和0, package demo01; import java.sql.Array; import ...
- Java数组去掉反复的方法集
经经常使用到,有时候不仅仅是简单的基本类型,那种能够用set集合去重,好多时间用到的是我们自己定义的类型,以下举个样例(我这儿就那int举例了): 方法一. 这样的类似与选择排序算法,首先我们取i值, ...
- java数组实现红包的方法
package Hongbao; import java.text.DecimalFormat; import java.util.Scanner; public class Hongbao { pu ...
- Java 数组复制之clone方法
一.源码 public class Test1 { public static void main(String[] args) { // Student[] arrs = new Student[] ...
- java数组复制的简单方法(一)
总结:主要是用a数组的长度等于b数组,然后a数组赋值给b数组,我不能想到这个办法,我还是不理解数组中length属性的含义 这里数组并没有正真复制过来,而是一个引用 package com.a; // ...
- Java 数组的 12 个方法
1. 声明一个数组 String[] aArray = new String[5]; String[] bArray = {"a","b","c&q ...
- Java数组的12个常用方法
以下是12个关于Java数组最常用的方法,它们是stackoverflow得票最高的问题. 声明一个数组 String[] aArray = new String[5]; String[] bArra ...
随机推荐
- Python中文
在python中有两种默认的字符串:str和unicode.在Python中一定要注意区分"Unicode字符串"和"Unicode对象"的区别. 后面所有的& ...
- 阿里Dubbo疯狂更新,关Spring Cloud什么事?
最近,开源社区发生了一件大事,那个全国 Java 开发者使用最广的开源服务框架 Dubbo 低调重启维护,并且 3 个月连续发布了 4 个维护版本. 我上次在写放弃Dubbo,选择最流行的Spring ...
- SSH框架基础
首先,SSH不是一个框架,而是多个框架(struts+spring+hibernate)的集成,是目前较流行的一种Web应用程序开源集成框架,用于构建灵活.易于扩展的多层Web应用程序. 集成SSH框 ...
- JVM菜鸟进阶高手之路十四:分析篇
转载请注明原创出处,谢谢! 题目回顾 JVM菜鸟进阶高手之路十三,问题现象就是相同的代码,jvm参数不一样,表现的现象不一样. private static final int _1MB = 1024 ...
- propertychange 不起作用
兼容性问题.将$("#systemLogSettings td[name='nMaxFileSize'] input").on("input propertychange ...
- SSL/TLS 握手过程详解
在现代社会,互联网已经渗透到人们日常生活的方方面面,娱乐.经济.社会关系等都离不开互联网的帮助.在这个背景下,互联网安全就显得十分重要,没有提供足够的安全保障,人们是不会如此依赖它的.幸运的是,在大牛 ...
- 为什么选择Django?
Web开发是Python语言应用领域的重要部分,也是工作岗位比较多的领域.如果你对基于Python的Web开发有兴趣,正打算开始学习使用Python做Web开发,或者已经是一个Web开发者有工作需要, ...
- 03.redis与ssm整合(mybatis二级缓存)
SSM+redis整合 ssm框架之前已经搭建过了,这里不再做代码复制工作. 这里主要是利用redis去做mybatis的二级缓存,mybaits映射文件中所有的select都会刷新已有缓存,如果不存 ...
- 第四届河南省ACM 表达式求值 栈
表达式求值 时间限制: 1 Sec 内存限制: 128 MB 提交: 14 解决: 7 [提交][状态][讨论版] 题目描述 Dr.Kong设计的机器人卡多掌握了加减法运算以后,最近又学会了一些简 ...
- 算法训练 最大的算式 DP
算法训练 最大的算式 时间限制:1.0s 内存限制:256.0MB 问题描述 题目很简单,给出N个数字,不改变它们的相对位置,在中间加入K个乘号和N-K-1个加号,(括号随便加)使最终结果 ...