java基础---------数组与可变个数形参

一、重点知识

double float小数在计算机中计算取得的都是近似值,所以存在精度问题

增强for循环
专门用于获取数组和集合中的元素
只能取值,不能赋值,因为他语法层面上操作不到下标
代码示例
public class For_eachTest {
public static void main(String[] args) {
    String [] name = new String []{"name","cao","cao","yu"};
    //for -each循环(增强循环)
    for(String e : name){
            System.out.println(e);
            }
        }
        }

for循环使用中找不出来规律就二倍看看有没有规律

最后一次警告char = ‘16’ 是错误的,一次只能写一个字符,16算两个字符了

存在堆里面的数据都是有默认值的

记得数组得动态初始化也是可以先定义再赋值的

局部变量必须先赋值再使用,即便是引用数据类型得局部变量也是如此

参数列表里面把数组作为形参,格式 int [] arr 。
int [] 起到的是声明arr的类型的作用int []作为一个整体  表示数组数据类型

程序一进来先找主函数,执行主函数里面的内容,主函数里面声明的变量会在主函数结束后才被释放内存空空间。也就是 ===主函数结束后里面的局部变量才会被销毁

堆里面的结构不是及时销毁的,得靠自动垃圾回收机制得判断

二、重点问题

可变形参的使用 -----把它当作一个数组来使用

代码示例
public void sum(int ... num){
  int sum = 0;
     for(int i =0 ;i < num.length;i++){
        sum += num[i];
    }
}

//把它当作一个数组来使用,他也可以使用下标

注意:可变参数一定要写在最后 

Boolean n2 = new Boolean("true");为什么可以这样写

在构造类得转换基本数据类型时时如果调用方法形参为String型,则赋值使用字符串格式,他自动会把数据从双引号当中抽取出来

三、课堂知识

3.1、数组遍历得两种写法

使用for循环
遍历:依次访问,从第一个元素,访问到最后一个元素。

1、使用循环来遍历数组

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

arr[i] = i;//赋值

System.out.println(arr[i]);//获取数值

}

for-each循环

for-each循环:【扩展】
增强for循环:JDK1.5的版本出现的。
特定的用法:专门用于获取数组中的每一个元素的值。
语法结构:
for(数据类型 变量名 : 数组名){
    System.out.println(变量名);
}

工作原理:
for(int e :arr){
    System.out.println(e);
}

int e,定义变量e,
依次获取数组的元素,赋值给e
注意点:
    A:for-each只能获取数组的数据,但是不能给数组进行赋值

    B:for-each,在代码这个层面,不能操作下标。

3.2、数组中的默认值

数组的默认值,就是数组创建后,里面存储的默认的数据。

数组的引用存在栈内存中,数组本身存在堆内存中。

数组创建完,就有默认的数据了。

数组中存储的默认值:

数组中是有默认值的

整数:0     小数:0.0     字符:\u0000    布尔:false    其他:null

3.3、创建数组的其他语法

动态创建数组:先创建数组,然后再根据下标一个一个存储数据。
A:先声明,再创建(分配内存空间)
数据类型 [] 数组名;
数组名 = new 数据类型[长度];

B:声明并创建
数据类型 [] 数组名 = new 数据类型[长度];
数据类型  数组名[] = new 数据类型[长度];

//静态创建数组:声明,创建,赋值一起写完。
C:声明,创建,并赋值
数据类型[] 数组名 = {数值1,数值2,数值3,数值4.。。。};
//=左边声明数组,=右边,会先根据{}中数据的个数,然后再将{}中数据,按照顺序存储进去。

完成了几件事:

1.先声明:int[] c

2.根据{}中数组值的个数,开辟堆内存

3.将{}中的数组值,依次按照顺序存入数组中

D:声明,创建,并赋值

数据类型[] 数组名 = new 数据类型[]{数值1,数值2,数值3,数值4.。。。}

3.4、数组的地址传递

Java中的数据分为两大类:

基本类型:4类8种

操作的都是数值本身

引用类型:数组

操作的是地址

基本类型进行赋值:数值

引用类型进行赋值:地址

3.5、数组作为参数

数组是引用类型:传递的是地址。就是参数也会指向这块内存。当方法结束的时候,参数就销毁了
class Test5ArrayMethod
{
//设计一个方法,用于打印数组
public static void printArray(int[] arr){
//int[] arr = a;a的地址给了arr,那么arr和a指向同一块内存的数组
for(int e : arr){
System.out.print(e +"\t");
}
System.out.println();
}
public static void main(String[] args)
{
int[] a = {1,2,3,4,5};
//设计一个方法,用于打印数组
printArray(a);//将a的地址,传递给arr

}
}

3.6 可变参数

概念:一个方法可以接收的参数的数量不定(0-多个),但是类型固定。

语法:数据类型 ... 参数名,可变参数在方法中当数组使用。

注意事项:

1、如果参数列表中,除了可变参数还有其他的参数,可变参数要写在整个参数列表的最后。

    2、一个方法最多只能有一个可变参数。

class Test6Array
{
//求一组int类型的数据的和
public static void getSum(int ... nums ){
int sum = 0;
for(int i = 0;i sum += nums[i];
}
System.out.println("结果:" + sum);
}
public static void main(String[] args)
{
/*
可变参数:同一种类型的参数,类型固定的,但是个数不固定。
语法的支持:
数据类型 ... 参数名
可变参数,类型固定,个数可变。0-多个
在方法中可变参数当数组使用
*/
getSum(1,2,3);
getSum(1,2,3,4,5,6,7,8,9,10);

}

}

3.7 数组的排序

排序:数组是存储一组数据,而且这些数据是有顺序的。但是数值本身可能是无序的。通过算法来实现给数组进行排序,升序(数值从小到大),降序(数值从大到小)。

1冒泡排序
1、冒泡排序:Bubble Sort

原理:比较相邻的两个数,将较大的数,向后移动。
class Test7BubbleSort
{
public static void main(String[] args)
{
int[] arr = {15,23,8,10,7};
for(int i= 1; ifor(int j = 0;j < arr.length - i;j++){
if(arr[j] > arr[j+1]){
//交换
int temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
for(int i = 0;iSystem.out.println(arr[i]);
}
}
}

你可能感兴趣的:(java基础---------数组与可变个数形参)