Java语言框架

甲骨文公司2023年11月30日
35469阅读

作品详情

简单性

Java看起来设计得很像C++,但是为了使语言小和容易熟悉,设计者们把C++语言中许多可用的特征去掉了,这些特征是一般程序员很少使用的。例如,Java不支持goto语句,代之以提供break和cotiue语句以及异常处理。Java还剔除了C++的操作符过载(overload)和多继承特征,并且不使用主文件,免去了预处理程序。因为Java没有结构,数组和串都是对象,所以不需要指针。Java能够自动处理对象的引用和间接引用,实现自动的无用单元收集,使用户不必为存储管理问题烦恼,能更多的时间和精力花在研发上。

面向对象

Java是一个面向对象的语言。对程序员来说,这意味着要注意其中的数据和操纵数据的方法(method),而不是严格地用过程来思考。在一个面向对象的系统中,类(class)是数据和操作数据的方法的集合。数据和方法一起描述对象(object)的状态和行为。每一对象是其状态和行为的封装。类是按一定体系和层次安排的,使得子类可以从超类继承行为。在这个类层次体系中有一个根类,它是具有一般行为的类。Java程序是用类来组织的。

Java还包括一个类的扩展集合,分别组成各种程序包(Package),用户可以在自己的程序中使用。例如,Java提供产生图形用户接口部件的类(java.awt包),这里awt是抽象窗口工具集(abstract widowig toolkit)的缩写,处理输入输出的类(java.io包)和支持网络功能的类(java.et包)。

分布性

Java设计成支持在网络上应用,它是分布式语言。Java既支持各种层次的网络连接,又以Socket类支持可靠的流(stream)网络连接,所以用户可以产生分布式的客户机和服务器。

网络变成软件应用的分布运载工具。Java程序只要编写一次,就可到处运行。

编译和解释性

Java编译程序生成字节码(byte-code),而不是通常的机器码。Java字节码提供对体系结构中性的目标文件格式,代码设计成可有效地传送程序到多个平台。Java程序可以在任何实现了Java解释程序和运行系统(ru-time system)的系统上运行。

在一个解释性的环境中,程序开发的标准“链接”阶段大大消失了。如果说Java还有一个链接阶段,它只是把新类装进环境的过程,它是增量式的、轻量级的过程。因此,Java支持快速原型和容易试验,它将导致快速程序开发。这是一个与传统的、耗时的“编译、链接和测试”形成鲜明对比的精巧的开发过程。

稳健性

Java原来是用作编写消费类家用电子产品软件的语言,所以它是被设计成写高可靠和稳健软件的。Java消除了某些编程错误,使得用它写可靠软件相当容易。

Java是一个强类型语言,它允许扩展编译时检查潜在类型不匹配问题的功能。Java要求显式的方法声明,它不支持C风格的隐式声明。这些严格的要求保证编译程序能捕捉调用错误,这就导致更可靠的程序。

可靠性方面最重要的增强之一是Java的存储模型。Java不支持指针,它消除重写存储和讹误数据的可能性。类似地,Java自动的“无用单元收集”预防存储漏泄和其它有关动态存储分配和解除分配的有害错误。Java解释程序也执行许多运行时的检查,诸如验证所有数组和串访问是否在界限之内。

异常处理是Java中使得程序更稳健的另一个特征。异常是某种类似于错误的异常条件出现的信号。使用try/catch/fially语句,程序员可以找到出错的处理代码,这就简化了出错处理和恢复的任务。

安全性

Java的存储分配模型是它防御恶意代码的主要方法之一。Java没有指针,所以程序员不能得到隐蔽起来的内幕和伪造指针去指向存储器。更重要的是,Java编译程序不处理存储安排决策,所以程序员不能通过查看声明去猜测类的实际存储安排。编译的Java代码中的存储引用在运行时由Java解释程序决定实际存储地址。

Java运行系统使用字节码验证过程来保证装载到网络上的代码不违背任何Java语言限制。这个安全机制部分包括类如何从网上装载。例如,装载的类是放在分开的名字空间而不是局部类,预防恶意的小应用程序用它自己的版本来代替标准Java类。

可移植性

Java使得语言声明不依赖于实现的方面。例如,Java显式说明每个基本数据类型的大小和它的运算行为(这些数据类型由Java语法描述)。

Java环境本身对新的硬件平台和操作系统是可移植的。Java编译程序也用Java编写,而Java运行系统用ANSIC语言编写。

高性能

Java是一种先编译后解释的语言,所以它不如全编译性语言快。但是有些情况下性能是很要紧的,为了支持这些情况,Java设计者制作了“及时”编译程序,它能在运行时把Java字节码翻译成特定CPU(中央处理器)的机器代码,也就是实现全编译了。

Java字节码格式设计时考虑到这些“及时”编译程序的需要,所以生成机器代码的过程相当简单,它能产生相当好的代码。

多线程性

Java是多线程语言,它提供支持多线程的执行(也称为轻便过程),能处理不同任务,使具有线程的程序设计很容易。Java的lag包提供一个Thread类,它支持开始线程、运行线程、停止线程和检查线程状态的方法。

Java的线程支持也包括一组同步原语。这些原语是基于监督程序和条件变量风范,由C.A.R.Haore开发的广泛使用的同步化方案。用关键词sychroized,程序员可以说明某些方法在一个类中不能并发地运行。这些方法在监督程序控制之下,确保变量维持在一个一致的状态。

动态性

Java语言设计成适应于变化的环境,它是一个动态的语言。例如,Java中的类是根据需要载入的,甚至有些是通过网络获取的。

功能介绍

java是1995年由Sun公司推出一门面向对象的编程语言。[1]Java具有简单性、面向对象、分布式等特点,可以编写桌面应用程序、Web应用程序、分布式系统和嵌入式系统应用程序等。[1]

声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态
案例
项目介绍: wms是日日顺物流的核心仓储管理系统,承接天猫,海尔商城,社会化等订单,实现了物流出入库作业,库存管理,盘点等仓储 作业,完善了企业的仓储信息管理。系统双11峰值日订单量达50万+, 入库接单接口性能TPS=2万+,出库接单接口性能TPS=1.2 万+ 技术架构: 1. spring boot架构,shiro权限框架 2. dubbo微服务 3. 接单等较大并发交互采用mq队列 4. 数据库采用分库策略每个中心一个schema 5. 订单出入库与日日顺oms系统对接,入库采用dubbo直连,出库考虑大促流量峰值采用mq异步消费 我的工作: 1.负责wms仓储系统的接单,出入库,
3980mysqlrocketmqdubbooracle物流
系统简介: 1. 提供竞价运力服务的平台。调度通过平台发布竞价货源,司机通过平台报价 2. 支持外部运力资源接入,如:满帮、福佑系统 3. 实现确定竞价货源后下单到网络货运平台 技术架构: 1. 前端采用日日顺统一i56开发平台,i56请求调运系统的服务时需要携带 jwt 信息,统一进入调运系统的 web 模块 2. 外部系统请求服务统一进入日日顺系统的网关服务,经路由转发后进入调运系统服务分发模块,需要验证签名,时间戳等 3. 后端架构为spring cloud框架,注册中心为nacos,配置中心为nacos config,网关为日日顺统一网关,数据库为mysql 4. 调运系统底层服务为
3450mysqlspringcloudrocketmq物流
1.云集社交零售电商平台是一个基于微服务分布式部署的SAAS系统,系统实现了完整的供应链所有环节,以及商城的下单到发货的所有功能,且系统有着真实的数据考验,2018年销售额达到200多亿。系统的主要模块包括:基础资料,商城库存,订单中心,支付中心,仓储库存,物流追踪,供应商入驻,仓库货物盘点调拨等。 2.我当时所负责的模块是仓储库存中心服务,作为库存中心的负责人,我亲手架构并实现了库存服务的大部分核心功能,为了满足活动大促所产生的爆炸式流量,我采用了redis+lua的方式实现对库存的增减,然后采用mq的方式把库存同步到DB,库存中心经历了真实的大并发数据考验,QPS可达到10000以上。
920vue社交电商
项目介绍: 实现了车货匹配,对标运满满、货拉拉行业龙头。打通货物运输的各节点数据,提升运输组织效率,通过提供运力服务、货源支持、车后生态等一站式物流解决方案及车后管家增值服务,为货主企业和司机用户赋能,助力行业降本增效 我的工作: 1. 需求评审,研发任务分解,日常研发进度质量管控。例如:光大银行,则一系统对接,直管到车等重大模块需求开发均按时保证 质量上线使用 2. code review,核心代码开发,升级改造。例如:抛账管理,则一对接,上市安全整改等重要任务的开发与优化 3. 处理日常线上紧急问题。如系统卡慢,cpu 过高,内存溢出,个别接口响应超时等 4. 实现系统部署由虚
4500vuemysqlredisspringcloudweb物流
项目名称: 湖仓一体化 开发架构: CDH+hadoop+hive+iceberg+flink+kafka+springboot+ES+mysql 项目描述:由于离线用户画像和指标统计,隔日才能看到报表数据,运营部门提出需求希望可以实时查看报表数据,实时通过技术手段调整运营策略和方式并触达用户,实现用户的快速增长和产品付费人数的增长,为公司带来业绩;同时营销部门也希望通过用户画像和数据分析,优化广告投放渠道,提高投入产出。以及数据分析人员需要即时OLAP分析,随时获取想要的统计分析数据。 系统实现:需求
1860springbootkafka大数据
当前共19334个项目

评论