随手一篇 ,Java 怎么看 Native 以及基础规则

👈👈👈 欢迎点赞收藏关注哟

首先分享之前的所有文章 >>>> 😜😜😜
文章合集 : 🎁 juejin.cn/post/694164...
Github : 👉 github.com/black-ant
CASE 备份 : 👉 gitee.com/antblack/ca...

一. 前言

之前有一段时间读底层编码时还看过这一块,但是时间长了方式又忘了,所以这一篇专门记录一下,也方便大家。

Native 源码

通常在阅读源码的时候会碰到这一类代码 ,IDEA 里面怎么点都看不到更底层的代码了 :

这一类代码叫本地方法,Java 是高级语言,但是对底层系统的调用是基于 C 语言的。当需要调用系统底层的时候,就会执行这个逻辑 : JVM 👉 Native Method 👉 C 代码 👉 底层系统

二. 怎么看 Native 代码

看 Native 源码其实就是看 C 语言的过程,方法也不难 , 不过前提是得看 OpenJDK 的代码 :

👉👉👉 jdk8/jdk8: log (openjdk.org) ,点击 ZIP 就可以下载

S1 : 找到 Native 对应 C 代码 , 一般当前 Java Class Name 即为 C Class Name

❗❗这里能看到,每个Java文件都对应了一个 .c 的文件

S2 : 找到对应的 方法

❗❗按照名字进行一一对应就行了

三. 有哪些 Native 代码值得一看

Native 里面有几大值得看的代码 ,这里我说一些我之前看过的 :

补充一 : OpenJDK 的源码结构

在上文步骤一里面我们可以看到好几个源码目录 ,他们分别代表不同模块的代码 :

  • corba : 一个应用之间互相通信的模块,主要是做对象请求代理的 ORB 功能,基本上可以不管
  • hotspot : JVM 相关的原生逻辑,例如线程的创建,我猜垃圾回收什么的应该也在里面(PS :JVM 和 Java 逻辑其实不是一套模块)
  • jaxp : Java中用于处理XML文档的API
  • jaxws : JAX-WS(Java API for XML Web Services)是Java平台上用于开发和部署Web服务的API
  • jdk : Open JDK 核心 API
  • Nashorn :Java平台上的一款JavaScript引擎 (还有这❓❓❓❓)

系列一 : Java Thread 系列

Java 多线程里面有些理论性的东西可能理解比较困难,但是一看源码就清清楚楚了,以线程的创建为例 ,这段代码主要在 JVM 代码里面,也就是 HotSpot 里面 (所以需要预先下载 HotSpot 的源码) :

  • 在这个里面会涉及到 jdk 和 hotspot 两套代码,所以都要下载结合来看
  • 可以看到,实际上的线程最后创建的就是系统线程

其他 :

  • Java 原生对象的一些源代码 (String ,Double) : \src\share\native\java\lang
  • Java IO 的一些代码 : \src\share\native\java\io

其实能看到,这些都涉及到用户态和内核态的一些调用,最终就会走 native 方法。

总结

关于 C 语言的一些用法我已经忘得差不多了,这一篇就不涉及到这一块了。

了解 Native 的原因在于一些底层的原理 。例如零拷贝,多线程实际上还需要这些代码辅助理解。

相关推荐
是梦终空2 分钟前
JAVA毕业设计176—基于Java+Springboot+vue3的交通旅游订票管理系统(源代码+数据库)
java·spring boot·vue·毕业设计·课程设计·源代码·交通订票
落落落sss12 分钟前
sharding-jdbc分库分表
android·java·开发语言·数据库·servlet·oracle
码爸15 分钟前
flink doris批量sink
java·前端·flink
我叫啥都行39 分钟前
计算机基础知识复习9.7
运维·服务器·网络·笔记·后端
Monodye1 小时前
【Java】网络编程:TCP_IP协议详解(IP协议数据报文及如何解决IPv4不够的状况)
java·网络·数据结构·算法·系统架构
一丝晨光1 小时前
逻辑运算符
java·c++·python·kotlin·c#·c·逻辑运算符
无名指的等待7121 小时前
SpringBoot中使用ElasticSearch
java·spring boot·后端
Tatakai252 小时前
Mybatis Plus分页查询返回total为0问题
java·spring·bug·mybatis
武子康2 小时前
大数据-133 - ClickHouse 基础概述 全面了解
java·大数据·分布式·clickhouse·flink·spark
.生产的驴2 小时前
SpringBoot 消息队列RabbitMQ 消费者确认机制 失败重试机制
java·spring boot·分布式·后端·rabbitmq·java-rabbitmq