访问对象的private 方法

本文探讨了在Java中实现Serializable接口时自定义序列化过程的方法,并解释了为什么相关方法被声明为私有。此外,文章还介绍了如何通过反射机制访问这些私有方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 这个问题是跟同学讨论interface Serializable的用法是注意到的。JDK文档中说Serializable 为标记接口(tag interface),实现该接口的类不需要实现任何指定的方法。但是,如果当我们需要自定义序列化过程时,就需要在类中添加两个指定的方法:
java 代码
  1. private void writeObject(java.io.ObjectOutputStream out)   
  2.      throws IOException   
  3. private void readObject(java.io.ObjectInputStream in)   
  4.      throws IOException, ClassNotFoundException;   
  嗯,private?确实这样。按常理说,这两个方法应该是被ObjectOutputStream和ObjectInputStream对象的writeObject和readObject方法调用的,这符合面向对象的封装规则:序列化就应该是对象自身的责任。但是,这两个方法设定为private,那么其他对象如何访问呢?当然,因为Serializable对象的序列化工作由jvm内置支持的,因此方法存取权限当然不是问题,但是Java将其设定为private有什么好处呢?
   其实,我们也可以访问对象的私有方法的,使用反射机制便可:
java 代码
  1. import java.lang.reflect.Method;   
  2.   
  3. public class EatApple {   
  4.   
  5.     /**  
  6.      * @param args  
  7.      */  
  8.     public static void main(String[] args) throws Exception{   
  9.         new EatApple().eat();   
  10.   
  11.     }   
  12.        
  13.     public void eat() throws Exception{   
  14.         Apple apple = new Apple();   
  15.         Method m = apple.getClass().getDeclaredMethod("taste",new Class[] {});   
  16.         m.setAccessible(true);   
  17.         Object result = m.invoke(apple, new Object[] {});   
  18.              
  19.     }   
  20. }   
  21.   
  22. class Apple{   
  23.        private void taste(){   
  24.          System.out.println("Delicious!");   
  25.        }   
  26.     }  
  这个又有什么用处呢?嗯,使用Junit测试私有方法的时候就可以派上用场了,可以看看Bill Venners的叙述: Testing Private Methods with JUnit and SuiteRunner
  。。敲完以后提示我权限不够,session超时吧,后退找不回来了,只好重敲了一遍,痛:(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值