《Head First Java》——对象的行为

类所描述的是 对象知道什么与执行什么!

调用两个参数的方法,并传入两个参数

void go(){

  TestStuff t = new TestStuff();

  t.takeTwo(12,34);

}

void takeTwo(int x,int y){

  int z =  x + y;

  System.out.println("Total is " + z);

}

你也可以将变量当作参数传入,只要类型相符就可以

void go(){

  int foo = 7;

  int bar = 3;

  t.takeTwo(foo,bar);

}

void takeTwo(){

  int z = x + y;

  System.out.println("Total is " + z);

}

Getter 和 Setter

Getter与Setter可让你执行get与set.Getter 的目的只有一个,就是返回实例变量的值。Setter的目的就是要取用一个参数来设定实例变量的值。

class ElectricGuitar {

  String brand ;

  int numOfPickkups;

  boolean rockStarUsesIt;

  String getBrand(){

  return brand;

}  

void setBrand(String aBrand){

  brand = aBrand;

}

int getNumOfPickups(){

  return numOfPickups;

}

void setNumOfPickups(int num){

  numOfPickups = num;

}

boolean getRockStarUsesIt(){

  return rockStarUsesIt;

}

void setRockStarUsesIt(boolean yesOrNo){

  rockStarUsesIt = yesOrNo;

}

}

封装

封装GoodDog

class GoodDog{

  private int size ;                                               //将实例变量设置成private

  

  public int getSize(){               //将getter 与setter 设定为public   //虽然次方法没有加上实质的功能性,但最重要的是允许你能够在事后改变心意,你可以回头把程序改得更加安全,更好。

  return size;

  }

  public void setSize(int s){

  size = s;

}

}

void bark (){

  if (size > 60){

    System.out.println("Wooof!wooof!");

  } else if (size > 14){

    System.out.println("Ruff! ruff!");

  } else {

    System.out.println("Yip! yip!");

  }

}

class GoodDogTestDrive{

  public static void main(String [] args){

    GoodDog one = new GoodDog();

    one.getSize(70);

    GoodDog two = new GoodDog();

    two.getSize(8);

System.out.println("Dog one:" + one.getSize());

    System.out.println("Dog two:" + two.getSize());

    one.bark();

two.bark();

  }  

}

另外,任何有值可以运用到的地方,都可以调用方法的方式取得该类型的值:

int x = 3 + 24;

可以写成: int x = 3 + one.getSize();

数组中对象的行为

声明一个含有7个Dog引用的Dog数组

Dog [] pets ;                             //创建一个名字叫做 pets 的Dog类数组

pets = new Dog[7];                   //说明这个名字叫 pets 数组里面有几个对象;

然后,创建两个Dog对象并赋值为数组的前两项元素

pets[0] = new Dog();

pets[1] = new Dog();

调用这两个Dog对象的方法

pets[0].setSize(30);

int x = pets[0].getSize();

变量的比较

使用 == 来比较两个 primitive主数据类型,或者判断两个引用是否用同一个对象。

使用equals()来判断两个对象是否在意义上相等

Foo a = new Foo();

Foo b = new Foo();

Foo c = a;

if (a == b){// false}

if (b == c){//false}

if (a == c){//true}

时间: 2024-10-05 04:52:01

《Head First Java》——对象的行为的相关文章

JVM —— Java 对象占用空间大小计算

零. 为什么要知道 Java 对象占用空间大小 缓存的实现: 在设计 JVM 内缓存时(不是借助 Memcached. Redis 等), 需要知道缓存的对象是否会超过 JVM 最大堆限制, 如果会超过要设置相应算法如 LRU 来丢弃一部分缓存数据以满足后续内容的缓存 JVM 参数设置: 如果知道对象会被创建, 可以帮助判断 -Xmx 需要设置多少 只是为了好玩 一. 对象的内存布局 HotSpot 虚拟机中,对象在内存中存储的布局可以分为三块区域:对象头(Header).实例数据(Instan

利用Apache的commons-beanutils和commons-collections包实现Java对象的按属性排序

在日常工作中经常用到需要对java对象集合或者Map集合中的某个属性做排序,这个需求可以利用Apache的commons-beanutils和commons-collections包来实现,主要实现方式如下: public static <T> void sort(List<T> list, String property, boolean asc) { Comparator<?> comparator = ComparableComparator.getInstanc

Java对象的内存布局

Java对象的内存布局:对象头(Header),实例数据(Instance Data),对齐填充(Padding):另外:不同的环境结果可能有差异,我所在的环境是HotSpot虚拟机,64位Windows. 对象头 对象头在32位系统上占用8bytes,64位系统上占用16bytes. System.out.println("sizeOf(new Object()) = " + sizeOf(new Object())); sizeOf(new Object()) = 16 实例数据

JAVA对象头

#为了防止自己忘记,先记着,之前我一直以为<深入理解JAVA虚拟机>写错了来着. 在HotSpot虚拟机中,对象在内存中存储的布局可以分为3块区域:对象头(Header),实例数据(Instance Data)和对齐填充(Padding). 也就是说  JAVA对象 = 对象头 + 实例数据 + 对象填充 对象头由两部分组成,一部分用于存储自身的运行时数据,称之为 Mark Word,另外一部分是类型指针,及对象指向它的类元数据的指针. 对象头 = Mark Word + 类型指针 (未开启指

Java对象及其引用 (1)

Java对象及其引用 [文章转载自:http://zwmf.iteye.com/blog/1738574] 说明:所有转载为个人学习存档使用,凡转载内容均注明转载出处.以后不再说明. 关于对象与引用之间的一些基本概念. 初学Java时,在很长一段时间里,总觉得基本概念很模糊.后来才知道,在许多Java书中,把对象和对象的引用混为一谈.可是,如果我分不清对象与对象引用, 那实在没法很好地理解下面的面向对象技术.把自己的一点认识写下来,或许能让初学Java的朋友们少走一点弯路. 为便于说明,我们先定

java对象分配

1.为什么会有年轻代 我们先来屡屡,为什么需要把堆分代?不分代不能完成他所做的事情么?其实不分代完全可以,分代的唯一理由就是优化GC性能.你先想想,如果没有分代,那我们所有的对象都在一块,GC的时候我们要找到哪些对象没用,这样就会对堆的所有区域进行扫描.而我们的很多对象都是朝生夕死的,如果分代的话,我们把新创建的对象放到某一地方,当GC的时候先把这块存“朝生夕死”对象的区域进行回收,这样就会腾出很大的空间出来. 2.年轻代中的GC     HotSpot JVM把年轻代分为了三部分:1个Eden

JAVA对象JSON数据互相转换的四种常见情况

1. 把java 对象列表转换为json对象数组,并转为字符串 JSONArray array = JSONArray.fromObject(userlist);    String jsonstr = array.toString(); 2.把java对象转换成json对象,并转化为字符串 JSONObject object = JSONObject.fromObject(invite);   String str=object.toString()); 3.把JSON字符串转换为JAVA 对

JAVA对象和XML文档、原来他们之间还有这一出

最近项目开发中遇到一个问题,访问接口不再通过url地址请求的方式,而是 通过socket发送xml格式的报文到指定服务器来进行信息的统一认证.. 因此组装xml格式的报文字符串以及解析服务器返回的xml格式的字符获得所需数据成了 解决问题的关键..在这之前,以为会有点难...做完之后,然并卵,也就那么一回事... LZ主要用的xStream类..这个类的完美地解决了XML文档和JAVA对象之间的转换.. 由于刚刚接触这个类...对于里面提供的很多功能还没细细挖掘..只是简单地实现了 我想要实现的

java对象的大小

原文出处:http://www.open-open.com/lib/view/open1423111722764.html 原文出处: cnblogs-zhanjindong 最近在读<深入理解Java虚拟机>,对Java对象的内存布局有了进一步的认识,于是脑子里自然而然就有一个很普通的问题,就是一个Java对象到底占用多大内存? 在网上搜到了一篇博客讲的非常好:http://yueyemaitian.iteye.com/blog/2033046,里面提供的这个类也非常实用: import j

附 Java对象内存布局

注意:本篇博客,主要参考自<深入理解Java虚拟机(第二版)> 1.对象在内存中存储的布局分为三块 对象头 存储对象自身的运行时数据:Mark Word(在32bit和64bit虚拟机上长度分别为32bit和64bit),包含如下信息: 对象hashCode 对象GC分代年龄 锁状态标志(轻量级锁.重量级锁) 线程持有的锁(轻量级锁.重量级锁) 偏向锁相关:偏向锁.自旋锁.轻量级锁以及其他的一些锁优化策略是JDK1.6加入的,这些优化使得Synchronized的性能与ReentrantLoc