一、包(package)

在java程序中,一个java源文件称为编译单元,以.java后缀命名。编译单元内可以有一个public类,类名必须与文件名相同。注意:每个编译单元只能有一个public类。

在C#中,我们用命名空间namespace来组织类库,用using关键字导入某个命名空间。Java中有同样的概念成为包,关键字是package,使用import关键字导入包。

1.package:
类库就是一组文件,每个文件都有一个public类,以及任意数量的非public类。package语句用来指定当前文件所属的类库,它必须放在文件开始,除注释外的第一行代码。例如:package com.cathy.dto;

2.import:
如果想使用某个包中的类,需要使用import导入对响应包的引用。如果导入包中的多个类,可以使用import.cathy.dto.*;

3.访问修饰符:

  • public:修饰的成员任何人都可以使用。
  • private:除了包含该成员的类,其他类都无法访问该成员。
  • protected:继承访问权限。

有一点需要注意:在C#中,类中的成员如果不添加访问修饰符默认是private;但是在Java中如果不提供任何访问修饰词,默认是包访问权限,处于同一个编译单元中的所有类彼此之间都是自动可访问的。

二、方法传参

1.基本类型作为参数传递
八种基本数据类型(byte,short,int,long,double,float,char,boolean)作为参数传递时,传递的是值的拷贝。所以,方法中任何操作都不会修改原值。

public class PrimitiveDemo {
public static void main(String[] args) {
int num = 10;
change(num);
System.out.println("main() a=" + num);//
} private static void change(Integer a) {
System.out.println("1 change() a=" + a);
a = 20;
System.out.println("2 change() a=" + a);
}
}

运行结果:

1 change() a=10
2 change() a=20
main() a=10

2.对象参数传递引用的拷贝
这个地方,在看《JAVA核心技术I》的时候,作者说的是“JAVA程序设计语言总是按值传递”,这个描述感觉不是太赞同。看了后面的描述:“方法得到的是对象引用的拷贝,对象引用及其他拷贝都同时引用同一对象”。大体和我理解的意思是一致的,也就不纠结说法了。
为方便测试,首先我们定义一个类Book:

class Book {
private int price; public void setPrice(int price) {
this.price = price;
} public Book(int price) {
this.price = price;
} @Override
public String toString() {
return super.toString() + "[price=" + price + "]";
}
}

当为对象类型赋值时,实际上是将两个对象指向了同一个引用,自然也就很容易修改引用对象的属性了。

public class ObjectDemo {
public static void main(String[] args) {
Book book = new Book(10);
System.out.println("①" + book.toString());
change(book);
System.out.println("③" + book.toString());
} private static void change(Book book) {
book.setPrice(20);
System.out.println("②change()" + book);
}
}
运行结果:
①Book@7440e464[price=10]
②change()Book@7440e464[price=20]
③Book@7440e464[price=20]

从运行结果可以看出:change()方法中的book参数确实和原对象指向了同一地址,也就是说在Java中对象作为参数传递时,实际上是把对象在内存中的地址拷贝传给了参数。这样一来,对参数对象book的修改也就修改了原对象。

到这里我就想,两个对象指向的内存地址是一样的,那会不会对象作为参数时,直接传递的就是该对象的引用呢?如果这样的话,我们修改一下参数book的指向,看看会不会影响原有对象的引用。

public class ObjectDemo2 {

public static void main(String[] args) {
Book b1=new Book(10);
Book b2=new Book(20);
System.out.println("before swap" + b1.toString()+b2.toString());
swap(b1,b2);
System.out.println("after swap" + b1.toString()+b2.toString());
} private static void swap(Book pb1, Book pb2) {
Book temp = pb1;
pb1 = pb2;
pb2 = temp;
System.out.println("swap() pb1 " + pb1);
System.out.println("swap() pb2 " + pb2);
pb1.setPrice(100);
pb2.setPrice(200);
}
}

运行结果:

before swapBook@7440e464[price=10] Book@49476842[price=20]
swap() pb1 Book@49476842[price=20]
swap() pb2 Book@7440e464[price=10]
after swapBook@7440e464[price=200] Book@49476842[price=100]

可以看到b1和b2引用的对象并没有变化,交换的只是拷贝的引用pb1和pb2的地址。

三、构造函数

说起构造函数大家一点都不陌生,但有几点要注意的地方:
1.仅当没有提供任何构造器的时候,系统才会默认提供一个无参构造器。
2.构造函数可以调用另一个构造函数,但是必须遵守以下几个规则:
* 构造函数调用必须位于第一行;
* 构造函数只能被调用一次;
* 不能在构造函数以外的任何位置调用构造函数。

public class Person {
private String name;
private Integer age; public Person(String name) {
this.name = name;
} public Person(String name, Integer age) {
this(name);
this.age = age;
} @Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
'}';
} public static void main(String[] args) {
Person p = new Person("a", 11);
System.out.println(p);
}
}

3.初始化顺序:先初始化变量,后调用构造函数。
在同一个类中,变量的初始化是和定义的先后顺序一致的。不过,即使变量定义在构造函数的后面,仍然会先初始化所有变量,然后才执行构造函数。

public class Order {
OrderDetail d1 = new OrderDetail(100);
OrderDetail d2 = new OrderDetail(200); public Order() {
OrderDetail d3 = new OrderDetail(300);
} OrderDetail d4 = new OrderDetail(400); public static void main(String[] args) {
new Order();
}
} class OrderDetail {
public OrderDetail(Integer price) {
System.out.println("OrderDetail price=" + price);
}
}

执行结果:

OrderDetail price=100
OrderDetail price=200
OrderDetail price=400
OrderDetail price=300

原来你是这样的JAVA[02]-包、传参、构造器的更多相关文章

  1. Jmeter调用JAVA jar包传参

    http://blog.csdn.net/xiazdong/article/details/7873767#

  2. java复用和传参

    java复用和传参的三种方法总结: (1) 直接在一个类中调用函数 : 1 package test1; 2 3 public class a 4 { 5 public static void get ...

  3. [Java]_函数传参的疑惑与思考

    问题来源于leetcode上的两道题 Path Sum I && II,分别写了两个dfs. void dfs(TreeNode node , int sum , ArrayList& ...

  4. Java的对象传参问题

    在c/c++中对于传参类型,无外乎就是传值.传引用.传指针这几种.但在java中,由于没有指针类型,其传参的方式也发生了相应的变化.之前有搜过相关的知识点一直理解的是:Java的传参方式中主要有两种: ...

  5. SpringBoot系列: Java应用程序传参和SpringBoot参数文件

    ===========================向java 程序传参的几种形式:===========================1. 使用 OS 环境变量. 这个不推荐. 2. 使用JVM ...

  6. 在Java中动态传参调用Python脚本

    最近,又接触到一个奇葩的接口,基于老板不断催促赶时间的情况下,在重写java接口和复用已有的python脚本的两条路中选择了后者,但是其实后者并没有好很多,因为我是一个对python的认识仅限于其名称 ...

  7. Java函数的传参机制

    一 最近的一个项目,里面各种返回void,参数用引用类型,那叫一个熟和多,但是也把我绕糊涂了. 我就打算好好理一理java的传参机制,整理一番 二 很多人一听Java的传参,那一定会脱口而出,java ...

  8. java 中 Integer 传参方式的问题

    Java本身都是值传递式的调用,对于对象传递的是地址值.给地址值重新赋值等于重新指向,不会影响外层. 而且这里Integer对象也有特殊性.其实现上可能类似 class Integer{ final ...

  9. Java接口实现传参

    package com.gezhi.interfaces;/** * 新建一个dog类实现接口livingable(狗吃和上厕所都是与生俱来的不应该写成接口) * @author square 凉 * ...

随机推荐

  1. JAVA8新特性(一)

    default拓展方法 java8为接口声明添加非抽象方法的实现,也成为拓展方法. public interface Formula { void doSomething(); default voi ...

  2. Servlet实践--留言板-v1

    功能介绍: 由三个jsp页面组成,在doGet中根据请求URL中的请求参数不同,跳转到不同的页面: 页面1:显示整个留言板列表 页面2:创建留言页面(包括用户.主题.内容和上传文件) 页面3:在查看单 ...

  3. 深入解析Java垃圾回收机制

    引入垃圾回收 哪些内存需要回收? 引用计数法 可达性分析 如何回收 Marking 标记 Normal Deletion 清除 Deletion with Compacting 压缩 为什么需要分代收 ...

  4. linux上kafka模拟客户端发送、接受消息

    producer   消息的生成者,即发布消息 consumer   消息的消费者,即订阅消息 broker     Kafka以集群的方式运行,可以由一个或多个服务组成,服务即broker zook ...

  5. html和css的区别

    html(结构) Hyper Text Markup Language(超文本标记语言)用于定义文档内容结构 1.该语言写的代码通常会被浏览器解析执行 2.超文本:不止包括文本,还有图片.链接.音乐. ...

  6. Linux send和recv

    1.send 函数 int send( SOCKET s, const char FAR *buf, int len, int flags ); 不论是客户还是服务器应用程序都用send函数来向TCP ...

  7. MERGE语法详解

    merge语法是根据源表对目标表进行匹配查询,匹配成功时更新,不成功时插入. 其基本语法规则是 merge into 目标表 a using 源表 b on(a.条件字段1=b.条件字段1 and a ...

  8. Cesium几个案例介绍

    前言 本文为大家介绍几个Cesium的Demo,通过这几个Demo能够对如何使用Cesium有进一步的了解,并能充分理解Cesium的强大之处和新功能.其他的无需多言,如果还不太了解什么是Cesium ...

  9. 【Struts2的执行流程,这个博主写的很详细】

    http://blog.csdn.net/wjw0130/article/details/46371847

  10. python爬虫(七)_urllib2:urlerror和httperror

    urllib2的异常错误处理 在我们用urlopen或opener.open方法发出一个请求时,如果urlopen或opener.open不能处理这个response,就产生错误. 这里主要说的是UR ...