Java基础知识点(反射、注解、JDBC、TCP/UDP/URL)

文章目录

  • 反射
    • 反射的定义
    • class对象
    • 反射的操作
  • 注解
    • 注解的定义
    • 注解的应用
    • 注解的分类
      • 基准注解
      • 元注解
    • 自定义注解
      • 自定义规则
      • 自定义demo
  • JDBC
  • TCP/UDP/URL
    • TCP
    • UDP
    • URL

反射

反射的定义

Java Reflection是Java被视为动态语言的基础啊, 反射机制允许程序在执行期间接入Reflection API获取任何类的内部信息,并能直接操作任意对象的内部属性及方法。

class对象

  1. 类加载完成后,在堆内存中就会残生一个该类的Class对象(一个类只有一个Class对象),Class对象中包含了完整类的结构信息,包括:类型、方法、属性、注解、构造函数、类加载起,父类Class对象等。
  2. 在Object类中有一个方法:public final Class getClass();这个方法被所有子类继承。
  3. Calss本身也是一个类。Class对象只能由系统建立,JVM产生。
  4. 一个类加载到JVM中只会产生一个Class对象,一个Class对象对应的是一个加载到JVM中的一个.class文件。
  5. 每个类的实例都会记得自己是由那个Calss实例是生成的,Object的getClass方法。
  6. 通过Class可以完整的得到一个类的所有被加载的结构。
  • Class的创建
//获得class办法一:通过对象获得
Class clazz1 = person.getClass();
//获得class办法二:通过字符串获得(包名+类名)
Class clazz2 = Class.forName("com.reflection.Student");
//获得class办法三:通过类的静态成员class获得
Class clazz3 = Person.class;
//获得class办法四:只针对内置的基本数据类型
Class clazz4 = Integer.TYPE;
//获得父类类型
Class clazz5 = clazz2.getSuperclass();
  • 常用方法
    在这里插入图片描述

  • 哪些类型可以有Class对象?

  • class:外部类,成员(成员内部类,静态内部类),局部内部类,匿名内部类。

  • interface:接口

  • []:数组

  • enum:枚举

  • annotation:注解@interface

  • primitive type:基本数据类型

  • void

反射的操作

  1. Class对象调用newInstance() 方法创建类的对象,类必须有一个无参数构造器,类的构造器必须有访问权限。
  2. 调用指定的方法,通过Class对象获取到具体的Method,然后执行Method的Object invoke(Object obj, Object[] args)方法就可完成调用,
  3. setAccessible
    Method/Field/Constructor对象都有setAccessible方法,setAccessible的作用是启动或者禁止访问安全检查的开关(也就是可以打开私有属性、方法、构造器等),值分为false和true。

注解

注解的定义

  1. Java注解又称Java标注、元数据,它提供了一种安全的类似注解的机制,用来将任何信息或者元数据(metadata)与程序元素(类、方法、属性等)进行关联。
  2. Java注解是附加在代码中的一些元数据,用于一些工具在编译、进行时进行解释和使用,起到说明配置的功能。

注解的应用

  1. 生成文档,也是Java最早提供的注解功能。
  2. 在编译时进行格式检查,例如:@Override注解放在方法前,如果这个方法并不是覆盖了超类的方法,在编译阶段就能检测出。
  3. 跟踪代码的以来星,实现替代配置文件的功能,比较常见的是Spring2.5开始基于注解开发,减少了配置文件的配置。
  4. 在Java反射中,可以解析并使用注解(Annotation),这也是上3实现的底层原理。

注解的分类

基准注解

基准注解就是Java语言自带的注解,主要有:

  1. @Override:作用在METHOD上,使用在SOURCE(源代码阶段),功能是:检查该方法是否是重写方法,如果发现父类超类并没有该方法,就会编译报错。
  2. @Deprecated:作用在CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, PARAMETER, TYPE上,使用在RUNTIME阶段,功能是:标记果实方法,如果使用该方法,会编译警告。
  3. @SuppressWarnings:作用在TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE上,使用在SOURCE阶段,功能是:提示编译器去忽略解释中的声明警告。
    在这里插入图片描述
  4. @FunctionalInterface:作用在TYPE上,使用在RUNTIME阶段,功能是:Java8支持,表示一个匿名函数或者函数式接口。

元注解

  1. @Target: 用来定义注解的使用范围,即描述注解可以使用在那些地方,该注解包含9个值,是ElmentType枚举类的枚举类型:
  • TYPE:应用于类、结构、注解类型、枚举上
  • CONSTRUCTOR: 应用于构造函数上
  • PARAMETER: 应用于方法的参数上
  • FIELD: 应用于字段属性上
  • METHOD: 应用于方法上
  • PACKAGE: 应用于包
  • LOCAL_VARIABLE: 应用于局部变量上
  • TYPE_PARAMETER: Java8新增,应用于类型变量
  • TYPE_USE: Java8新增,应用在任何使用类型语句中
  1. @Retention:用来定义该注解可以在哪一个阶段可用,该注解包含3个值,是RententionPolicy枚举类的枚举类型:
  • SOURCE:源代码阶段,编译时被丢弃,不包含在class文件冲,
  • CLASS(默认值):class文件阶段,JVM加载时被丢弃,包含在class文件中,
  • RUNTIME: 运行时阶段,由JVM加载,包含在class文件中,在运行时可以获取到。
  1. @Documented: 生成文档信息时候保留注解,对类起说名作用,该注解将会包含在javadoc中.
  2. @Inherited: 说明子类可以继承父类中的该注解.
  3. @Repeatable:表示允许统一程序元素可以多次使用相同的注解。
//在使用时候,需要同时提供一个容器注解来封装可以重复注解的多个实例:@Repeatable(Roles.class)
public @interface Role {String value();
}// 容器注解
public @interface Roles {Role[] value();
}
使用该注解:
@Role("admin")
@Role("supervisor")
public class MyClass {// ...
}

自定义注解

自定义规则

  1. 使用@interface自定义注解,使用时激动继承了java.lang.annotation.Annotation接口。
  2. 具体规则:
  • @interface 中每一个方法实际上是声明了一个配置参数,方法的名称就是参数的名称,返回值类型就是蚕食的类型(返回值类型只能是基本类型、Class、String、enum).
  • 通过default来声明蚕食的默认值。
  • 如果只能由一个参数成员,一般参数名为value。
  • 注解元素必须要有值,自定义注解元素时,经常使用空字符串、0作为默认值

自定义demo

自定义注解类:

package com.xxliao.annotation;import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;/*** @author xxliao* @description: 字符初始化* @date 2023/11/16$ 1:16$*/@Target(value = {ElementType.METHOD,ElementType.FIELD,ElementType.CONSTRUCTOR})// 可在字段、方法上使用
@Retention(value = RetentionPolicy.RUNTIME) // 运行时
public @interface Init {String value() default "";}

实体类:

package com.xxliao.annotation;/*** @author xxliao* @description: 用户实体类* @date 2024/6/1 15:25*/public class User {private String name;@Init("xxliao")public void setName(String name) {this.name = name;}@Overridepublic String toString() {return "User{" +"name='" + name + '\'' +'}';}
}

实体工厂类:

package com.xxliao.annotation;import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;/*** @author xxliao* @description: 用户对象工厂 用来创建用户对象 添加了读取自定义注解 赋默认值的功能* @date 2024/6/1 15:27*/
public class UserFactory {private static boolean IS_DEFAULT_VALUE;private static Init INIT;private static Method METHOD;static{// 获取User类中所有的方法(getDeclaredMethods也行)Method[] methods = User.class.getDeclaredMethods();for (Method method : methods) {// 如果一个注解指定注解类型是存在于此元素上此方法返回true,否则返回false//参数 -- 对应于注解类型的Class对象if (method.isAnnotationPresent(Init.class)) {//此方法返回该元素的注解在此元素的指定注释类型(如果存在),IS_DEFAULT_VALUE  = true;INIT =  method.getAnnotation(Init.class);METHOD = method;break;}}}/*** @description  创建对象* @author  xxliao* @date  2024/6/1 15:29*/public static User newInstance()  {User instance = new User();if(IS_DEFAULT_VALUE) {try {METHOD.invoke(instance,INIT.value());} catch (IllegalAccessException e) {throw new RuntimeException(e);} catch (InvocationTargetException e) {throw new RuntimeException(e);}}return instance;}
}

测试类:

package com.xxliao.annotation;/*** @author xxliao* @description: 自定义注解 测试客户端* @date 2023/11/16$ 1:37$*/public class TestClient {public static void main(String[] args) {User user = UserFactory.newInstance();System.out.println(user);}
}

演示结果:
在这里插入图片描述

JDBC

//JDBC使用步骤
// 1.加载驱动
Class.forName("com.mysql.jdbc.Driver");
// 2.连接数据库,代表数据库
Connection connection = DriverManager.getConnection(url, username,password);
// 3.向数据库发送SQL的对象Statement,PreparedStatement : CRUD
Statement statement = connection.createStatement();
// 4.编写SQL
String sql = "select * from users";
// 5.执行查询SQL,返回一个 ResultSet : 结果集
ResultSet rs = statement.executeQuery(sql);
while (rs.next()){
System.out.println("id="+rs.getObject("id"));
System.out.println("name="+rs.getObject("name"));
System.out.println("password="+rs.getObject("password"));
System.out.println("email="+rs.getObject("email"));
System.out.println("birthday="+rs.getObject("birthday"));
}
// 6.关闭连接,释放资源(一定要做) 先开后关
rs.close();
statement.close();
connection.close();

TCP/UDP/URL

TCP

server端:

package com.xxliao.tcp;import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;/*** @author xxliao* @description: TCP 服务端* @date 2023/11/19$ 12:47$*/public class TcpServer {public static void main(String[] args) {ServerSocket serverSocket = null;Socket accept = null;InputStream is = null;ByteArrayOutputStream baos = null;try {//1. 开放服务器端口,创建ServerSocketserverSocket = new ServerSocket(8899);//2. 等待客户端的连接accept = serverSocket.accept();//3. 读入客户端的消息,is = accept.getInputStream();/*回忆之前的IO流方案,弊端:存在中文,可能存在乱码。byte[] buffer = new byte[1024];int len;while ((len=is.read(buffer))!=-1){String str = new String(buffer,0,len);System.out.println(str);}**/baos = new ByteArrayOutputStream();byte[] buffer = new byte[1024];int len;while ((len=is.read(buffer))!=-1){baos.write(buffer,0,len);}System.out.println(baos.toString());System.out.println("数据来源地址:"+accept.getInetAddress().getHostName());} catch (IOException e) {e.printStackTrace();} finally {//4. 关闭资源try {if (baos!=null){baos.close();}if (is!=null){is.close();}if (accept!=null){accept.close();}if (serverSocket!=null){serverSocket.close();}}catch (Exception e){e.printStackTrace();}}}
}

client端:

package com.xxliao.tcp;import java.io.IOException;
import java.io.OutputStream;
import java.net.InetAddress;
import java.net.Socket;
import java.net.UnknownHostException;/*** @author xxliao* @description: TCP演示* @date 2023/11/19$ 12:45$*/public class TcpClient {public static void main(String[] args) {Socket socket = null;OutputStream os = null;try {//1. 连接服务器的地址InetAddress serverIP = InetAddress.getByName("127.0.0.1");int port = 8899;//2. 创建一个Socketsocket = new Socket(serverIP,port);//3. 创建一个输出流,向外写东西os = socket.getOutputStream();os.write("hello,tcp...".getBytes());} catch (UnknownHostException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();} finally {//4. 关闭资源try {if (os!=null){os.close();}if (socket!=null){socket.close();}} catch (IOException e) {e.printStackTrace();}}}
}

UDP

udp接受端:

package com.xxliao.udp;import java.net.DatagramPacket;
import java.net.DatagramSocket;/*** @author xxliao* @description: UdpReceiver* @date 2023/11/19$ 12:54$*/public class UdpReceiver {public static void main(String[] args) throws Exception{//1. 建立DatagramSocket,开放端口DatagramSocket socket = new DatagramSocket(9090);//2. 接收数据byte[] buffer = new byte[1024];DatagramPacket packet = new DatagramPacket(buffer,0,buffer.length);socket.receive(packet);//3. 输出数据// packet.getData() : 获取packet中的数据System.out.println(new String(packet.getData(), 0,packet.getLength()));//4. 关闭socketsocket.close();}
}

udp发送端:

package com.xxliao.udp;import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException;/*** @author xxliao* @description: UdpSender* @date 2023/11/19$ 12:53$*/public class UdpSender {public static void main(String[] args) throws Exception {//1. 建立DatagramSocketDatagramSocket socket = new DatagramSocket();//2. 封装数据包String msg = "UDPSender==>";byte[] data = msg.getBytes();InetAddress inet = InetAddress.getByName("127.0.0.1");int port = 9090;DatagramPacket packet = newDatagramPacket(data,0,data.length,inet,port);//3. 通过 Socket 发送 packetsocket.send(packet);//4. 关闭socketsocket.close();}
}

URL

举例1:

package com.xxliao.url;import java.net.MalformedURLException;
import java.net.URL;/*** @author xxliao* @description: url demo one * @date 2023/11/19$ 13:01$*/public class URLDemo {public static void main(String[] args) {try {URL url = new URL("http://localhost:8080/helloworld/index.jsp? username=kuangshen&password=123");System.out.println(url.getProtocol()); //获取URL的协议名System.out.println(url.getHost()); //获取URL的主机名System.out.println(url.getPort()); //获取URL的端口号System.out.println(url.getPath()); //获取URL的文件路径System.out.println(url.getFile()); //获取URL的文件名System.out.println(url.getQuery()); //获取URL的查询名} catch (MalformedURLException e) {e.printStackTrace();}}
}

举例2:

package com.xxliao.url;import java.io.FileOutputStream;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;/*** @author xxliao* @description: url demo two* @date 2023/11/19$ 13:02$*/public class URLDemo02 {public static void main(String[] args) {try {//1. 定位到服务器端的资源URL url = newURL("http://localhost:8080/helloworld/xxliao.jpg");//2. 创建连接HttpURLConnection connection = (HttpURLConnection)url.openConnection();//3. 获取输入流InputStream is = connection.getInputStream();//4. 写出文件FileOutputStream fos = new FileOutputStream("xxliao2.jpg");byte[] buffer = new byte[1024];int len;while ((len=is.read(buffer))!=-1){fos.write(buffer,0,len);}//关闭资源fos.close();is.close();connection.disconnect(); //断开连接} catch (Exception e) {e.printStackTrace();}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/20415.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[数据集][目标检测]脑肿瘤检测数据集VOC+YOLO格式9787张3类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):9787 标注数量(xml文件个数):9787 标注数量(txt文件个数):9787 标注…

【图像增强处理工具】软件使用说明书

软件使用说明书 软件名称 图像增强处理工具 软件简介 该软件是一个基于 PySide6 和 OpenCV 的图像处理工具,用户可以通过 GUI 界面来执行图像的旋转、平移和镜像操作,并将处理后的图像保存到指定路径。 运行软件须知 确保 ui_form.py 文件在同一目录下,该文件包含了通…

浅谈安科瑞ASJ10-LD1A智能漏电继电器的设计与应用-安科瑞 蒋静

一 产品简介 功能 ASJ10-LD1A安科瑞智能电力继电器 剩余电流保护可与低压断路器或低压接触器等组成组合式的剩余电流动作保护器,主要适用于交流50Hz,额定电压为400V及以下的TT或TN系统配电线路,防止接地故障电流引起的设备和电气火灾事故&a…

AndroidStudio中debug.keystore的创建和配置使用

1.如果没有debug.keystore,可以按照下面方法创建 首先在C:\Users\Admin\.android路径下打开cmd窗口 之后输入命令:keytool -genkey -v -keystore debug.keystore -alias androiddebugkey -keyalg RSA -validity 10000 输入两次密码(密码不可见,打码处随便填写没关系) 2.在build…

select多个客户端连接,传输数据时只能顺序传输产生原因

1. 场景描述 即A先连接,B后连接&#xff0c;只能先A后B依次输入数据&#xff0c;服务端依次读取数据 这是因为进行循环遍历lfd之后的描述符时&#xff0c;没有判断文件描述符i是否在newset集合中 //cfd发生变化 for(int ilfd1;i<maxfd;i){printf("i num %d\t"…

Matplotlib | 绘制柱状图

简介 安装 Matplotlib 开始绘制 简单柱状图 改变颜色 改变纹理 改变边框样式 改变透明度 改变柱子宽度 改变图表标题 ​编辑 并列柱状图 横向柱状图 堆叠柱状图 更多函数 简介 柱状图&#xff08;Bar chart&#xff09;&#xff0c;是一种以长方形的长度为变量的…

黑白群晖激活AME(Advanced Media Extention)

黑群晖激活Advanced Media Extensions&#xff08;AME&#xff09;解码HEVC视频和HEIC图片 声明&#xff1a;此教程在正版群晖系统中进行的操作&#xff0c;虽然也能用于非正版系统中AME的安装&#xff0c;但是在非正版系统中安装AME属于破解行为&#xff0c;对系统造成的影响和…

这里一定有你不知道的VS调试技巧

目录 使用环境&#xff1a;Visual Studio 2022,如无特殊说明&#xff0c;都是在Debug、x64环境下编译 一.什么是BUG 二.调试快捷键 F9&#xff1a;创建断电或取消断点 条件断点&#xff1a;满足这个条件才触发 F5&#xff1a;启动调试&#xff0c;经常⽤来直接跳到下⼀个断…

20 - grace数据处理 - 地下水储量计算过程分解 - 地下水储量计算

20 - grace数据处理 - 地下水储量计算过程分解 - 地下水储量计算 0 引言1 地下水储量变化计算过程0 引言 由水平衡方程可以将地下水储量的计算过程分解为3个部分,第一部分计算陆地水储量变化、第二部分计算地表水储量变化、第三部分计算冰后回弹改正、第四部分计算地下水储量变…

Vue:Bin Code Editor格式化JSON编辑器

最终效果如下图所示&#xff0c; Bin Code Editor安装 npm或yarn安装命令如下&#xff0c; npm i bin-code-editor -S # or yarn add bin-code-editor 组件注册 全局注册 在 main.js 中写入导入以下内容&#xff0c; import Vue from vue; import CodeEditor from bin-cod…

服务器数据恢复—异常断电导致ESXi虚拟机无法启动的数据恢复案例

服务器数据恢复环境&#xff1a; 某大厂PS4000服务器&#xff0c;服务器上部署VMware ESXi虚拟化平台。 服务器故障&#xff1a; 机房断电&#xff0c;重启后服务器中的某台虚拟机不能正常启动。管理员查看虚拟机配置文件&#xff0c;发现无法启动的虚拟机的配置文件除了磁盘文…

【每日刷题】Day53

【每日刷题】Day53 &#x1f955;个人主页&#xff1a;开敲&#x1f349; &#x1f525;所属专栏&#xff1a;每日刷题&#x1f34d; &#x1f33c;文章目录&#x1f33c; 1. 1019. 链表中的下一个更大节点 - 力扣&#xff08;LeetCode&#xff09; 2. 116. 填充每个节点的下一…

Exce 两列一组对齐呈现,缺失补 0

Excel 里有 多 组数据&#xff0c;每组 2 列&#xff0c;每组长度不同。第 1 列是编号&#xff0c;列之间的编号有重复。 ABCDEFGH1Mass10Mass11Mass12Mass132802200581309088146532802225938133306824779282975598142002482273148413154988335698822331305832720485110460842…

计算机考研|408 值得选择吗?有哪些优势?

408当然非常值得报考&#xff0c;但是现在的408已经卷麻了&#xff01; 现在越来越多的学校改考408&#xff0c;光今年就有6所发布通知&#xff0c;宣布改考408&#xff0c;分别是&#xff1a; 这对考408的学生肯定是好消息&#xff0c;后面可能还会有学校陆续改考&#xff0c;…

一、实现一个简单的 Google Chrome 扩展程序

目录 &#x1f9ed; 效果展示 # 图示效果 a. 拓展程序列表图示效果&#xff1a; b. 当前选项卡页面右键效果&#xff1a; c. 拓展程序消息提示效果&#xff1a; &#x1f4c7; 项目目录结构 # 说明 # 结构 # 文件一览 ✍ 核心代码 # manifest.json # background.j…

华为 2024 届实习校园招聘-硬件通⽤/单板开发——第五套

华为 2024 届实习校园招聘-硬件通⽤/单板开发——第五套 部分题目分享&#xff0c;完整版带答案(有答案和解析&#xff0c;答案非官方&#xff0c;未仔细校正&#xff0c;仅供参考&#xff09;&#xff08;共十套&#xff0c;每套四十题选择题&#xff09;获取&#xff08;WX:…

java期末细节知识整理(一)

1.java程序的执行过程&#xff1a;先编译后解释。也就是我们在idea写的文件叫做java源文件&#xff08;.java结尾的文件&#xff09;&#xff0c;经过编译器会生成字节码文件&#xff08;.class结尾的文件&#xff09;&#xff0c;再通过解释器进行实现 2.栈用来存储引用类型的…

易语言本地IP一键切换程序(附带源码)

易语言本地IP一键切换程序 效果图部分源码源码领取下期更新预报 效果图 部分源码 .判断开始 (单选框1.选中 &#xff1d; 真)标签5.标题 &#xff1d; #换行符 &#xff0b; “正在切换IP.”.如果真 (运行 (“netsh interface ip set address ” &#xff0b; #引号 &#xff…

PHP火狼大灌篮游戏源码微信+手机wap源码带控制

使用此接口可以实现支付宝、QQ钱包、微信支付与财付通的即时到账&#xff0c;免签约&#xff0c;无需企业认证。PHP易支付源码&#xff0c;免签约不需要企业的支付平台源码&#xff0c;彩虹第三四方在线支付系统源码,易支付token合作者商户申请源码&#xff0c;app和网页都可以…

ubuntu--Linux运行时格式

Linux运行时格式 \r 错误 用vim打开那个执行错误的 sh脚本文件 进入最后一行模式下 :set ff显示 fileformatdos 解决方法 : :set ffunix查看是否更改 : :set ff结果 : 保存退出即可 :x运行, 没有出错 * Author: cpu_code * Date: 2020-07-29 19:07:52 * LastEditTime: 2020…