一文带你深入理解【Java基础】 · Java语言概述

写在前面


        Hello大家好, 我是【麟-小白】,一位软件工程专业的学生,喜好计算机知识。希望大家能够一起学习进步呀!本人是一名在读大学生,专业水平有限,如发现错误不足之处,请多多指正!谢谢大家!!!

        如果小哥哥小姐姐们对我的文章感兴趣,请不要吝啬你们的小手,多多点赞加关注呀!❤❤❤ 爱你们!!!


目录

写在前面

前言:

1.软件开发介绍

1.1 软件开发

1.2 人机交互方式

1.3 常用的Dos命令

1.4  常用快捷键

2.计算机编程语言介绍

2.1 什么是计算机语言

2.2 第一代语言

2.3 第二代语言

2.4 第三代语言:高级语言

3.Java语言概述

3.1 概述

3.2 Java简史

3.3Java技术体系平台

3.4 Java在各领域中的应用

3.5 Java语言的诞生

3.6 Java的主要特性

4.Java程序运行机制及运行过程

4.1 Java语言的特点

4.2 Java的两种核心机制

4.2.1 核心机制---Java虚拟机

4.2.2 核心机制---垃圾回收机制

5.开发体验---HelloWorld

5.1 编写

5.2 编译

5.3 运行

6.常见问题及解决办法

7.注释

小结第一个程序

8.良好的编程风格

结语


习题:【Java基础】 · 第1章 · Java语言概述习题总结

前言:

        1995年年底,Java语言在Internet舞台一亮相便名声大噪。原因在于它将有望成为连接用户与信息的万能胶,而不论这些信息来自Web服务器、数据库、信息提供商,还是任何其他可以想象的渠道。事实上,就发展前景而言,Java的地位是独一无二的。它是一种完全可信赖程序设计语言,并得到了广泛认可。其固有的可靠性安全性仅令Java程序员放心,也令使用Java程序的用户放心。Java内建了对网络编程、数据库连接和并发等高级程序设计任务的支持。


1.软件开发介绍


1.1 软件开发

  • 软件,即一系列按照一定顺序组织的计算机数据和指令的集合,有系统软件应用软件之分。

1.2 人机交互方式

  • 图形化界面(Graphical User Interface GUI):这种方式简单直观,使用者易于接受容易上手操作。
  • 命令行方式(Command Line Interface CLI):这种方式需要有一个控制台,输入特定的指令,让计算机完成一些操作。但这种方式较为复杂,需要记忆一些相关的指令。

1.3 常用的Dos命令

  • dir:列出当前目录下的文件和文件夹
  • md:创建目录
  • rd:删除目录
  • cd:进入指定目录
  • cd..:返回到上一级目录
  • cd\:退回到根目录
  • del:删除文件
  • exit:退出Dos命令行

1.4  常用快捷键

  • ←  →:移动光标
  • ↑  ↓:调阅历史操作命令
  • DeleteBackspace:删除字符

2.计算机编程语言介绍


2.1 什么是计算机语言

  • 语言:是人与人之间用于沟通的一种方式。例如:中国人与中国人用普通话沟通。而
        中国人要和英国人交流,就要学习英语。
  • 计算机语言:人与计算机交流的方式。
         如果人要与计算机交流,那么就要学习计算机语言。
        计算机语言有很多种。如:C,C++,C#,Java,PHP,Python,go等。

2.2 第一代语言

  • 机器语言指令以二进制代码形式存在。(...11011001001...)

2.3 第二代语言

  • 汇编语言使用助记符来表示一条机器指令(比第一代高级,但封装性不好)。


2.4 第三代语言:高级语言

  • CPascalFortran面向过程的语言
  •  C++面向过程/面向对象
  •  Java跨平台的纯面向对象的语言
  •  .NET跨语言的平台
  •  PythonScala

 


3.Java语言概述


3.1 概述

  • Java是SUN(Stanford University Network,斯坦福大学网络公司 ) 1995年推出的一门高级编程语言。
  • Java是一种面向Internet的编程语言。Java一开始富有吸引力是因为Java程序可以在Web浏览器中运行。这些Java程序被称Java小程序(applet)。applet使用现代的图形用户界面与Web用户进行交互。 applet内嵌在HTML代码中。
  • 随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。

3.2 Java简史

  • 1991年, Green项目,开发语言最初命名为Oak (橡树)
  • 1994年,开发组意识到Oak 非常适合于互联网
  • 1996年,发布JDK 1.0,约8.3万个网页应用Java技术来制作
  • 1997年,发布JDK 1.1JavaOne会议召开,创当时全球同类会议规模之最
  • 1998年,发布JDK 1.2,同年发布企业平台J2EE
  • 1999年,Java分成J2SEJ2EEJ2MEJSP/Servlet技术诞生
  • 2004年,发布里程碑式版本:JDK 1.5,为突出此版本的重要性,更名为JDK 5.0
  • 2005年,J2SE -> JavaSEJ2EE -> JavaEEJ2ME -> JavaME
  • 2009年,Oracle公司收购SUN,交易价格74亿美元
  • 2011年,发布JDK 7.0
  • 2014年,发布JDK 8.0,是继JDK 5.0以来变化最大的版本
  • 2017年,发布JDK 9.0,最大限度实现模块化
  • 20183月,发布JDK 10.0,版本号也称为18.3
  • 20189月,发布JDK 11.0,版本号也称为18.9
  • 2019年2月,Java 12 发布
  • 2019年9月,Java 13 发布
  • 2020 年3月17日,Java 14 发布。
  • 2020 年9月15日,Java 15 发布。
  • 2021 年3月16日,Java SE 16 发布。
  • 2021 年9月14日,Java SE 17 LTS 发布。

3.3Java技术体系平台

Java SE(Java Standerd Edition)标准版
支持面向 桌面级应用 (如 Windows 下的应用程序)的 Java 平台,提供了完整的 Java 核心API ,此版本以前称为 J2SE
Java EE(Java Enterprise Edition)企业版
是为 开发企业环境下的应用程序 提供的一套解决方案。该技术体系中包含的技术如:Servlet 、 Jsp 等,主要针对于 Web 应用程序开发。版本以前称为 J2EE
Java ME(Java Micro Edition) 小型版
支持Java 程序运行在 移动终端 (手机、 PDA )上的平台,对 Java API 有所精简,并加入了针对移动终端的支持,此版本以前称为J2ME
Java Card
支持一些Java 小程序( Applets )运行在 小内存设备 (如智能卡)上的平台

3.4 Java在各领域中的应用

        从Java的应用领域来分,Java语言的应用方向主要表现在以下几个方面:

  • 企业级应用:主要指复杂的大企业的软件系统、各种类型的网站。Java的安全机制以及 它的跨平台的优势,使它在分布式系统领域开发中有广泛应用。应用领域包括金融、电 信、交通、电子商务等。
  • Android平台应用Android应用程序大多使用Java语言编写Android开发水平的高低很大程度上取决于Java语言核心能力是否扎实。
  • 大数据平台开发:各类框架有Hadoopsparkstormflink等,就这类技术生态圈来讲,还有各种中间件如flumekafkasqoop等等 ,这些框架以及工具大多数是用Java编写而成,但提供诸如JavascalaPythonR等各种语言API供编程。
  • 移动领域应用:主要表现在消费和嵌入式领域,是指在各种小型设备上的应用,包括手 机、PDA、机顶盒、汽车通信设备等。

3.5 Java语言的诞生

         java之父 James Gosling 团队在开发 ”Green” 项目时,发现 C 缺少垃圾回收系统,还有可移植的安全性、分布程序设计和多线程功能。最后,他们想要一种 易于移植 到各种设备上的平台。
        Java确实是从 C 语言和 C++ 语言继承了许多成份,甚至可以将 Java 看成是 类C语言 发展和衍生的产物。比如 Java 语言的变量声明,操作符形式,参数传递,流程控制等方面和C 语言、 C++ 语言完全相同。但同时,Java 是一个 纯粹的面向对象 的程序设计语言,它继承了 C++ 语言 面向对象 技术的核心。Java舍弃了C语言中容易引起错误的指针 (以引用取代)、运算符重载(operator overloading )、多重继承(以接口取代)等特性,增加了垃圾回收器功能 用于回收不再被引用的对象所占据的内存空间。JDK1.5 又引入了 泛型编程 Generic
Programming )、 类型安全的枚举 不定长参数和自动装/拆箱

3.6 Java的主要特性

  • Java语言是易学的Java语言的语法与C语言和C++语言很接近,使得大多数程序员很容易学习和使用Java
  • Java语言是强制面向对象的Java语言提供类、接口和继承等原语,为了简单起见,只支持类之间的单继承,但支持接口之间的多继承,并支持类与接口之间的实现机制(关键字为implements)。
  • Java语言是分布式的Java语言支持Internet应用的开发,在基本的Java应用编程接口中有一个网络应用编程接口(java net),它提供了用于网络应用编程的类库,包括URLURLConnectionSocketServerSocket等。JavaRMI(远程方法激活)机制也是开发分布式应用的重要手段。
  • Java语言是健壮的。Java的强类型机制、异常处理、垃圾的自动收集等是Java程序健壮性的重要保证。对指针的丢弃是Java的明智选择。
  • Java语言是安全的。Java通常被用在网络环境中,为此,Java提供了一个安全机制以防恶意代码的攻击。如:安全防范机制(类ClassLoader),如分配不同的名字空间以防替代本地的同名类、字节代码检查。
  • Java语言是体系结构中立的。Java程序(后缀为java的文件)在Java平台上被编译为体系结构中立的字节码格式(后缀为class的文件),然后可以在实现这个Java平台的任何系统中运行。
  • Java语言是解释型的。如前所述,Java程序在Java平台上被编译为字节码格式,然后可以在实现这个Java平台的任何系统的解释器中运行。
  • Java是性能略高的。与那些解释型的高级脚本语言相比,Java的性能还是较优的。
  • Java语言是原生支持多线程的。Java语言中,线程是一种特殊的对象,它必须Thread类或其子(孙)类来创建。

4.Java程序运行机制及运行过程


4.1 Java语言的特点

  • 特点一:面向对象
  • 两个基本概念:类、对象
  • 三大特性:封装、继承、多态
  • 特点二:健壮性
  • 吸收了C/C++语言的优点,但去掉了其影响程序健壮性的部分(如指针、内存的申请与释放等),提供了一个相对安全的内存管理和访问机制
  • 特点三:跨平台性
  • 跨平台性:通过Java语言编写的应用程序在不同的系统平台上都可以运行。Write once , Run Anywhere

        因为有了JVM ,同一个 Java 程序在三个不同的操作系统中都可以执行。这
样就实现了 Java 程序的跨平台性。
  • 原理:只要在需要运行 java 应用程序的操作系统上,先安装一个Java虚拟机JVM (Java Virtual Machine) 即可。由JVM来负责Java程序在该系统中的运行。

4.2 Java的两种核心机制

  • Java虚拟机 (Java Virtal Machine)
  • 垃圾收集机制 (Garbage Collection)

4.2.1 核心机制---Java虚拟机

  • JVM是一个虚拟的计算机,具有指令集并使用不同的存储区域。负责执行指令,管理数据、内存、寄存器
  • 对于不同的平台,有不同的虚拟机。
  • 只有某平台提供了对应的java虚拟机,java程序才可在此平台运行
  • Java虚拟机机制屏蔽了底层运行平台的差别,实现了“一次编译,到处运行”

4.2.2 核心机制---垃圾回收机制

  • 不再使用的内存空间应回收—— 垃圾回收。
  • C/C++等语言中,由程序员负责回收无用内存。
  • Java 语言消除了程序员回收无用内存空间的责任:它提供一种系统级线程跟踪存储空 间的分配情况。并在JVM空闲时,检查并释放那些可被释放的存储空间。
  • 垃圾回收在Java程序运行过程中自动进行,程序员无法精确控制和干预。

4.3 JDK,JRE,JVM之间的关系


5.开发体验---HelloWorld


步骤:
  • Java 代码编写到扩展名为 .java 的文件中。
  • 通过 javac 命令对该 java 文件进行编译
  • 通过 java 命令对生成的 class 文件进行运行


5.1 编写

        选择最简单的编 辑器: 记事本 。 敲入代码 class Test{ } 将文件保存成 Test.java ,这个
文件是存放 java 代码的文件, 称为源文件。
        第一个Java 程序:
public class Test{
    public static void main(String[] args) {
        System.out.println(“Hello World!”);
    }
}

5.2 编译

  • 有了java源文件,通过编译器将其编译成JVM可以识别的字节码文件。
  • 在该源文件目录下,通过javac编译工具对Test.java文件进行编译。
  • 如果程序没有错误,没有任何提示,但在当前目录下会出现一个Test.class件,该文件称为字节码文件,也是可以执行的java的程序。


5.3 运行

        有了可执行的java 程序 ( Test.class字节码文件 ) ,通过运行工具java.exe 对字节码文件进行执行。 出现提示:缺少一个名称为main 的方法。

        因为一个程序的执行需要一个起始点或者入口,所以在Test 类中的加入 public static void
main(String[] args){ } 对修改后的Test.java 源文件需要重新编译,生成新的 class 文件后,再进行执行。发现没有编译失败,但也没有任何效果,因为并没有告诉JVM 要帮我们做什么事情,也就是没有可以具体执行的语句。
        想要和JVM 来个互动,只要在 main 方法中加入一句 System.out.println(“Hello World"); 因为程序进行改动,所以再重新编译,运行即可。


6.常见问题及解决办法


  • 源文件名不存在或者写错
  • 当前路径错误
  • 后缀名隐藏问题
  • 类文件名写错,尤其文件名与类名不一致时,要小心类文件不在当前路径下,或者不在classpath指定路径下

  •  声明为public的类应与文件名一致,否知编译失败

  • 编译失败,注意错误出现的行数,再到源代码中指定位置改错

总结:
        学习编程最容易犯的错是 语法错误 Java 要求你必须按照语法规则编写代码。如果你的程序违反了语法规则,例如:忘记了分号、大括号、引号,或者拼错了单词,java 编译器都会报语法错误。 尝试着去看懂编译器会报告的错误信息。

7.注释


  • 用于注解说明解释程序的文字就是注释。
  • Java中的注释类型:
    • 单行注释
    • 多行注释
    • 文档注释 (java特有)
  • 提高了代码的阅读性;调试程序的重要方法。
  • 注释是一个程序员必须要具有的良好编程习惯。
  • 将自己的思想通过注释先整理出来,再用代码去体现

  • 单行注释
    • 格式: //注释文字
  • 多行注释
    • 格式: /* 注释文字 */

        注:        

  • 对于单行和多行注释,被注释的文字,不会被JVMjava虚拟机)解释执行。多行注释里面不允许有多行注释嵌套。
  • 文档注释(Java特有)
    • 格式:/**
    • @author 指定java程序的作者
    • @version 指定源文件的版本
    • */
  • 注释内容可以被JDK提供的工具 javadoc 所解析,生成一套以网页文件形式体现的该程序的说明文档。
  • 操作方式


小结第一个程序

  • Java源文件以“java”为扩展名。源文件的基本组成部分是类(class),如本例中的HelloWorld类。
  • Java应用程序的执行入口是main()方法。它有固定的书写格式:
    • public static void main(String[] args) {...}
  • Java语言严格区分大小写。
  • Java方法由一条条语句构成,每个语句以“;”结束。
  • 大括号都是成对出现的,缺一不可。
  • 一个源文件中最多只能有一个public类。其它类的个数不限,如果源文件包含一个public类,则文件名必须按该类名命名。

8.良好的编程风格


  • 正确的注释和注释风格
  • 使用文档注释来注释整个类或整个方法。
  • 如果注释方法中的某一个步骤,使用单行或多行注释。
  • 正确的缩进和空白
  • 使用一次tab操作,实现缩进
  • 运算符两边习惯性各加一个空格。比如:2 + 4 * 5
  • 块的风格
  • Java API 源代码选择了行尾风格


结语


本人会持续更新文章的哦!希望大家一键三连,你们的鼓励就是作者不断更新的动力

  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
Spark是一个快速通用的集群计算框架,它可以处理大规模数据,并且具有高效的内存计算能力。Spark可以用于各种计算任务,包括批处理、流处理、机器学习等。本文将你了解Spark计算框架的基本概念和使用方法。 一、Spark基础概念 1. RDD RDD(Resilient Distributed Datasets)是Spark的基本数据结构,它是一个分布式的、可容错的、不可变的数据集合。RDD可以从Hadoop、本地文件系统等数据源中读取数据,并且可以通过多个转换操作(如map、filter、reduce等)进行处理。RDD也可以被持久化到内存中,以便下次使用。 2. Spark应用程序 Spark应用程序是由一个驱动程序和多个执行程序组成的分布式计算应用程序。驱动程序是应用程序的主要入口点,它通常位于用户的本地计算机上,驱动程序负责将应用程序分发到执行程序上并收集结果。执行程序是运行在集群节点上的计算单元,它们负责执行驱动程序分配给它们的任务。 3. Spark集群管理器 Spark集群管理器负责管理Spark应用程序在集群中的运行。Spark支持多种集群管理器,包括Standalone、YARN、Mesos等。 二、Spark计算框架使用方法 1. 安装Spark 首先需要安装Spark,可以从Spark官网下载并解压缩Spark安装包。 2. 编写Spark应用程序 编写Spark应用程序通常需要使用Java、Scala或Python编程语言。以下是一个简单的Java代码示例,用于统计文本文件中单词的出现次数: ```java import org.apache.spark.SparkConf; import org.apache.spark.api.java.JavaRDD; import org.apache.spark.api.java.JavaSparkContext; import java.util.Arrays; import java.util.Map; public class WordCount { public static void main(String[] args) { SparkConf conf = new SparkConf().setAppName("WordCount").setMaster("local"); JavaSparkContext sc = new JavaSparkContext(conf); JavaRDD<String> lines = sc.textFile("input.txt"); JavaRDD<String> words = lines.flatMap(line -> Arrays.asList(line.split(" ")).iterator()); Map<String, Long> wordCounts = words.countByValue(); for (Map.Entry<String, Long> entry : wordCounts.entrySet()) { System.out.println(entry.getKey() + " : " + entry.getValue()); } sc.stop(); } } ``` 3. 运行Spark应用程序 将编写好的Spark应用程序打包成jar包,并通过以下命令运行: ```bash spark-submit --class WordCount /path/to/wordcount.jar input.txt ``` 其中,--class参数指定应用程序的主类,后面跟上打包好的jar包路径,input.txt是输入文件的路径。 4. 查看运行结果 Spark应用程序运行完毕后,可以查看应用程序的输出结果,例如上述示例中的单词出现次数。 以上就是Spark计算框架的基本概念和使用方法。通过学习Spark,我们可以更好地处理大规模数据,并且提高计算效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

麟-小白

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

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

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

打赏作者

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

抵扣说明:

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

余额充值