数组

相同类型的,用一个标识符名称封装到一起的一个对象序列或者基本数据类型序列叫数组.(多么严谨的概念)

数组的声明

int[] a1int a1[]都可以表示一个数组. 前者是java风格的,后者是C/C++风格的.但是java数组不允许指定数组的大小. 因为对于java来说,这个标识符就是一个引用. java觉得这玩意儿就是一个引用,指定一个引用的大小是件很傻的事情.
对于数组,初始化动作可以出现在任何地方.

数组的初始化和赋值

初始化的时候可以使用{}来进行. 使用这个就相当与一个new. 这时候才是给这个数组分配空间. 这个时候会把分配空间和赋值一起完成了. 当然也可以使用new关键字.

public class ArrayInit {
static int[] a1 = {1,2,3,4,5};
static int[] a2 = new int[6]; public static void main(String[] args) {
for(int eachItem1:a1){
System.out.print(eachItem1+" ");
}
System.out.println();
for(int eachItem2:a2){
System.out.print(eachItem2+" ");
}
}
}

对于非基本数据类型,想想数组的定义,貌似也是可以搞成一个数组的,只要它是同一种数据类型.

    public void test2(){
Dog[] dogs1 = {new Dog("Husky"),new Dog("Samoyed"),new Dog("Alaskan Malamute")};
Dog[] dogs2 = new Dog[3];
dogs2[0]=new Dog("Husky");
dogs2[1]=new Dog("Samoyed");
dogs2[2]=new Dog("Alaskan Malamute"); System.out.println(Arrays.toString(dogs1));
System.out.println(Arrays.toString(dogs2));
}

可变参数列表

java中所有的类有个老祖宗叫Object. 不管你是一个Dog还是一个Person,都是一个Object.那么如果,把一个object数组作为形参,那么这个函数是不是就可以变成一个可变参数列表的函数了呢?

    public static void test3(Object[] obj){
for(Object eachObj:obj){
System.out.println(eachObj);
}
}
@Test
public void test4(){
ArrayInit.test3(new Object[] {new Integer(1),new Integer(2),new Integer(3)});
}

既然可以这么搞,那java干脆整个关键字吧,于是一个很形象的关键字诞生了...
于是上面这段代码就可以写成

    public static void test3(Object...obj){
for(Object eachObj:obj){
System.out.println(eachObj);
}
}
@Test
public void test4(){
ArrayInit.test3(new Object[] {new Integer(1),new Integer(2),new Integer(3)});
}

当然除了Object还可以是其他类型. 但是,可变参数列表一定要放在形参列表的最后,且只能有一个. 如果多了的话很有可能会产生歧义. 所以干脆别整那么多.

TIJ读书笔记08-数组的初始化和可变长参数形参的更多相关文章

  1. Noah的学习笔记之Python篇:函数“可变长参数”

    Noah的学习笔记之Python篇: 1.装饰器 2.函数“可变长参数” 3.命令行解析 注:本文全原创,作者:Noah Zhang  (http://www.cnblogs.com/noahzn/) ...

  2. TIJ读书笔记02-控制执行流程

      TIJ读书笔记02-控制执行流程 TIJ读书笔记02-控制执行流程 if-else 迭代 无条件分支 switch语句 所有条件语句都是以条件表达式的真假来决定执行路径,也就是通过布尔测试结果来决 ...

  3. TIJ读书笔记03-初始化和构造器

      TIJ读书笔记03-初始化和构造器 初始化和清理是涉及安全的两个问题,如果对象不能正确的初始化会引起很多错误,比如空指针异常等,如果不能恰当及时的清理,会占用过多资源. 构造器在创建一个类的实例的 ...

  4. TIJ读书笔记06-终结清理和垃圾回收

    TIJ读书笔记06-终结清理和垃圾回收 finalize()方法 垃圾回收器如何工作 java的垃圾回收是由jvm来控制的.所以需要java程序员参与的部分不是很多. 但是在这里需要明白一点,java ...

  5. TIJ读书笔记05-this关键字

    TIJ读书笔记05-this关键字 概述 this的用法 static方法 概述 两个对象同时调用一个方法,那么jvm怎么知道是哪个方法调用的呢. 我们在书写的时候会写成a.fun(1) 或者b.fu ...

  6. TIJ读书笔记04-方法重载

    TIJ读书笔记04-方法重载 为什么会有方法重载 方法签名 如何区分重载 关于基本类型的重载 为什么会有方法重载 OOP的编程方式就是让程序的逻辑更加接近现实世界的逻辑. 而在现实世界中,自然语言本身 ...

  7. TIJ读书笔记01-操作符

      TIJ读书笔记01-操作符 概述 关系操作符和逻辑操作符 位操作符 类型转换 概述 操作符 操作符接受一个或多个参数,并生成一个新值. 换句话说操作符作用于操作数,生成一个新值.有些操作符会改变操 ...

  8. Java 数组 可变长参数 实例

    可以把类型相同但个数可变的参数传递给方法,方法中的参数声明如下: typeName...parameterName (类型名...参数名) 在方法声明中,指定类型后紧跟着省略号...,只能给方法指定一 ...

  9. python学习笔记-函数与可变长参数

    一.函数 1. def test(x): y=x+1 return yprint(test) #这是打印函数在内存中的地址 过程:就是没有返回值的函数 在python中过程也是函数,就算没哟返回值,也 ...

随机推荐

  1. javascript eval函数解析json数据时为什加上圆括号eval("("+data+")")

    原因很简单:因为在js中{}表示一个语句块(代码段),所有加上"()"表示表达式

  2. Java连接mysql数据库

    1.先创建一个Java项目testMysql(我使用的是intellij编辑器). 2.导入mysql的驱动包. (1) (2) (4) 3.编写代码 import java.sql.Connecti ...

  3. UITabBarController常见代理方法的使用

    //下面两个函数是成对出现的若第一个函数返回YES那么第二个方法自动触发执行 //是否允许选择不同的Item触发后续操作,YES是允许,NO是不允许 -(BOOL)tabBarController:( ...

  4. 第三个Sprint冲刺第四天

    讨论地点:宿舍 讨论成员:邵家文.李新.朱浩龙.陈俊金 讨论问题:强化界面功能

  5. JDK各版本新特性!

    1.JDK1.5 新特性 1.自动装箱与拆箱:自动装箱的过程:每当需要一种类型的对象时,这种基本类型就自动地封装到与它相同类型的包装中.自动拆箱的过程:每当需要一个值时,被装箱对象中的值就被自动地提取 ...

  6. Java实验一

    20145113 Java实验一 使用JDK编译.运行简单的Java程序 安装JDK并配置相关环境 安装JDK后配置环境变量 计算机→属性→高级系统设置→高级→环境变量 新建 JAVA_HOME 变量 ...

  7. POJ 2533 动态规划入门 (LIS)

    Longest Ordered Subsequence Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 42914 Accepte ...

  8. unique函数的作用

    unique() 去重函数 unique()函数是一个去重函数,STL中unique的函数 unique的功能是去除相邻的重复元素(只保留一个),还有一个容易忽视的特性是它并不真正把重复的元素删除.他 ...

  9. linux之log_format

    log_format是指存储日志的时候所采用的格式,可以在/usr/local/nginx/conf/nginx.conf的http字段中设置 下面是一个典型的log_format设置 log_for ...

  10. *** glibc detected *** malloc(): memory corruption 分类: C/C++ Linux 2015-05-14 09:22 37人阅读 评论(0) 收藏

    *** glibc detected *** malloc(): memory corruption: 0x09eab988 *** 发现是由于memset越界写引起的. 在Linux Server上 ...