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]);
        }
    }

}

得到的结果

我们再来写个小例子

//公共的   类   类名
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] + ",");
        }
    }

}

我们的运行结果

现在我们有一个需求就是不要最后面的逗号,我们该怎么去做?其实就是判断

//公共的   类   类名
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);
    }
}

输出的结果‘

五.排序

这个就比较有意思了

-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] + " ");
        }
    }
}

拿着每一个元素都比较一遍,然后从大到小排列

我们再来一个更好用的

-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] + " ");
        }

    }
}

这样我们也可以输出

二.二维数组

说完了数组,我们又来了一个二维数组,数组中的数组,其实就是一个装数组类型的数组,这样说就比较清晰了

格式

  • 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);
    }
}

输出的结果

我们来个小练习

(选择题)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!

JAVA之旅(三)——数组,堆栈内存结构,静态初始化,遍历,最值,选择/冒泡排序,二维数组,面向对象思想的更多相关文章

  1. [java学习笔记]java语言基础概述之数组的定义&常见操作(遍历、排序、查找)&二维数组

    1.数组基础 1.什么是数组:           同一类型数据的集合,就是一个容器. 2.数组的好处:           可以自动为数组中的元素从零开始编号,方便操作这些数据. 3.格式:  (一 ...

  2. php将一个二维数组按照某个字段值合并成一维数组,如果有重复则将重复的合并成二维数组

    版权声明:本文为博主原创文章,未经博主允许不得转载. 最近工作中碰到一个问题,用PHP将一个二维数组按照二维数组中的各个项中的某个特定字段值合并成一维数组,如果有重复则将重复的合并成二维数组,生成的二 ...

  3. 存在一个足够大的二维数组,每个数组中的值都是整数,使用javascript如何实现按每个数组中的平均值,从大到小排序这个二维数组?

    这是牛客网上的一道题~ 题意:对数组排序,顺序是按照数组的平均值,即按照一个元素和平均值相减的绝对值的大小来排序...本例按这个绝对值递增排序 解题思想:先求出这个数组的平均值,如果 a<b,那 ...

  4. yii2中判断值是否存在二维数组中

    //在yii2中,在类里面的函数,可以不加action $arr = array( array('a', 'b'), array('c', 'd') ); in_array('a', $arr); / ...

  5. C语言笔记(二维数组与数值指针)

    一.关于二维数组和二维数组区别 (1)一维数组在内存中是连续分布存储的,同样,二维数组也是在内存连续存储的.所以从内存的角度来分析,一维数组和二维数组其实没有本质区别. (2) 二维数组可以使用一维数 ...

  6. C++二维数组讲解、二维数组的声明和初始化

    我们知道,一维空间是一条线,数学中用一条数轴来表达:二维空间是一个平面,数学中用平面坐标系来表达.那么二维数组又是什么样的呢? 线与面 我们用一个下标来描述一维数组中的某个元素,就好像在用数描述一条线 ...

  7. OpenCV中Mat与二维数组之间的转换

    ---恢复内容开始--- 在OpenCV中将Mat(二维)与二维数组相对应,即将Mat中的每个像素值赋给一个二维数组. 全部代码如下: #include <iostream> #inclu ...

  8. 《java入门第一季》二维数组三个案例详解

    案例一:遍历二维数组 /* 需求:二维数组遍历 外循环控制的是二维数组的长度,其实就是一维数组的个数行数. 内循环控制的是一维数组的长度,每一行,一维数组元素分别的个数. */ class Array ...

  9. 06-01 Java 二维数组格式、二维数组内存图解、二维数组操作

    二维数组格式1 /* 二维数组:就是元素为一维数组的一个数组. 格式1: 数据类型[][] 数组名 = new 数据类型[m][n]; m:表示这个二维数组有多少个一维数组. n:表示每一个一维数组的 ...

  10. Java 数组(三)二维数组

    如果一维数组的各个元素仍然是一个数组,那么它就是一个二维数组.二维数组常用于表示表,表中的信息以行和列的形式组织,第一个下标代表元素所在的行,第二个下标代表所在的列. 一.二维数组的创建 1.先声明, ...

随机推荐

  1. let 和 const 命令

    let 命令 基本用法 ES6 新增了let命令,用来声明变量.它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效. { let a = 10; var b = 1; } a / ...

  2. Android Studio: You need to use a Theme.AppCompat theme (or descendant) with this activity.

    错误描述为: java.lang.IllegalStateException: You need to use a Theme.AppCompat theme (or descendant) with ...

  3. Bootstrap3 表单-基本表单

    单独的表单控件会被自动赋予一些全局样式.所有设置了 .form-control 类的 <input>.<textarea> 和 <select> 元素都将被默认设置 ...

  4. 一个未排序整数数组,有正负数,重新排列使负数排在正数前面,并且要求不改变原来的正负数之间相对顺序,比如: input: 1,7,-5,9,-12,15 ans: -5,-12,1,7,9,15 要求时

    #include <iostream> using namespace std; void txsort(int* arr, int len) { if (!arr || len == 1 ...

  5. FFmpeg的HEVC解码器源代码简单分析:CTU解码(CTU Decode)部分-TU

    ===================================================== HEVC源代码分析文章列表: [解码 -libavcodec HEVC 解码器] FFmpe ...

  6. Cocos2D中节点Z序的计算规则

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 免责申明:本博客提供的所有翻译文章原稿均来自互联网,仅供学习交 ...

  7. [supervisor] 使用小记(入门教程)

    之前到现在很久没有用了,还是从安装说下,做个简单的实验,系统为Ubuntu14.04 快速安装配置 sudo pip_python install supervisor sudo echo_super ...

  8. JDBC-数据库的编程(一)

    因为我使用的mysql数据库客户端程序是workBench,所以会用workBench来进行讲解. create table tbl_user( id int(11) unsigned not nul ...

  9. C语言函数--atoi

          在Java语言中,由于面向对象的思想,它对基本数据类型也进行了相应的封装,例如 int 就封装成了 Integer 类,这无疑会使我们的操作方便了许多,例如,有一个字符串,我想把它转换为i ...

  10. 免安装版本tomcat 指定的服务并未以已安装的服务存在,Unable to open the service

    今天在自己的电脑上安装了Tomcat6.0.14,是在Tomcat主页上直接下载的免安装版.但是把文件解压的之后,双击Tomcat6w.exe时,去出现了"指定的服务并未以已安装的服务存在, ...