黑马程序员——方法总结之反射

本文深入解析Java反射机制,包括获取Class对象、构造器、成员变量、方法,以及如何利用动态代理实现前置验证与后置记录功能,提高代码安全性与可维护性。
------ Java培训、Android培训、iOS培训、.Net培训、期待与您交流! -------

/*
A:反射
1.获取Class对象
	Person p = new Person();
	Class c = p.getClass();
	Class c2 = Person.class;
	Class c3 = Class.forName("cn.itcast.Person");
2.获取构造器对象
	获取单个构造方法对象
		Constructor con = c.getConstructor();//获取无参构造方法
		Constructor con = c.getConstructor(Strinig.class;Integer.class);//获取带参构造方法
		Constructor con = c.getDeclaredConstructor();//获取私有构造方法
	获取所有构造方法对象的数组
		public Constructor[] getDeclaredConstructors();
	获取公共构造方法对象的数组
		public Consturctor[] getConstructor();
3.取消访问限制:暴力访问
	con.setAccessible(true);
4.创建对象
	Object obj = con.newInstance();
	Object obj = con.newInstance("林青霞",27);
5.获取成员变量对象
	获取名为name的成员变量
		Field nameField = c.getDeclaredField("name");
	获取所有成员变量数组
		Field[] fields = c.getDeclaredFields();
	获取公共成员变量数组
		Field[] fields = c.getFields();
6.取消访问检查
	nameField.setAccessible(true);
7.给obj对象的成员变量赋值为value
	public void set(Object obj,Object value);
	nameField.set(obj,"tony");
8.获取成员方法对象
	public Method getMethod(String name,Class<?>... parameterTypes)
	获取名为name的无参方法
		Method m = c.getDeclaredMethod("name");
	获取名为name,参数为String类型的带参方法
		Method m = c.getDeclaredMethod("name",String.calss);
	获取自己的所有方法的数组
		Method[] methods = c.getDeclaredMehtods();
	获取自己的及父类的公共方法
		Method[] methods = c.getMethods();
9.取消访问检查
	m.setAccessible(true);
10.调用obj对象的name方法
	m.invoke(obj):
	m.invoke(obj,"haha");
	
B:动态代理
1.创建被代理的对象
	StudentDao st = new StudentDaoImpl();
2.创建实现InvocationHandler的类,并重写invoke方法
	public class MyInvocationHandler implements InvocationHandler{
		//传入被代理的目标对象
		private Object target;
		public MyInvocationHandler(Object target){
			this.target = target;
		}
		
		//重写invoke方法,该方法的参数会自动加载代理对象的方法参数
		//只需通过反射调用对象的方法,然后加上特殊功能即可
		public Object invoke(Object proxy,Method method,Object[] args){
			//执行登录或注册前进行校验
			System.out.println("校验方法");
			
			//通过反射调用对象方法
			method.invoke(target,args);
			
			//登录或注册后进行记录
			System.out.println("记录功能");
			
			//因为有返回值Object为避免上述方法中没有返回值,提供默认返回
			return null;//如果底层方法返回类型为 void,则该调用返回 null
		}
	}
3.传入被代理对象,创建实现了InvocationHandler接口的实例
	MyInvocationHandler mi = new MyInvocationHandler(st);
4.创建动态代理对象
	需要3个参数:加载器对象;接口实现类对象;mi;
	public static Object newProxyInstance(ClassLoader loader,Class<?>[] interfaces,InvocationHandler h)
	StudentDao proxy = (StudentDao)	Proxy.newProxyInstance(st.getClass().getClassLoader(),st.getClass().getInterfaces(),mi);
5.用动态代理对象调用方法
	proxy.login();
	proxy.regist();
注意事项:
1.反射对象虽然也在lang包中,但是使用时还是需要导包:java.lang.reflect.Method;等
2.使用有参数的对象,获取时一定要加上字节码文件对象作为参数。
3.被反射调用的类一定是public修饰的,否则无法访问内部成员。
*/



### TCP传输原理与实现 TCP(Transmission Control Protocol)是一种面向连接的、可靠的、基于字节流的传输层协议。其核心原理是通过建立端到端的连接,确保数据在不可靠的网络中能够可靠地传输。TCP 使用确认机制、流量控制、拥塞控制等机制来保障数据的完整性和有序性。 在 Java 中,TCP 通信可以通过 `Socket` 和 `ServerSocket` 类实现。客户端使用 `Socket` 连接到服务器,服务器端使用 `ServerSocket` 监听连接请求。通信过程中,数据通过输入流和输出流进行传输。 #### 客户端实现 客户端的主要任务是与服务器建立连接,并通过输出流向服务器发送数据,同时可以通过输入流接收服务器的响应。例如: ```java Socket s = new Socket(InetAddress.getLocalHost(), 10004); OutputStream out = s.getOutputStream(); out.write("Hello TCPClient".getBytes()); InputStream is = s.getInputStream(); byte[] buffer = new byte[1024]; int len = is.read(buffer); System.out.println(new String(buffer, 0, len)); s.close(); ``` 该代码实现了客户端与服务器的连接,并发送了一条文本消息,同时接收服务器的响应[^1]。 #### 服务端实现 服务端通过 `ServerSocket` 监听指定端口,等待客户端连接。一旦连接建立,服务端通过输入流接收客户端发送的数据,并通过输出流向客户端发送响应。例如: ```java ServerSocket ss = new ServerSocket(10012); Socket s = ss.accept(); InputStream in = s.getInputStream(); byte[] buffer = new byte[1024]; int len = in.read(buffer); System.out.println(new String(buffer, 0, len)); PrintWriter out = new PrintWriter(s.getOutputStream(), true); out.println("<font color='red' size=7>客户端s你好</font>"); s.close(); ss.close(); ``` 该代码展示了如何在服务端接收客户端发送的数据,并向客户端发送 HTML 格式的响应[^3]。 #### TCP连接的建立与释放 TCP 连接的建立采用三次握手(Three-way Handshake): 1. 客户端发送 SYN(同步)报文给服务器,表示请求建立连接。 2. 服务器收到 SYN 报文后,发送 SYN-ACK(同步-确认)报文作为响应。 3. 客户端收到 SYN-ACK 后,发送 ACK(确认)报文,连接建立。 连接的释放采用四次挥手(Four-way Handshake): 1. 客户端发送 FIN(结束)报文,表示数据发送完成。 2. 服务器发送 ACK 报文,确认收到 FIN。 3. 服务器发送 FIN 报文,表示数据发送完成。 4. 客户端发送 ACK 报文,连接关闭。 #### TCP的可靠性机制 TCP 通过以下机制确保数据的可靠传输: - **确认机制**:接收方收到数据后,向发送方发送确认信息。 - **重传机制**:如果发送方未收到确认信息,则重传数据。 - **流量控制**:通过滑动窗口机制,控制发送速率,避免接收方缓冲区溢出。 - **拥塞控制**:通过慢启动、拥塞避免等算法,防止网络拥塞。 #### TCP的编程模型 TCP 编程模型通常包括以下几个步骤: 1. **创建 Socket**:客户端创建 `Socket` 对象,连接服务器;服务端创建 `ServerSocket` 对象,监听端口。 2. **获取流对象**:获取 `Socket` 的输入流和输出流,用于数据传输。 3. **数据读写**:通过输入流读取数据,通过输出流写入数据。 4. **关闭连接**:通信结束后,关闭 `Socket` 和流对象。 ### 示例代码:完整的 TCP 通信 以下是一个完整的 TCP 通信示例,包含客户端和服务端的代码。 #### 客户端代码 ```java import java.io.*; import java.net.*; public class TcpClient { public static void main(String[] args) { try { Socket socket = new Socket("localhost", 8888); OutputStream out = socket.getOutputStream(); out.write("Hello Server!".getBytes()); InputStream in = socket.getInputStream(); byte[] buffer = new byte[1024]; int len = in.read(buffer); System.out.println("Server response: " + new String(buffer, 0, len)); socket.close(); } catch (IOException e) { e.printStackTrace(); } } } ``` #### 服务端代码 ```java import java.io.*; import java.net.*; public class TcpServer { public static void main(String[] args) { try { ServerSocket serverSocket = new ServerSocket(8888); System.out.println("Server is listening on port 8888..."); Socket socket = serverSocket.accept(); InputStream in = socket.getInputStream(); byte[] buffer = new byte[1024]; int len = in.read(buffer); System.out.println("Client message: " + new String(buffer, 0, len)); OutputStream out = socket.getOutputStream(); out.write("Hello Client!".getBytes()); socket.close(); serverSocket.close(); } catch (IOException e) { e.printStackTrace(); } } } ``` ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一夸克

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值