# JAVA之旅(三)——数组,堆栈内存结构,静态初始化,遍历,最值,选择/冒泡排序,二维数组,面向对象思想
* * *
> 我们继续JAVA之旅
## 一.数组
### 1.概念
> 数组就是同一种类型数据的集合,就是一个容器
* 数组的好处:可以自动给数组中的元素从0开始编号,方便操作这些元素
> 数组的格式
~~~
//公共的 类 类名
public class HelloJJAVA {
// 公共的 静态 无返回值 main方法 数组
public static void main(String[] str) {
/**
* 格式:元素类型 [] 数组名 = new 元素类型[元素个数]
* 定义一个可以存储3个整数的容器
*/
int[] x = new int[3];
}
}
~~~
### 2.内存结构
> JAVA程序在运行时,需要在内存中分配空间,为了提高效率,有对空间进行不同区域的划分,因为每一片区域都有特定的处理数据方式和内存内存管理方式
* 堆内存:用于存储局部变量,当数据使用完,所占空间会自动释放
* 栈内存
* 数组和对象,通过new建立的实例都放在堆内存中
* 每一个实体都有内存地址值
* 实体中的变量都有默认的初始值
* 实体不再被使用,会在不确定的时间被垃圾回收器回收
* 方法区
* 本地方法,寄存器
> 数组还有另外一种格式
~~~
int [] arr = new int[]{3,6,8,74,99,12};
int [] arr1 = {3,6,8,74,99,12};
~~~
> 我们把他叫做静态初始化
### 3.遍历
> 数组的操作,我们先看一个最简单的,直接循环
~~~
//公共的 类 类名
public class HelloJJAVA {
// 公共的 静态 无返回值 main方法 数组
public static void main(String[] str) {
/**
* 数组操作
*/
int [] arr = {3,6,8,74,99,12};
for (int i = 0; i < arr.length; i++) {
System.out.println("遍历"+arr[i]);
}
}
}
~~~
> 得到的结果
![这里写图片描述](http://img.blog.csdn.net/20160514115018671)
> 我们再来写个小例子
~~~
//公共的 类 类名
public class HelloJJAVA {
// 公共的 静态 无返回值 main方法 数组
public static void main(String[] str) {
/**
* 数组操作
*/
int[] arr = { 3, 6, 8, 74, 99, 12 };
printArray(arr);
}
/**
* 定义一个方法打印数组中的元素用逗号隔开
*/
public static void printArray(int[] array) {
for (int i = 0; i < array.length; i++) {
System.out.print(array[i] + ",");
}
}
}
~~~
> 我们的运行结果
![这里写图片描述](http://img.blog.csdn.net/20160514125924958)
> 现在我们有一个需求就是不要最后面的逗号,我们该怎么去做?其实就是判断
~~~
//公共的 类 类名
public class HelloJJAVA {
// 公共的 静态 无返回值 main方法 数组
public static void main(String[] str) {
/**
* 数组操作
*/
int[] arr = { 3, 6, 8, 74, 99, 12 };
printArray(arr);
}
/**
* 定义一个方法打印数组中的元素用逗号隔开
*/
public static void printArray(int[] array) {
for (int i = 0; i < array.length; i++) {
// 最后一个
if ((array.length - 1) - i == 0) {
System.out.print(array[i]);
} else {
System.out.print(array[i] + ",");
}
}
}
}
~~~
> 只要我的长度-1 再减去你的循环数是0,说明是最后一个,那就不加逗号,输出的结果
### 4.获取最值
> 获取最值就是最大值,最小值之类的,我们一个个来获取
#### -1.最大/最小值
~~~
//公共的 类 类名
public class HelloJJAVA {
// 公共的 静态 无返回值 main方法 数组
public static void main(String[] str) {
/**
* 获取数组中的最大值和最小值
*/
int[] arr = { 3, 6, 8, 74, 99, 12 };
// 最大值
int max = arr[0];
// 最小值
int min = arr[0];
/**
* 思路,定义一个变量对数组的元素进行比较,大于/小于 就记录
*/
for (int i = 1; i < arr.length; i++) {
if (arr[i] > max) {
max = arr[i];
}
}
System.out.println("最大值:" + max);
for (int i = 0; i < arr.length; i++) {
if (arr[i] < min) {
min = arr[i];
}
}
System.out.println("最小值:" + min);
}
}
~~~
> 输出的结果‘
![这里写图片描述](http://img.blog.csdn.net/20160514132053285)
### 五.排序
> 这个就比较有意思了
#### -1.选择排序
~~~
//公共的 类 类名
public class HelloJJAVA {
// 公共的 静态 无返回值 main方法 数组
public static void main(String[] str) {
/**
* 选择排序
*/
int[] arr = { 3, 6, 8, 74, 99, 12 };
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr.length; j++) {
if (arr[i] > arr[j]) {
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
}
// 打印
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
}
}
~~~
> 拿着每一个元素都比较一遍,然后从大到小排列
![这里写图片描述](http://img.blog.csdn.net/20160514133326739)
> 我们再来一个更好用的
#### -2.冒泡排序
> 这个比较逻辑就更加效率了,相邻的两个元素进行比较,换位置
~~~
//公共的 类 类名
public class HelloJJAVA {
// 公共的 静态 无返回值 main方法 数组
public static void main(String[] str) {
/**
* 冒泡排序
*/
int[] arr = { 3, 6, 8, 74, 99, 12 };
for (int i = 0; i < arr.length - 1; i++) {
// 每一次比较的元素-1,避免角标越界
for (int j = 0; j < arr.length - i - 1; j++) {
if (arr[j] < arr[j + 1]) {
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
// 输出
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
}
}
~~~
> 这样我们也可以输出
![这里写图片描述](http://img.blog.csdn.net/20160514133940310)
## 二.二维数组
> 说完了数组,我们又来了一个二维数组,数组中的数组,其实就是一个装数组类型的数组,这样说就比较清晰了
>
> 格式
* int [] [] arr = new int [3] [2] ;
* int [] [] arr = new int [ ] [2] ;
> 这是个小知识点,我们简单说一下
~~~
//公共的 类 类名
public class HelloJJAVA {
// 公共的 静态 无返回值 main方法 数组
public static void main(String[] str) {
/**
* 二维数组的和
*/
int[][] arr = { { 4, 6, 8 }, { 99, 22, 88 }, { 74, 36, 1 } };
int num = 0;
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr[i].length; j++) {
num = num + arr[i][j];
}
}
System.out.println("num:" + num);
}
}
~~~
> 输出的结果
![这里写图片描述](http://img.blog.csdn.net/20160514170016045)
> 我们来个小练习
>
> (选择题)int [] x,y [] ; //x是一维 y是二维
* a.x[0] = y; //error
* b.y[0]= x; //yes
* c.y[0][0] = x; //error
* d.x[0][0] = y; // error
* e.y[0][0] = x[0]; //yes
* f.x=y //error
## 三.面向对象
> 这篇博文其实到这里本该结束的,为了埋个伏笔,我再加点面向对象的思想,我们先理解一下面向对象的思想
* 面向对象是相对于面向过程而已
* 面向对象和面向过程都是一种思想
* 面向过程
* 强调的是功能行为
* 面向对象
* 讲功能封装进对象,强调具备了功能的对象
* 面向对象是基于面向过程的
> 这么说可能有点笼统,我们举个例子来说明
>
> 还记得那个故事吗,把大象放进冰箱里,这里分几步?
* 第一步:打开冰箱门
* 第二步:把大象放进去
* 第三步:关闭冰箱门
> 这个行为艺术,叫做过程,这个行为过程,我很强调过程,不管是大象还是小象,无所谓,打开,放进去,关上,这就是面向过程
>
> 而面向对象
> 只需要我们封装这个冰箱,那么那就有打开,存储,和关闭的功能,那么我们作用的就是冰箱这个对象了,我们直接面向他
>
> 这样说,是不是有点空洞?我下篇博客会继续深入,生动的把这个思想给描绘出来,尽情期待!
## 有兴趣的可以加群555974449!
版权声明:本文为博主原创文章,博客地址:http://blog.csdn.net/qq_26787115,未经博主允许不得转载。
- 0-发现
- AndroidInterview-Q-A
- Android能让你少走弯路的干货整理
- LearningNotes
- temp
- temp11
- 部分地址
- 0-待办任务
- 待补充列表
- 0-未分类
- AndroidView事件分发与滑动冲突处理
- Spannable
- 事件分发机制详解
- 1-Java
- 1-Java-01基础
- 未归档
- 你应该知道的JDK知识
- 集合框架
- 1-Java-04合集
- Java之旅0
- Java之旅
- JAVA之旅01
- JAVA之旅02
- JAVA之旅03
- JAVA之旅04
- JAVA之旅05
- JAVA之旅06
- JAVA之旅07
- JAVA之旅08
- JAVA之旅09
- java之旅1
- JAVA之旅10
- JAVA之旅11
- JAVA之旅12
- JAVA之旅13
- JAVA之旅14
- JAVA之旅15
- JAVA之旅16
- JAVA之旅17
- JAVA之旅18
- JAVA之旅19
- java之旅2
- JAVA之旅20
- JAVA之旅21
- JAVA之旅22
- JAVA之旅23
- JAVA之旅24
- JAVA之旅25
- JAVA之旅26
- JAVA之旅27
- JAVA之旅28
- JAVA之旅29
- java之旅3
- JAVA之旅30
- JAVA之旅31
- JAVA之旅32
- JAVA之旅33
- JAVA之旅34
- JAVA之旅35
- 1-Java-05辨析
- HashMapArrayMap
- Java8新特性
- Java8接口默认方法
- 图解HashMap(1)
- 图解HashMap(2)
- 2-Android
- 2-Android-1-基础
- View绘制流程
- 事件分发
- AndroidView的事件分发机制和滑动冲突解决
- 自定义View基础
- 1-安卓自定义View基础-坐标系
- 2-安卓自定义View基础-角度弧度
- 3-安卓自定义View基础-颜色
- 自定义View进阶
- 1-安卓自定义View进阶-分类和流程
- 10-安卓自定义View进阶-Matrix详解
- 11-安卓自定义View进阶-MatrixCamera
- 12-安卓自定义View进阶-事件分发机制原理
- 13-安卓自定义View进阶-事件分发机制详解
- 14-安卓自定义View进阶-MotionEvent详解
- 15-安卓自定义View进阶-特殊形状控件事件处理方案
- 16-安卓自定义View进阶-多点触控详解
- 17-安卓自定义View进阶-手势检测GestureDetector
- 2-安卓自定义View进阶-绘制基本图形
- 3-安卓自定义View进阶-画布操作
- 4-安卓自定义View进阶-图片文字
- 5-安卓自定义View进阶-Path基本操作
- 6-安卓自定义View进阶-贝塞尔曲线
- 7-安卓自定义View进阶-Path完结篇伪
- 8-安卓自定义View进阶-Path玩出花样PathMeasure
- 9-安卓自定义View进阶-Matrix原理
- 通用类介绍
- Application
- 2-Android-2-使用
- 2-Android-02控件
- ViewGroup
- ConstraintLayout
- CoordinatorLayout
- 2-Android-03三方使用
- Dagger2
- Dagger2图文完全教程
- Dagger2最清晰的使用教程
- Dagger2让你爱不释手-终结篇
- Dagger2让你爱不释手-重点概念讲解、融合篇
- dagger2让你爱不释手:基础依赖注入框架篇
- 阅读笔记
- Glide
- Google推荐的图片加载库Glide:最新版使用指南(含新特性)
- rxjava
- 这可能是最好的RxJava2.x入门教程完结版
- 这可能是最好的RxJava2.x入门教程(一)
- 这可能是最好的RxJava2.x入门教程(三)
- 这可能是最好的RxJava2.x入门教程(二)
- 这可能是最好的RxJava2.x入门教程(五)
- 这可能是最好的RxJava2.x入门教程(四)
- 2-Android-3-优化
- 优化概况
- 各种优化
- Android端秒开优化
- apk大小优化
- 内存分析
- 混淆
- 2-Android-4-工具
- adb命令
- 一键分析Android的BugReport
- 版本控制
- git
- git章节简述
- 2-Android-5-源码
- HandlerThread 源码分析
- IntentService的使用和源码分析
- 2-Android-9-辨析
- LRU算法
- 什么是Bitmap
- 常见图片压缩方式
- 3-Kotlin
- Kotlin使用笔记1-草稿
- Kotlin使用笔记2
- kotlin特性草稿
- Kotlin草稿-Delegation
- Kotlin草稿-Field
- Kotlin草稿-object
- 4-JavaScript
- 5-Python
- 6-Other
- Git
- Gradle
- Android中ProGuard配置和总结
- gradle使用笔记
- Nexus私服搭建
- 编译提速最佳实践
- 7-设计模式与架构
- 组件化
- 组件化探索(OKR)
- 1-参考列表
- 2-1-组件化概述
- 2-2-gradle配置
- 2-3-代码编写
- 2-4-常见问题
- 2-9-值得一读
- 8-数据结构与算法
- 0临时文件
- 汉诺塔
- 8-数据-1数据结构
- HashMap
- HashMap、Hashtable、HashSet 和 ConcurrentHashMap 的比较
- 迟到一年HashMap解读
- 8-数据-2算法
- 1个就够了
- Java常用排序算法(必须掌握的8大排序算法)
- 常用排序算法总结(性能+代码)
- 必须知道的八大种排序算法(java实现)
- 9-职业
- 阅读
- 书单
- 面试
- 面试-01-java
- Java面试题全集骆昊(上)
- Java面试题全集骆昊(下)
- Java面试题全集骆昊(中)
- 面试-02-android
- 40道Android面试题
- 面试-03-开源源码
- Android图片加载框架最全解析(二),从源码的角度理解Glide的执行流程
- 面试-07-设计模式
- 面试-08-算法
- 面试-09-其他
- SUMMARY
- 版权说明
- temp111