概率推理_知识图上的概率推理

2024-02-08 04:59
文章标签 知识 推理 概率 图上

本文主要是介绍概率推理_知识图上的概率推理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概率推理

知识图和原因 (KNOWLEDGE GRAPHS & REASONING)

Using a knowledge graph without reasoning is like having an inviting cake and leave it there to admire it: aesthetically fascinating but a waste of yummy ingredients and, in the long run, pointless!

不加说明地使用知识图就像是一个诱人的蛋糕,放在那儿欣赏它:美观迷人,但浪费了美味的原料,从长远来看,毫无意义!

Reasoning enables the ‘knowledge part’ of a knowledge graph which, without it, can be viewed more like a database than a knowledge model.

推理使知识图的“知识部分”成为可能,如果没有知识图,则知识图更像数据库,而不是知识模型

Here’s the difference in a nutshell.

简而言之,这就是区别。

While a relational database has its central point in modeling reality with relations, storing into tables, and querying in SQL a domain of interest, a knowledge graph is more about graph-like data (but not only data as in a graph database).

虽然关系数据库在通过关系对现实进行建模,将其存储到表中以及在SQL中查询感兴趣的域时具有中心点,但是知识图更多地是关于像图的数据(但不仅是像图数据库中的数据)。

With a knowledge graph, you can model a reality of interest for which you have graph-like data (the so-called ground extensional component). You can abstractly describe how such reality works, that is: what are the rules of the underlying business, what are the things humans know, but neither programs nor databases do. Finally, through the reasoning process, you can generate new knowledge in the form of new nodes and edges for your graph, namely, the derived extensional component, a.k.a. reasoning component [1].

使用知识图 ,您可以为感兴趣的现实建模,并获得类似图的数据(所谓的地面扩展组件 )。 您可以抽象地描述这种现实的工作原理,即:基础业务的规则是什么,人们知道什么,但是程序和数据库都没有。 最后,通过推理过程,您可以以新节点和边的形式为图形生成新知识,即派生的扩展组件,即推理组件 [1]。

For a straightforward example of reasoning on knowledge graphs, you can check it out here on Medium.

有关知识图上推理的简单示例,可以在Medium上进行检查。

So far, so good.

到目前为止,一切都很好。

But the reality is uncertain, data are uncertain, the domain knowledge is uncertain, and even our human brain inferential processes are, by design, uncertain. Therefore, reasoning needs to include and handle all kinds of uncertainty.

但是现实是不确定的,数据是不确定的,领域知识是不确定的,甚至我们的人脑推理过程在设计上也是不确定的。 因此,推理需要包括和处理各种不确定性。

So, if you want to make cutting-edge reasoning on knowledge graphs and if you want a more reasonable and reliable representation of reality and not a kind of robot/puppet version of human reasoning, you need to consider uncertainty and incorporate it in your reasoning.

因此,如果您想在知识图上进行最前沿的推理,并且想要更合理和可靠地表示现实,而不是某种人类推理的机器人/木偶版本,则需要考虑不确定性并将其纳入推理中

如何在KG上做概率推理 (How to cook probabilistic reasoning on KGs)

Image for post
Calum Lewis on Calum Lewis Unsplash 摄,Unsplash

In probabilistic reasoning with KGs, we need to perform the ‘probabilistic part’ of course. Still, the bad news is that if we want to achieve it wisely, we also need to satisfy at the same time, the standard requirements for reasoning on KGs [2].

在使用KG进行概率推理时,我们当然需要执行“概率部分”。 不过,坏消息是,如果我们想明智地实现它,我们需要同时满足KG推理的标准要求 [2]。

We don’t want to be able to, for example, handle null values but not be able to traverse the graph, right? So we need FOUR CRITICAL INGREDIENTS for the basic recipe here:

例如,我们不希望能够处理空值,但又无法遍历图形,对吗? 因此,我们在这里需要四个关键成分作为基本配方:

  1. Full recursion

    完全递归

If you want to explore graph structures, at least, you will expect to traverse these graphs! Of course not only to traverse: you want to explore graph data with a multitude of algorithms, where the extent and the form of the paths are not known a priori.

如果至少要探索图形结构,则可以遍历这些图形! 当然,不仅要遍历,还需要使用多种算法来探索图形数据,而这些算法的先验范围并不知道路径的范围和形式。

With graph databases, you may be used to pattern-matching languages like in Neo4J. Here the world is different: knowledge graphs don’t usually do pattern matching, but rely on a way more powerful tool: recursion.

使用图数据库,您可能会像Neo4J一样习惯于模式匹配语言。 这里的世界是不同的:知识图通常不进行模式匹配,而是依靠更强大的工具:递归

So, I am sorry to inform you that since you want to reason on a kg, you need recursion.

因此,很遗憾地通知您,由于您要推理一个公斤,因此需要递归。

And it must be full, in the sense that we cannot get away with many existing forms of partial recursion, as we want a complete choice of the graph algorithm we can write.

并且它必须是完整的 ,从某种意义上说,我们无法摆脱许多现有的部分递归形式,因为我们希望可以完全选择可以编写的图算法。

Let’s take a basic graph problem like st-connectivity (the decision problem asking in a directed graph, if t is reachable from s). It is expressible via left recursion. But there are a lot of fundamental but non-trivial problems that are impossible to state, not even with linear recursion. That’s why full recursion is a must.

让我们来看一个基本的图问题,例如st-connectivity (如果t从s可以到达,则有向图中的决策问题)。 它可以通过左递归表示。 但是,存在许多根本但非平凡的问题,即使是线性递归也无法解决。 这就是为什么必须进行完全递归。

I think knowing about recursion is never enough, so if you agree to me, also read this or this, or come back to the first year of computer science and reread a brilliant book like this!

我想知道关于递归是远远不够的,所以如果你同意我,也看过这个或这或回来计算机科学的第一年,重读一本书灿烂像这样 !

2. Induction (no, it is not the recursion again… read also ingredient 2!)

2.归纳法(不,这不是递归……也请阅读成分2!)

A language, or if you want to be more informal and breezy, a system aiming at reasoning (on knowledge graphs) and that wants to be ready for probabilistic reasoning must be able to express non-ground inductive definitions [3,4].

一种语言,或者如果您想变得更加非正式和轻松,一个旨在推理(在知识图上)并且希望为概率推理做好准备的系统必须能够表达非地面归纳定义 [3,4]。

An inductive definition is a definition given in terms of itself, and it must be sound. There must be one or more non-recursive base cases + one or more recursive cases that eventually lead back to the base case.

归纳定义是根据本身给出的定义,它必须是合理的。 必须有一个或多个非递归基本案例+一个或多个最终递归回到基本案例的递归案例。

Very well-known examples of inductive definitions are the Fibonacci series and the factorial. Probably the plainest example of an inductive definition is transitive closure. If a system can’t even do a non-ground (only with the base case) transitive closure of a binary relation. And it is of the essence for reasoning since:

归纳定义的非常著名的例子是斐波那契数列和阶乘。 归纳定义的最简单的例子可能是传递闭包 。 如果系统甚至无法进行非地面操作(仅在基本情况下),则将暂时关闭二进制关系。 这是推理的关键,因为:

if a system can’t even work out a transitive closure, you can be sure it won’t help you with reasoning!

如果系统甚至无法计算出传递闭包,则可以确保它不会帮助您推理!

3. Semantics

3.语义学

The reasoning process must be traced back to a specific semantic, the ingredient that gives meaning to the intensional component and to query answers.

推理过程必须追溯到特定的语义,即赋予内涵成分和查询答案含义的成分。

You have a lot of different choices for semantics at your disposal, in this case, language semantics: stable-model semantics, well-founded semantics, least-model semantics, and all their variants, etc. They offer a more or less efficient reasoning process in terms of performance.

对于语义,您有许多不同的选择,在这种情况下,是语言语义:稳定模型语义,有充分根据的语义,最小模型语义及其所有变体等。它们提供了或多或少有效的推理性能方面的过程。

A reasonable choice, in this case, is the use of well-founded semantics.

在这种情况下,合理的选择是使用可靠的语义

Let’s take the answer to a conjunctive query. With the stable-model semantics, the construction of the solution needs to consider the facts appearing in all the possible interpretations that satisfy your intensional component and the query. On the contrary, in well-founded semantics, a correct answer to the query contains all the facts of whatever true interpretation. The saving is self-evident in terms of performance.

让我们来回答一个联合查询。 使用稳定模型语义,解决方案的构建需要考虑出现在满足您的内涵组件和查询的所有可能解释中的事实。 相反,在有充分根据的语义中,对查询的正确答案包含任何真实解释的所有事实。 就性能而言,节省是不言而喻的。

This and other theoretical underpinnings [5] are such that you can develop faster reasoners using well-founded semantics, and therefore it is a better choice!

这和其他理论基础[5]使得您可以使用良好的语义开发更快的推理机,因此这是一个更好的选择!

4. Ontological reasoning

4.本体论推理

We’re talking about reasoning ok, but it is a bit vague, which kind of reasoning? I would like to have a powerful version of reasoning, of course, one that allowed me to query my knowledge graph for having unexpected, new, and significant insights!

我们在说推理还可以,但是有点模糊,哪种推理? 当然,我想拥有一个强大的推理版本,该版本可以让我查询我的知识图谱以获取意外,新的和重要的见解!

So, at least we would like to have ontological reasoning that in philosophical terms can be seen as the ability of reasoning ‘on the existing’. While in mathematical terms implies the presence of specific operators like inclusion, universal and existential quantification, etc.

因此,至少我们希望有本体论推理,以哲学术语可以将其视为“对现有事物”进行推理的能力。 用数学术语表示存在特定的运算符,例如包含,通用和存在量化等。

In computer science, ontological reasoning is often made to correspond to the ability of a system to support SPARQL (to query language) under the reasoning rules, known as ‘entailment regime’, of OWL 2 QL profile (a complex of concepts and reasoning rules in a well-known language of the semantic web community).

在计算机科学中,本体推理往往对应作出一个系统的支持SPARQL(以查询语言)下的推理规则,被称为“蕴含政权”的能力OWL 2 QL轮廓 (一个复杂的概念和推理规则以语义网络社区的知名语言)。

This ‘profile’ is a kind of toolbox with all the essentials of reasoning: just think that it includes symmetric, reflexive, and irreflexive properties, disjoint properties or, simply define classes and sub-classes.

这种“轮廓”是具有推理所有基本要素的一种工具箱:只需认为它包含对称,自反和不自反特性,不相交的特性,或者简单地定义类和子类即可。

Ontological reasoning under this profile also offers excellent performance, with a nice trade-off between expressive power and computational complexity; for example, being in the AC0 complexity class when the query is assumed to be fixed.

在这种情况下,本体论推理还提供了出色的性能,在表达能力和计算复杂度之间取得了很好的折衷。 例如,假设查询是固定的,则属于AC0复杂度类。

制备: (Preparation:)

Image for post
Photo by Aarón Blanco Tejedor on Unsplash
照片由 AarónBlanco Tejedor 摄于 Unsplash

The four ingredients we just saw are for the basic recipe: reasoning. But for the advanced recipe, probabilistic reasoning, you will need the joint effort of the all ‘fabulous five’. You will need at least another crucial ingredient, THE FIFTH INGREDIENT: now, you must decide how you wish to manage uncertainty.

我们刚刚看到的四种成分是基本配方:推理。 但是对于高级配方 ,概率推理,您将需要所有“ 神话般的五个人”的共同努力。 您至少需要另一个关键成分, 第五种成分 :现在,您必须决定如何处理不确定性。

Scientists have conceived the most different approaches to cope with the most various situations involving imperfect or unknown information: probability theory, fuzzy logic, subjective logic, evidence theory, etc.

科学家已经构思出最不同的方法来应对涉及不完善或未知信息的大多数情况:概率论,模糊逻辑,主观逻辑,证据理论等。

If we keep it to the ground and refer to probability theory for uncertainty, what kind of models/systems can we use to perform probabilistic reasoning on KGs?

如果我们坚持到底,并参考概率论的不确定性, 我们可以使用哪种模型/系统对KG进行概率推理?

Well, a lot of people are working on probabilistic reasoning. So many people involved that there exist at least three main related research areas: probabilistic logic programming, probabilistic programming languages, and statistical relational learning.

好吧,很多人都在进行概率推理。 涉及的人员如此之多,至少存在三个主要的相关研究领域:概率逻辑编程,概率编程语言和统计关系学习。

It takes me a while just to dive into the different branches of science attempting to this goal. And definitely, a lot of time to truly understand what the heck the state of the art has to offer for probabilistic reasoning on knowledge graphs. And now I can report to you what I’ve found.

我花了一段时间才潜入尝试达到该目标的科学的不同分支。 无疑, 有很多时间才能真正了解知识图上的概率推理所能提供的最新技术。 现在,我可以向您报告所发现的内容。

PROBABILISTIC LOGIC PROGRAMMING is a group of very nice languages that allows you to define very compact and elegantly simple logic programs. More, they use Sato semantics, a straightforward and compact way to define semantics.

概率逻辑程序设计是一组非常好的语言,使您可以定义非常紧凑且优雅的简单逻辑程序。 另外,他们使用Sato语义,这是一种定义语义的简单明了的方法。

PROBABILISTIC PROGRAMMING LANGUAGES are elegant because they let you treat all the statistical distributions natively, and this is so attractive and comfortable for statisticians.

概率编程语言之所以优雅,是因为它们可让您本地处理所有统计分布,这对统计人员而言是如此诱人且舒适。

STATISTICAL RELATIONAL LEARNING allows us to use Probabilistic Graphical Models like Markov Logic Networks, so all competencies people have in a machine learning environment can be immediately put to use (for example, probabilistic inference in PGM). You can create PGMs that are very close to your reality of interest and model entities and relationships with minimal effort.

统计关系学习使我们可以使用概率图形模型(例如Markov Logic Networks),因此人们可以立即使用人们在机器学习环境中拥有的所有能力(例如,PGM中的概率推理)。 您可以轻松创建与现实情况非常接近的PGM,并为实体和关系建模。

All pleasant and positive points and no drawbacks! So, what should I go for?

所有令人愉快和积极的观点,没有缺点! 那么,我应该去做什么呢?

All these techniques have focused only on the fifth ingredient of the recipe: HOW TO MANAGE UNCERTAINTY. But they almost completely avoid the other four.

所有这些技术仅集中于配方的第五个成分:如何处理不确定性。 但是他们几乎完全避免了其他四个。

In other words, they provided a specific way to cope with uncertainty but without all the other fundamentals features for reasoning on knowledge graphs.

换句话说,它们提供了一种解决不确定性的特定方法,但没有在知识图上进行推理的所有其他基本原理。

They are not applicable to probabilistic reasoning on knowledge graphs.

它们不适用于知识图上的概率推理。

It is as if they studied and developed the best masala (the curry powder) for a curry recipe, forgetting the vegetables or the chicken or even the fire sometimes. How can you cook your curry then?

仿佛他们研究并开发出了最适合咖喱食谱的咖喱粉(咖喱粉),有时会忘记蔬菜,鸡肉甚至是火。 那你怎么煮咖喱呢?

Image for post
Image: Photo by Enrico Mantegazza on Unsplash
图片: Enrico Mantegazza在 Unsplash上 拍摄的照片

Having noted this, I have tried to provide my contribution to cooking probabilistic knowledge graphs, making an extra effort, studying what is necessary, and going to groceries for all the required ingredients. This is my curry recipe for probabilistic reasoning on knowledge graphs.

注意到这一点之后,我试图为烹饪概率知识图做出贡献,做出额外的努力,研究必要的知识,并为所有必需的食材提供食品杂货。 这是我在知识图上进行概率推理的咖喱食谱 。

I’m eager to listen to yours!

我很想听听你的!

结论 (CONCLUSIONS)

Without reasoning, knowledge graphs are half-cooked (read more about it here), and handling uncertainly for principled reasoning is paramount. Yet, there are five fundamentals for doing this, the ‘fabulous five’. They are full recursion, induction, semantics, ontological reasoning, and probability theory. More of the existing approaches neglect most of these fabulous five and focus only on one of these ‘ingredients’. Yet some attempts have been made: here there have been used all ‘fabulous five’.

如果不进行推理,知识图将被半熟( 在此处了解更多信息),并且对原则性推理进行不确定的处理至关重要。 然而,这样做有五个基本原则,即“ 神话般的五个”。 它们是完整的递归,归纳,语义,本体论推理和概率论。 现有的方法更多地忽略了这五个神话般的大部分,而仅关注这些“成分”之一。 然而,已经做了一些尝试: 这里使用了所有“ 神话般的五”

Follow me on Medium for more.

跟随我的中等更多。

Let’s keep in touch also on Linkedin!

让我们也保持联系Linkedin !

参考资料 (REFERENCES)

[1] L. Bellomarini et al., Knowledge Graphs and Enterprise AI: The Promise of an Enabling Technology (2019), ICDE

[1] L. Bellomarini等人,《 知识图谱和企业AI:实现技术的承诺》 (2019年),ICDE

[2] L. Bellomarini et al., Reasoning under Uncertainty in Knowledge Graphs (2020), RuleML+RR 2020

[2] L. Bellomarini等人, 知识图不确定性下的推理 (2020),RuleML + RR 2020

[3] D. Fierens et al., Inference and learning in probabilistic logic programming weighted boolean formulas (2015), Theory and Practice of Logic Programming

[3] D. Fierens等人, 概率逻辑编程加权布尔公式的推理和学习 (2015年),逻辑编程的理论与实践

[4] J. Lee and Y. Wang, Weighted rules under the stable model semantics (2016), KR. pp.145–154. AAAI Press

[4] J. Lee和Y. Wang, 稳定模型语义下的加权规则 (2016),KR。 第145–154页。 AAAI新闻

[5] M. Denecker, et al., Logic programming revisited: Logic programs as inductive definitions (2001), ACM Trans. Comput. Log.

[5] M. Denecker等人,“ 逻辑编程再探” :作为归纳定义的逻辑程序 (2001),ACM Trans。 计算 日志。

翻译自: https://towardsdatascience.com/probabilistic-reasoning-on-knowledge-graphs-d510269f5cf0

概率推理


http://www.taodudu.cc/news/show-8451757.html

相关文章:

  • 返回很目录是./还是../_...一切都很好
  • 如何在服务器响应请求,从数据库服务器得到响应后,如何响应前端请求?
  • node.js mysql orm_为什么你需要避免使用ORM(含Node.js示例)
  • 使用watch监听属性完成编辑时数据的回填
  • 【Pytorch Lighting】第 4 章:Lightning Flash 中的即食模型
  • 01字串变换
  • CSGO游戏搬砖老鸟给新手的一些建议
  • 敲黑板啦!CSGO游戏搬砖项目操作注意事项
  • 给csgo搬砖新手的十大建议
  • 给csgo游戏搬砖新手的十大建议
  • 如何评价当下的CSGO游戏搬砖市场,玩家们该何去何从?
  • CSGO游戏搬砖项目新手必看知识点汇总
  • 如何做csgo搬砖入门流程
  • python一直爬取网易商城(原生)
  • steam搬砖好做吗?
  • 关于悠悠有品疑似做空市场,我想说
  • AutoUU--有品租赁自动上架的开源轻量化工具--程序篇、(二)
  • CSGO搬砖:装备卖得好,一件装备多200+
  • bioinformatics小技巧
  • 计算机模拟细胞膜激酶的机理,科学网—JIPB│湖南大学于峰教授团队及其合作者揭示质膜蛋白激酶TMK4参与调控ABA信号途径的机制 - 闫宗运的博文...
  • 【DeepDTA模型解读】
  • BPS Bioscience高纯度PI3 kinase(p110α/p85α)重组蛋白
  • 优酷如何构建覆盖全网的播放白盒测试体系
  • 极品家丁—优酷全网独播喜剧
  • 使用Java生成Word
  • 面试指导笔记——投递篇
  • 应聘互联网公司,简历应该怎么写?
  • 统计学-logistic回归-小论文
  • 职业简历与健康病例 ,让别人更加了解你的途径,很重要!!!
  • 【177期】抛开硬实力,如何写简历才能帮你更快争取到面试机会?
  • 这篇关于概率推理_知识图上的概率推理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



    http://www.chinasem.cn/article/689972

    相关文章

    Java架构师知识体认识

    源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

    sqlite3 相关知识

    WAL 模式 VS 回滚模式 特性WAL 模式回滚模式(Rollback Journal)定义使用写前日志来记录变更。使用回滚日志来记录事务的所有修改。特点更高的并发性和性能;支持多读者和单写者。支持安全的事务回滚,但并发性较低。性能写入性能更好,尤其是读多写少的场景。写操作会造成较大的性能开销,尤其是在事务开始时。写入流程数据首先写入 WAL 文件,然后才从 WAL 刷新到主数据库。数据在开始

    hdu4865(概率DP)

    题意:已知前一天和今天的天气概率,某天的天气概率和叶子的潮湿程度的概率,n天叶子的湿度,求n天最有可能的天气情况。 思路:概率DP,dp[i][j]表示第i天天气为j的概率,状态转移如下:dp[i][j] = max(dp[i][j, dp[i-1][k]*table2[k][j]*table1[j][col] )  代码如下: #include <stdio.h>#include

    系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

    本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

    【Python知识宝库】上下文管理器与with语句:资源管理的优雅方式

    🎬 鸽芷咕:个人主页  🔥 个人专栏: 《C++干货基地》《粉丝福利》 ⛺️生活的理想,就是为了理想的生活! 文章目录 前言一、什么是上下文管理器?二、上下文管理器的实现三、使用内置上下文管理器四、使用`contextlib`模块五、总结 前言 在Python编程中,资源管理是一个重要的主题,尤其是在处理文件、网络连接和数据库

    dr 航迹推算 知识介绍

    DR(Dead Reckoning)航迹推算是一种在航海、航空、车辆导航等领域中广泛使用的技术,用于估算物体的位置。DR航迹推算主要通过已知的初始位置和运动参数(如速度、方向)来预测物体的当前位置。以下是 DR 航迹推算的详细知识介绍: 1. 基本概念 Dead Reckoning(DR): 定义:通过利用已知的当前位置、速度、方向和时间间隔,计算物体在下一时刻的位置。应用:用于导航和定位,

    【H2O2|全栈】Markdown | Md 笔记到底如何使用?【前端 · HTML前置知识】

    Markdown的一些杂谈 目录 Markdown的一些杂谈 前言 准备工作 认识.Md文件 为什么使用Md? 怎么使用Md? ​编辑 怎么看别人给我的Md文件? Md文件命令 切换模式 粗体、倾斜、下划线、删除线和荧光标记 分级标题 水平线 引用 无序和有序列表 ​编辑 任务清单 插入链接和图片 内嵌代码和代码块 表格 公式 其他 源代码 预

    PyInstaller问题解决 onnxruntime-gpu 使用GPU和CUDA加速模型推理

    前言 在模型推理时,需要使用GPU加速,相关的CUDA和CUDNN安装好后,通过onnxruntime-gpu实现。 直接运行python程序是正常使用GPU的,如果使用PyInstaller将.py文件打包为.exe,发现只能使用CPU推理了。 本文分析这个问题和提供解决方案,供大家参考。 问题分析——找不到ONNX Runtime GPU 动态库 首先直接运行python程序

    图神经网络(2)预备知识

    1. 图的基本概念         对于接触过数据结构和算法的读者来说,图并不是一个陌生的概念。一个图由一些顶点也称为节点和连接这些顶点的边组成。给定一个图G=(V,E),  其 中V={V1,V2,…,Vn}  是一个具有 n 个顶点的集合。 1.1邻接矩阵         我们用邻接矩阵A∈Rn×n表示顶点之间的连接关系。 如果顶点 vi和vj之间有连接,就表示(vi,vj)  组成了

    JAVA初级掌握的J2SE知识(二)和Java核心的API

    /** 这篇文章送给所有学习java的同学,请大家检验一下自己,不要自满,你们正在学习java的路上,你们要加油,蜕变是个痛苦的过程,忍受过后,才会蜕变! */ Java的核心API是非常庞大的,这给开发者来说带来了很大的方便,经常人有评论,java让程序员变傻。 但是一些内容我认为是必须掌握的,否则不可以熟练运用java,也不会使用就很难办了。 1、java.lang包下的80%以上的类