1、函数(掌握)

1、概念(掌握)

定义在类中,有特定功能的一小段程序

2、格式(掌握)

修饰符 返回类型 函数名(参数类型 形式参数,...){

函数体;

return 返回值;

}

解释:

A 修饰符: public static

B 返回值类型 :就是数据类型

C 函数名:见名知意,如果一个单词,首字母小写,如果多个单词组成,从第二个单词开始首字母大写

D 参数类型 :数据类型

E 形式参数 :接受实际参数的变量

F 实际参数 :就是实际参与运算的变量

G 函数体:实现功能的代码

H 返回值 程序的结果,如果没有明确返回值可以不写

I return 返回值 ,那里调用程序,return就把结果返回到哪里 比如 int num = max(1,2);return把结果返回给num

3、特点(掌握!!)

A 函数和函数是平级关系,且只能定义在类中,不能在函数中嵌套函数

B 函数只有被调用才会执行

4、注意(掌握)

无论函数的返回值是具体的数据类型还是void,任何函数都是以return语句结束的

5、函数的调用(理解)

            A 有明确返回值函数的调用

单独调用//没有意义

输出调用//视频中老师用的最多的

赋值调用//开发中用的最多的

            B  没有明确返回值函数的调用

单独调用

6、函数的重载-overload(掌握)                   

        概念                 

在同一个类中,函数名相同,参数列表不同(参数类型和个数),与返回值类型无关

        举例                              

  1. classDemo{

  2.      publicstaticvoid print(int x,int y){}

  3.      publicstaticvoid print(int a,int b,int c){}

  4.      publicstaticvoid print(double a){}

  5.      publicstaticvoid print(int a){}

  6. }

7、案例(掌握)

1、有明确返回值的案例

A求两个数据和

B 求两个数据的最大值

C 比较两个数是否相等

2、没有明确返回值的案例

A 打印矩形案例

B 打印99乘法表

2、数组(掌握)

1、概念(掌握)

数组是存储多个同一类型数据元素的容器(container)

2、好处(理解)

数组中的元素会被自动从0开始编号,方便我们获取

3、格式(掌握)

A int[] arr =new int[2];            //念法:int类型的数组arr

B int arr[] = new int[2];              //念法:int 类型的arr数组,不推荐这么写,他和第一种格式其实一样的

C int[] arr = new int[]{1,2,3,7};  //大括号内可以没有任何东西

D int[] arr = {3,4,65,4};            //大括号内可以没有任何东西

推荐使用A D ,C存在的意义:作为实际参数传递

获取数组的长度:变量名.length;     

     4、内存图(理解)

堆:所有new出来的东西都在堆里

1、每一个实体都有地址值
                  2、每一个实体内的内容都有默认值

整数:         0

浮点数:      0.0

字符:         ’\u0000’  //char c = ‘\u0000’;

布尔:         false

5、数组操作(掌握)                  

            1、数组遍历

  1. int[] arr ={1,3,5,6,3,5,2};

  2. for(int i=0; i<arr.length; i++){

  3.      int element = arr[i];     \\element:元素

  4.      System.out.println(element);

  5. }

            2、获取数组最值

  1. /*
  2. 方式一:临时变量为元素值
  3. 思路:
  4. 1,获取最值需要进行比较。每一次比较都会有一个较大的值。因为该值不确定。
  5. 通过一个变量进行临储。
  6. 2,让数组中的每一个元素都和这个变量中的值进行比较。
  7. 如果大于了变量中的值,就用该该变量记录较大值。
  8. 3,当所有的元素都比较完成,那么该变量中存储的就是数组中的最大值了。
  9. */
  10. publicstaticint getMax(int[] arr)
  11. {
  12. int max = arr[0];
  13. for(int x=1; x<arr.length; x++)
  14. {
  15. if(arr[x]>max)
  16. max = arr[x];
  17. }
  18. return max;
  19. }
  20. /*
  21. 方式二:临时变量为角标
  22. 初始化为数组中任意一个角标。
  23. */
  24. publicstaticint getMax_2(int[] arr)
  25. {
  26. int max =0;
  27. for(int x=1; x<arr.length; x++)
  28. {
  29. if(arr[x]>arr[max])
  30. max = x;
  31. }
  32. return arr[max];
  33. }
 

            3、数组查找:给定一个值,查找该值在数组中对应的索引

  1. int[] arr ={1,3,5,6};
  2. //查找5所定义应的角标
  3. int index = getIndex(arr,5);
  4. /**
  5. 查找元素所对应的角标
  6. */
  7. publicstaticint getIndex(int[] arrays,int element){
  8.   for(int i=0; i<arrays.length; i++){
  9.     if(arrays[i]== element){
  10.       return i;
  11.    }
  12.  }
  13. }
 
        4、数组间元素的拷贝:将A数组中的元素拷贝到B数组中
  1. import java.util.Arrays;
  2. publicclassArrayUtil{
  3. publicstaticvoid main(String[] args){
  4. int[] arr1 ={1,3,5};
  5. int[] arr2 ={1,6,3};
  6. copy(arr2, arr1);
  7. System.out.println(Arrays.toString(arr1));
  8. System.out.println(Arrays.toString(arr2));
  9. }
  10. /**
  11. * 将arr1数组中的元素拷贝到arr2中,前提:两个数组的长度必须一致
  12. * 需要的知识点:数组的遍历,数组中元素的获取,数组中元素的修改
  13. * @param arr1
  14. * @param arr2
  15. */
  16. publicstaticvoid copy(int[] arr1,int[] arr2){
  17. int length = arr1.length>arr2.length?arr2.length:arr1.length;
  18. for(int i=0; i<length; i++){
  19. arr2[i]= arr1[i];
  20. }
  21. }
  22. }
 
 

6、常见问题(掌握)

A 数组越界异常:

ArrayIndexOutOfBoundsException

你访问了不存在的索引。

                B 空指针异常:

NullPointerException

一个实例(对象)已经不存在了,你还去访问它的内容

7、二维数组(理解)

A 格式

第一种定义通过定义长度的方式定义了二维数组的长度,并且定义了一维数组的长度 int[][] arr = new int[6][3]

第二种定义通过长度仅定义了二维数组的长度,没有初始化一维数组int[] [] arr= new int[2][]

第三种定义通过直接给出元素定义了二维数组的长度和每一个一维数组的长度 int[][] arr = {{2,23},{33}}

B 案例

抽烟案例

  1. /**
  2. 一条烟中10包烟
  3. 每包烟有20支烟
  4. 那么就把一条烟看成一个二维数组,里面的包是一维数组
  5. */
  6. classSmokeDemo
  7. {
  8.     publicstaticvoid main(String[] args)
  9.     {
  10.          int[][] tiaoyan =newint[10][20];
  11.        
  12.          tiaoyan[9]=newint[2];
  13.        
  14.          for(int i=0; i<tiaoyan.length; i++)
  15.          {
  16.               int[] baoyan = tiaoyan[i];
  17.               for(int j=0; j<baoyan.length; j++)
  18.               {
  19.                    System.out.println("正在抽第"+(i+1)+"盒烟中的第"+(j+1)+"根烟");
  20.               }
  21.          }
  22.     }
  23. }
 
 

3、今天必须掌握的内容。以及常见的笔试题和面试题(学完这个就可以放心学习后面的知识了)

 
对于基本类型数组来说里面的每一个元素存的是数值,对于引用类型数组来说里面的每一个元素存的是地址值
1、谈谈什么是方法以及方法的声明格式
2、谈谈方法的调用以及注意事项(注意事项就是方法的特点)
      分为有返回值方法和无返回值方法的调用,详情见上面
3、谈谈什么是数组以及一维数组的声明格式
        详情见上面
4、如何操作数组中的元素
        数组名[索引]来操作数组中的元
5、如何获取数组中的最值
        详情见上面
6、数组中常见的两个异常以及异常产生的原因
7、说说方法的重载
 
8、练习的代码:数组的遍历,获取数组中的最值,查询某个数据在数组中的索引,数组中元素的拷贝。
9、定义一个reverse(int[] arr)方法,将数组中的元素反转,比如{1,2,3}反转后就是{3,2,1}
10、求两个数的和
11、求两个数中的最大值
13、定义两个equals方法,一个用于比较两个int是否相同,另一个用于比较两个double是否相同
14、定义方法,在可控制太打印矩形
15、什么时候定义有返回值类型的方法,什么时候定义无返回值类型的方法
        刚开始,需求会写明,需求明确说要有返回值那就定义返回值,需求明确说不需要,就不需要定义返回值。后期随着知识的增加我们会详细的去分析,但是目前掌握到这种程度就好
 

Day05_JAVA语言基础第五天的更多相关文章

  1. Java语言基础(五)

    Java语言基础(五) 一.浮点数 浮点数就是小数,其标准是IEEE 754,用指数和尾数表示 例如30000=3*10000=3*10^4  其中4是指数,3是尾数 Java中,浮点数有float ...

  2. [Java入门笔记] Java语言基础(五):数组

    简介 数组可用用于存储存储多个数据,Java的数组要求所有的数组元素具有一种相同的数据类型.一旦数组初始化完成,数组在内存中的空间被固定下来,长度不可改变,即使把数组的元素清空,所占用的空间依然被保留 ...

  3. C语言基础第五次作业

    题目7-2 统计一行文本的单词个数 1.实验代码 #include <stdio.h> int main() { char a; ,countword=; ){ scanf("% ...

  4. Go语言核心36讲(Go语言基础知识五)--学习笔记

    05 | 程序实体的那些事儿(中) 在前文中,我解释过代码块的含义.Go 语言的代码块是一层套一层的,就像大圆套小圆. 一个代码块可以有若干个子代码块:但对于每个代码块,最多只会有一个直接包含它的代码 ...

  5. Java语言基础(五) Java原始数据类型的分类以及数据范围

    Java原始数据类型的分类以及数据范围 1.基本数据类型分为:整型(byte, short, int, long),浮点型(float, double),字符型(char),布尔型(boolean) ...

  6. C语言基础-第五章

    流程控制 1.顺序结构 顺序结构是指程序将按照书写的顺序一步步执行程序. 2.选择结构 2.1但分支结构语句 if(表达式){语句} 2.2双分支结构 if(表达式){}else if{} else{ ...

  7. C语言基础知识(五)——数组与指针的等价表示

    void f(void) { int * p; int a[3] = {1,2,3}; p = a; printf("%d %d", a[0], p[0], *(a+1), *(p ...

  8. java语言基础(五)_Scanner类_Random类_ArrayList类

    API API(Application Programming Interface),应用程序编程接口.Java API是一本程序员的字典 ,是JDK中提供给程序员使用的类的说明文档.这些类将底层的代 ...

  9. 第二十五节:Java语言基础-面向对象基础

    面向对象 面向过程的代表主要是C语言,面向对象是相对面向过程而言,Java是面向对象的编程语言,面向过程是通过函数体现,面向过程主要是功能行为. 而对于面向对象而言,将功能封装到对象,所以面向对象是基 ...

随机推荐

  1. 使用ServerSocket创建TCP服务器端

    在两个通信实体没有建立虚拟链路之前,必须有一个通信实体先做出“主动姿态”,主动接受来自其他通信实体的连接请求. Java中能接受其它通信实体连接请求的类是ServerSocket,ServerSock ...

  2. HBase High Level Architecutre

  3. eclipse debug时老提示edit source lookup path解决方案

    用myeclipse debug web应用的时候,总提示edit source lookup path,每次都得手动选择项目,费时费力.在网上终于找到了方法. 搬运:http://www.educi ...

  4. HDU 4906 Our happy ending(2014 Multi-University Training Contest 4)

    题意:构造出n个数 这n个数取值范围0-L,这n个数中存在取一些数之和等于k,则这样称为一种方法.给定n,k,L,求方案数. 思路:装压 每位 第1为表示这种方案能不能构成1(1表示能0表示不能)   ...

  5. ASP.NET MVC学习之路由篇(1)

    1.基本路由 RouteConfig.cs: 1 public class RouteConfig 2 { 3 public static void RegisterRoutes(RouteColle ...

  6. Javascript——Math对象

    Math 对象是一个固有的对象,无需创建它,直接把 Math 作为对象使用就可以调用其所有属性和方法.这是它与Date,String对象的区别  Math 对象属性 Math 对象方法  

  7. WP8.1 Study2:MapControl控件的应用

    总的界面布局如下:

  8. SGU 140 扩展欧几里得

    题目大意: 给定序列a[] , p , b 希望找到一个序列 x[] , 使a1*x1 + a2*x2 + ... + an*xn = b (mod p) 这里很容易写成 a1*x1 + a2*x2 ...

  9. 蓝桥杯 algo_5 最短路 (bellman,SPFA)

    问题描述 给定一个n个顶点,m条边的有向图(其中某些边权可能为负,但保证没有负环).请你计算从1号点到其他点的最短路(顶点从1到n编号). 输入格式 第一行两个整数n, m. 接下来的m行,每行有三个 ...

  10. 弹框工作区(dialog)

    弹出窗口分为普通弹出窗口和模态弹出窗口,普通弹出窗口可以铜鼓taskBar组件进行最小化等操作.弹出的窗口的DOM结构会放入主页面的body中,结构如下: <div class="bj ...