首页编程java编程java什么叫异步任务?Java 怎么在Main函数中,执行完异步任务后才退出主线程

java什么叫异步任务?Java 怎么在Main函数中,执行完异步任务后才退出主线程

编程之家 2023-10-14 112次浏览

大家好,今天给各位分享java什么叫异步任务的一些知识,其中也会对Java 怎么在Main函数中,执行完异步任务后才退出主线程进行解释,文章篇幅可能偏长,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在就马上开始吧!

java什么叫异步任务?Java 怎么在Main函数中,执行完异步任务后才退出主线程

做Java开发都需要学什么怎么学

以下介绍的课程主要针对零基础大数据工程师每个阶段进行通俗易懂简易介绍,方面大家更好的了解大数据学习课程。课程框架是科多大数据的零基础大数据工程师课程。

一、第一阶段:静态网页基础(HTMLCSS)

1.难易程度:一颗星

java什么叫异步任务?Java 怎么在Main函数中,执行完异步任务后才退出主线程

2.课时量(技术知识点阶段项目任务综合能力)

3.主要技术包括:html常用标签、CSS常见布局、样式、定位等、静态页面的设计制作方式等

4.描述如下:

java什么叫异步任务?Java 怎么在Main函数中,执行完异步任务后才退出主线程

从技术层面来说,该阶段使用的技术代码很简单、易于学习、方便理解。从后期课程层来说,因为我们重点是大数据,但前期需要锻炼编程技术与思维。经过我们多年开发和授课的项目经理分析,满足这两点,目前市场上最好理解和掌握的技术是J2EE,但J2EE又离不开页面技术。所以第一阶段我们的重点是页面技术。采用市场上主流的HTMlCSS。

二、第二阶段:JavaSEJavaWeb

1.难易程度:两颗星

2.课时量(技术知识点阶段项目任务综合能力)

3.主要技术包括:java基础语法、java面向对象(类、对象、封装、继承、多态、抽象类、接口、常见类、内部类、常见修饰符等)、异常、集合、文件、IO、MYSQL(基本SQL语句操作、多表查询、子查询、存储过程、事务、分布式事务)JDBC、线程、反射、Socket编程、枚举、泛型、设计模式

4.描述如下:

称为Java基础,由浅入深的技术点、真实商业项目模块分析、多种存储方式的设计

与实现。该阶段是前四个阶段最最重要的阶段,因为后面所有阶段的都要基于此阶段,也是学习大数据紧密度最高的阶段。本阶段将第一次接触团队开发、产出具有前后台(第一阶段技术第二阶段的技术综合应用)的真实项目。

三、第三阶段:前端框架

1.难易程序:两星

2.课时量(技术知识点阶段项目任务综合能力):64课时

3.主要技术包括:Java、Jquery、注解反射一起使用,XML以及XML解析、解析dom4j、jxab、jdk8.0新特性、SVN、Maven、easyui

4.描述如下:

前两个阶段的基础上化静为动,可以实现让我们网页内容更加的丰富,当然如果从市场人员层面来说,有专业的前端设计人员,我们设计本阶段的目标在于前端的技术可以更直观的锻炼人的思维和设计能力。同时我们也将第二阶段的高级特性融入到本阶段。使学习者更上一层楼。

四、第四阶段:企业级开发框架

1.难易程序:三颗星

2.课时量(技术知识点阶段项目任务综合能力)

3.主要技术包括:Hibernate、Spring、SpringMVC、log4jslf4j整合、myBatis、struts2、Shiro、redis、流程引擎activity,爬虫技术nutch,lucene,、Tomcat集群和热备、MySQL读写分离

4.描述如下:

如果将整个JAVA课程比作一个糕点店,那前面三个阶段可以做出一个武大郎烧饼(因为是纯手工-太麻烦),而学习框架是可以开一个星巴克(高科技设备-省时省力)。从J2EE开发工程师的任职要求来说,该阶段所用到的技术是必须掌握,而我们所授的课程是高于市场(市场上主流三大框架,我们进行七大框架技术传授)、而且有真实的商业项目驱动。需求文档、概要设计、详细设计、源码测试、部署、安装手册等都会进行讲解。

五、第五阶段:初识大数据

1.难易程度:三颗星

2.课时量(技术知识点阶段项目任务综合能力)

3.主要技术包括:大数据前篇(什么是大数据,应用场景,如何学习大数据库,虚拟机概念和安装等)、Linux常见命令(文件管理、系统管理、磁盘管理)、LinuxShell编程(SHELL变量、循环控制、应用)、Hadoop入门(Hadoop组成、单机版环境、目录结构、HDFS界面、MR界面、简单的SHELL、java访问hadoop)、HDFS(简介、SHELL、IDEA开发工具使用、全分布式集群搭建)、MapRece应用(中间计算过程、Java操作MapRece、程序运行、日志监控)、Hadoop高级应用(YARN框架介绍、配置项与优化、CDH简介、环境搭建)、扩展(MAP端优化,COMBINER使用方法见,TOPK,SQOOP导出,其它虚拟机VM的快照,权限管理命令,AWK与SED命令)

4.描述如下:

该阶段设计是为了让新人能够对大数据有一个相对的大概念怎么相对呢?在前置课程JAVA的学习过后能够理解程序在单机的电脑上是如何运行的。现在,大数据呢?大数据是将程序运行在大规模机器的集群中处理。大数据当然是要处理数据,所以同样,数据的存储从单机存储变为多机器大规模的集群存储。

(你问我什么是集群?好,我有一大锅饭,我一个人可以吃完,但是要很久,现在我叫大家一起吃。一个人的时候叫人,人多了呢?是不是叫人群啊!)

那么大数据可以初略的分为:大数据存储和大数据处理所以在这个阶段中呢,我们课程设计了大数据的标准:HADOOP大数据的运行呢并不是在咋们经常使用的WINDOWS7或者W10上面,而是现在使用最广泛的系统:LINUX。

六、第六阶段:大数据数据库

1.难易程度:四颗星

2.课时量(技术知识点阶段项目任务综合能力)

3.主要技术包括:Hive入门(Hive简介、Hive使用场景、环境搭建、架构说明、工作机制)、HiveShell编程(建表、查询语句、分区与分桶、索引管理和视图)、Hive高级应用(DISTINCT实现、groupby、join、sql转化原理、java编程、配置和优化)、hbase入门、HbaseSHELL编程(DDL、DML、Java操作建表、查询、压缩、过滤器)、细说Hbase模块(REGION、HREGIONSERVER、HMASTER、ZOOKEEPER简介、ZOOKEEPER配置、Hbase与Zookeeper集成)、HBASE高级特性(读写流程、数据模型、模式设计读写热点、优化与配置)

4.描述如下:

该阶段设计是为了让大家在理解大数据如何处理大规模的数据的同时。简化咋们的编写程序时间,同时提高读取速度。

怎么简化呢?在第一阶段中,如果需要进行复杂的业务关联与数据挖掘,自行编写MR程序是非常繁杂的。所以在这一阶段中我们引入了HIVE,大数据中的数据仓库。这里有一个关键字,数据仓库。我知道你要问我,所以我先说,数据仓库呢用来做数据挖掘分析的,通常是一个超大的数据中心,存储这些数据的呢,一般为ORACLE,DB2,等大型数据库,这些数据库通常用作实时的在线业务。

总之,要基于数据仓库分析数据呢速度是相对较慢的。但是方便在于只要熟悉SQL,学习起来相对简单,而HIVE呢就是这样一种工具,基于大数据的SQL查询工具,这一阶段呢还包括HBASE,它为大数据里面的数据库。纳闷了,不是学了一种叫做HIVE的数据“仓库”了么?HIVE是基于MR的所以查询起来相当慢,HBASE呢基于大数据可以做到实时的数据查询。一个主分析,另一个主查询

七、第七阶段:实时数据采集

1.难易程序:四颗星

2.课时量(技术知识点阶段项目任务综合能力)

3.主要技术包括:Flume日志采集,KAFKA入门(消息队列、应用场景、集群搭建)、KAFKA详解(分区、主题、接受者、发送者、与ZOOKEEPER集成、Shell开发、Shell调试)、KAFKA高级使用(java开发、主要配置、优化项目)、数据可视化(图形与图表介绍、CHARTS工具分类、柱状图与饼图、3D图与地图)、STORM入门(设计思想、应用场景、处理过程、集群安装)、STROM开发(STROMMVN开发、编写STORM本地程序)、STORM进阶(java开发、主要配置、优化项目)、KAFKA异步发送与批量发送时效,KAFKA全局消息有序,STORM多并发优化

4.描述如下:

前面的阶段数据来源是基于已经存在的大规模数据集来做的,数据处理与分析过后的结果是存在一定延时的,通常处理的数据为前一天的数据。

举例场景:网站防盗链,客户账户异常,实时征信,遇到这些场景基于前一天的数据分析出来过后呢?是否太晚了。所以在本阶段中我们引入了实时的数据采集与分析。主要包括了:FLUME实时数据采集,采集的来源支持非常广泛,KAFKA数据数据接收与发送,STORM实时数据处理,数据处理秒级别

八、第八阶段:SPARK数据分析

1.难易程序:五颗星

2.课时量(技术知识点阶段项目任务综合能力)

3.主要技术包括:SCALA入门(数据类型、运算符、控制语句、基础函数)、SCALA进阶(数据结构、类、对象、特质、模式匹配、正则表达式)、SCALA高级使用(高阶函数、科里函数、偏函数、尾迭代、自带高阶函数等)、SPARK入门(环境搭建、基础结构、运行模式)、Spark数据集与编程模型、SPARKSQL、SPARK进阶(DATAFRAME、DATASET、SPARKSTREAMING原理、SPARKSTREAMING支持源、集成KAFKA与SOCKET、编程模型)、SPARK高级编程(Spark-GraphX、Spark-Mllib机器学习)、SPARK高级应用(系统架构、主要配置和性能优化、故障与阶段恢复)、SPARKMLKMEANS算法,SCALA隐式转化高级特性

4.描述如下:

同样先说前面的阶段,主要是第一阶段。HADOOP呢在分析速度上基于MR的大规模数据集相对来说还是挺慢的,包括机器学习,人工智能等。而且不适合做迭代计算。SPARK呢在分析上是作为MR的替代产品,怎么替代呢?先说他们的运行机制,HADOOP基于磁盘存储分析,而SPARK基于内存分析。我这么说你可能不懂,再形象一点,就像你要坐火车从北京到上海,MR就是绿皮火车,而SPARK是高铁或者磁悬浮。而SPARK呢是基于SCALA语言开发的,当然对SCALA支持最好,所以课程中先学习SCALA开发语言。

在科多大数据课程的设计方面,市面上的职位要求技术,基本全覆盖。而且并不是单纯的为了覆盖职位要求,而是本身课程从前到后就是一个完整的大数据项目流程,一环扣一环。

比如从历史数据的存储,分析(HADOOP,HIVE,HBASE),到实时的数据存储(FLUME,KAFKA),分析(STORM,SPARK),这些在真实的项目中都是相互依赖存在的。

java什么叫类属性 实例属性 以及区别

-E,呵呵,你还是没听错,给你个百科的J2EE标准说明,看看你就明白了:记得给分哦~~

网址如下

J2EE简介

J2EE Java2平台企业版(Java 2 Platform,Enterprise Edition)

J2EE是一套全然不同于传统应用开发的技术架构,包含许多组件,主要可简化且规范应用系统的开发与部署,进而提高可移植性、安全与再用价值。

J2EE核心是一组技术规范与指南,其中所包含的各类组件、服务架构及技术层次,均有共通的标准及规格,让各种依循J2EE架构的不同平台之间,存在良好的兼容性,解决过去企业后端使用的信息产品彼此之间无法兼容,导致企业内部或外部难以互通的窘境。

一、J2EE的概念

目前,Java 2平台有3个版本,它们是适用于小型设备和智能卡的Java 2平台Micro

版(Java 2 Platform Micro Edition,J2ME)、适用于桌面系统的Java 2平台标准版(

Java 2 Platform Standard Edition,J2SE)、适用于创建服务器应用程序和服务的Jav

a 2平台企业版(Java 2 Platform Enterprise Edition,J2EE)。

J2EE是一种利用Java 2平台来简化企业解决方案的开发、部署和管理相关的复杂问

题的体系结构。J2EE技术的基础就是核心Java平台或Java 2平台的标准版,J2EE不仅巩

固了标准版中的许多优点,例如"编写一次、随处运行"的特性、方便存取数据库的JDBC

API、CORBA技术以及能够在Internet应用中保护数据的安全模式等等,同时还提供了对

EJB(Enterprise JavaBeans)、Java Servlets API、JSP(Java Server Pages)以及X

ML技术的全面支持。其最终目的就是成为一个能够使企业开发者大幅缩短投放市场时间

的体系结构。

J2体系结构提供中间层集成框架用来满足无需太多费用而又需要高可用性、高可靠

性以及可扩展性的应用的需求。通过提供统一的开发平台,J2EE降低了开发多层应用的

费用和复杂性,同时提供对现有应用程序集成强有力支持,完全支持Enterprise

JavaBeans,有良好的向导支持打包和部署应用,添加目录支持,增强了安全机制,提高

了性能。

二. J2EE的优势

J2EE为搭建具有可伸缩性、灵活性、易维护性的商务系统提供了良好的机制:

1.保留现存的IT资产:由于企业必须适应新的商业需求,利用已有的企业信息系

统方面的投资,而不是重新制定全盘方案就变得很重要。这样,一个以渐进的(而不是

激进的,全盘否定的)方式建立在已有系统之上的服务器端平台机制是公司所需求的。J

2EE架构可以充分利用用户原有的投资,如一些公司使用的BEA Tuxedo、IBM CICS,

IBM Encina,、Inprise VisiBroker以及Netscape Application Server。这之所以成为

可能是因为J2EE拥有广泛的业界支持和一些重要的'企业计算'领域供应商的参与。每一

个供应商都对现有的客户提供了不用废弃已有投资,进入可移植的J2EE领域的升级途径

。由于基于J2EE平台的产品几乎能够在任何操作系统和硬件配置上运行,现有的操作系

统和硬件也能被保留使用。

2.高效的开发: J2EE允许公司把一些通用的、很繁琐的服务端任务交给中间件供

应商去完成。这样开发人员可以集中精力在如何创建商业逻辑上,相应地缩短了开发时

间。高级中间件供应商提供以下这些复杂的中间件服务:

o状态管理服务--让开发人员写更少的代码,不用关心如何管理状态,

这样能够更快地完成程序开发。

o持续性服务--让开发人员不用对数据访问逻辑进行编码就能编写应用

程序,能生成更轻巧,与数据库无关的应用程序,这种应用程序更易于开发与维护。

o分布式共享数据对象CACHE服务--让开发人员编制高性能的系统,极大

提高整体部署的伸缩性。

3.支持异构环境: J2EE能够开发部署在异构环境中的可移植程序。基于J2EE的应

用程序不依赖任何特定操作系统、中间件、硬件。因此设计合理的基于J2EE的程序只需

开发一次就可部署到各种平台。这在典型的异构企业计算环境中是十分关键的。J2EE标

准也允许客户订购与J2EE兼容的第三方的现成的组件,把他们部署到异构环境中,节省

了由自己制订整个方案所需的费用。

4.可伸缩性:企业必须要选择一种服务器端平台,这种平台应能提供极佳的可伸

缩性去满足那些在他们系统上进行商业运作的大批新客户。基于J2EE平台的应用程序可

被部署到各种操作系统上。例如可被部署到高端UNIX与大型机系统,这种系统单机可支

持64至256个处理器。(这是NT服务器所望尘莫及的)J2EE领域的供应商提供了更为广泛

的负载平衡策略。能消除系统中的瓶颈,允许多台服务器集成部署。这种部署可达数千

个处理器,实现可高度伸缩的系统,满足未来商业应用的需要。

稳定的可用性:一个服务器端平台必须能全天候运转以满足公司客户、合作伙伴的需要

。因为INTERNET是全球化的、无处不在的,即使在夜间按计划停机也可能造成严重损失

。若是意外停机,那会有灾难性后果。J2EE部署到可靠的操作环境中,他们支持长期的

可用性。一些J2EE部署在WINDOWS环境中,客户也可选择健壮性能更好的操作系统如Sun

Solaris、IBM OS/390。最健壮的操作系统可达到99.999%的可用性或每年只需5分钟停机

时间。这是实时性很强商业系统理想的选择。

三. J2EE的四层模型

J2EE使用多层的分布式应用模型,应用逻辑按功能划分为组件,各个应用组件根据

他们所在的层分布在不同的机器上。事实上,sun设计J2EE的初衷正是为了解决两层模式

(client/server)的弊端,在传统模式中,客户端担当了过多的角色而显得臃肿,在这种

模式中,第一次部署的时候比较容易,但难于升级或改进,可伸展性也不理想,而且经

常基于某种专有的协议??通常是某种数据库协议。它使得重用业务逻辑和界面逻辑非

常困难。现在J2EE的多层企业级应用模型将两层化模型中的不同层面切分成许多层。一

个多层化应用能够为不同的每种服务提供一个独立的层,以下是 J2EE典型的四层结构:

运行在客户端机器上的客户层组件

运行在J2EE服务器上的Web层组件

运行在J2EE服务器上的业务逻辑层组件

运行在EIS服务器上的企业信息系统(Enterprise information system)层软件

J2EE应用程序组件

J2EE应用程序是由组件构成的.J2EE组件是具有独立功能的软件单元,它们通过相关

的类和文件组装成J2EE应用程序,并与其他组件交互。J2EE说明书中定义了以下的J2EE

组件:

应用客户端程序和applets是客户层组件.

Java Servlet和JavaServer Pages(JSP)是web层组件.

Enterprise JavaBeans(EJB)是业务层组件.

客户层组件

J2EE应用程序可以是基于web方式的,也可以是基于传统方式的.

web层组件

J2EE web层组件可以是JSP页面或Servlets.按照J2EE规范,静态的HTML页面和Appl

ets不算是web层组件。

正如下图所示的客户层那样,web层可能包含某些 JavaBean对象来处理用户输入,并把

输入发送给运行在业务层上的enterprise bean来进行处理。

业务层组件

业务层代码的逻辑用来满足银行,零售,金融等特殊商务领域的需要,由运行在业务

层上的enterprise bean进行处理.下图表明了一个enterprise bean是如何从客户端

程序接收数据,进行处理(如果必要的话),并发送到EIS层储存的,这个过程也可以逆

向进行。

有三种企业级的bean:会话(session) beans,实体(entity) beans,和消息驱动(messa

ge-driven) beans.会话bean表示与客户端程序的临时交互.当客户端程序执行完后,

会话bean和相关数据就会消失.相反,实体bean表示数据库的表中一行永久的记录.

当客户端程序中止或服务器关闭时,就会有潜在的服务保证实体bean的数据得以保存.

消息驱动 bean结合了会话bean和 JMS的消息监听器的特性,允许一个业务层组件异步

接收JMS消息.

企业信息系统层

企业信息系统层处理企业信息系统软件包括企业基础建设系统例如企业资源计划

(ERP),大型机事务处理,数据库系统,和其它的遗留信息系统.例如,J2EE应用组件可

能为了数据库连接需要访问企业信息系统

四. J2EE的结构

这种基于组件,具有平台无关性的J2EE结构使得J2EE程序的编写十分简单,因为业务

逻辑被封装成可复用的组件,并且J2EE服务器以容器的形式为所有的组件类型提供后台

服务.因为你不用自己开发这种服务,所以你可以集中精力解决手头的业务问题。

容器和服务

容器设置定制了J2EE服务器所提供得内在支持,包括安全,事务管理,JNDI(Java

Naming and Directory Interface)寻址,远程连接等服务,以下列出最重要的几种服务

J2EE安全(Security)模型可以让你配置 web组件或enterprise bean,这样只有被授权

的用户才能访问系统资源.每一客户属于一个特别的角色,而每个角色只允许激活特定

的方法。你应在enterprise bean的布置描述中声明角色和可被激活的方法。由于这种声

明性的方法,你不必编写加强安全性的规则。

J2EE事务管理(Transaction Management)模型让你指定组成一个事务中所有方法间的

关系,这样一个事务中的所有方法被当成一个单一的单元.当客户端激活一个enterpris

e bean中的方法,容器介入一管理事务。因有容器管理事务,在enterprise bean中不必

对事务的边界进行编码。要求控制分布式事务的代码会非常复杂。你只需在布置描述文

件中声明enterprise bean的事务属性,而不用编写并调试复杂的代码。容器将读此文件

并为你处理此enterprise bean的事务。

JNDI寻址(JNDI Lookup)服务向企业内的多重名字和目录服务提供了一个统一的接口,这

样应用程序组件可以访问名字和目录服务.

J2EE远程连接(Remote Client Connectivity)模型管理客户端和enterprise bean间的

低层交互.当一个enterprise bean创建后,一个客户端可以调用它的方法就象它和客户

端位于同一虚拟机上一样.

生存周期管理(Life Cycle Management)模型管理enterprise bean的创建和移除,一个

enterprise bean在其生存周期中将会历经几种状态。容器创建enterprise bean,并在

可用实例池与活动状态中移动他,而最终将其从容器中移除。即使可以调用enterprise

bean的create及remove方法,容器也将会在后台执行这些任务。

数据库连接池(Database Connection Pooling)模型是一个有价值的资源。获取数据库

连接是一项耗时的工作,而且连接数非常有限。容器通过管理连接池来缓和这些问题。e

nterprise bean可从池中迅速获取连接。在bean释放连接之可为其他bean使用。

容器类型

J2EE应用组件可以安装部署到以下几种容器中去:

EJB容器管理所有J2EE应用程序中企业级bean的执行. enterprise bean和它们的容

器运行在J2EE服务器上.

Web容器管理所有J2EE应用程序中JSP页面和Servlet组件的执行. Web组件和它们的容

器运行在J2EE服务器上.

应用程序客户端容器管理所有J2EE应用程序中应用程序客户端组件的执行.应用程序客

户端和它们的容器运行在J2EE服务器上.

Applet容器是运行在客户端机器上的web浏览器和 Java插件的结合.。

五. J2EE的核心API与组件

J2EE平台由一整套服务(Services)、应用程序接口(APIs)和协议构成,它对开发基

于Web的多层应用提供了功能支持,下面对J2EE中的13种技术规范进行简单的描述(限于

篇幅,这里只能进行简单的描述):

1. JDBC(Java Database Connectivity):

JDBC API为访问不同的数据库提供了一种统一的途径,象ODBC一样,JDBC对开发者屏蔽

了一些细节问题,另外,JDCB对数据库的访问也具有平台无关性。

2. JNDI(Java Name and Directory Interface):

JNDI API被用于执行名字和目录服务。它提供了一致的模型来存取和操作企业级的资源

如DNS和LDAP,本地文件系统,或应用服务器中的对象。

3. EJB(Enterprise JavaBean):

J2EE技术之所以赢得某体广泛重视的原因之一就是EJB。它们提供了一个框架来开发和实

施分布式商务逻辑,由此很显著地简化了具有可伸缩性和高度复杂的企业级应用的开发

。EJB规范定义了EJB组件在何时如何与它们的容器进行交互作用。容器负责提供公用的

服务,例如目录服务、事务管理、安全性、资源缓冲池以及容错性。但这里值得注意的

是,EJB并不是实现J2EE的唯一途径。正是由于J2EE的开放性,使得有的厂商能够以一种

和EJB平行的方式来达到同样的目的。

4. RMI(Remote Method Invoke):

正如其名字所表示的那样,RMI协议调用远程对象上方法。它使用了序列化方式在客户端

和服务器端传递数据。RMI是一种被EJB使用的更底层的协议。

5. Java IDL/CORBA:

在Java IDL的支持下,开发人员可以将Java和CORBA集成在一起。他们可以创建Java对象

并使之可在CORBA ORB中展开,或者他们还可以创建Java类并作为和其它ORB一起展开的C

ORBA对象的客户。后一种方法提供了另外一种途径,通过它Java可以被用于将你的新的

应用和旧的系统相集成。

6. JSP(Java Server Pages):

JSP页面由HTML代码和嵌入其中的Java代码所组成。服务器在页面被客户端所请求以后对

这些Java代码进行处理,然后将生成的HTML页面返回给客户端的浏览器。

7. Java Servlet:

Servlet是一种小型的Java程序,它扩展了Web服务器的功能。作为一种服务器端的应用

,当被请求时开始执行,这和CGI Perl脚本很相似。Servlet提供的功能大多与JSP类似

,不过实现的方式不同。JSP通常是大多数HTML代码中嵌入少量的Java代码,而servlets

全部由Java写成并且生成HTML。

8. XML(Extensible Markup Language):

XML是一种可以用来定义其它标记语言的语言。它被用来在不同的商务过程中共享数据。

XML的发展和Java是相互独立的,但是,它和Java具有的相同目标正是平台独立性。通过

将Java和XML的组合,您可以得到一个完美的具有平台独立性的解决方案。

9. JMS(Java Message Service):

MS是用于和面向消息的中间件相互通信的应用程序接口(API)。它既支持点对点的域,有

支持发布/订阅(publish/subscribe)类型的域,并且提供对下列类型的支持:经认可的

消息传递,事务型消息的传递,一致性消息和具有持久性的订阅者支持。JMS还提供了另

一种方式来对您的应用与旧的后台系统相集成。

10. JTA(Java Transaction Architecture):

JTA定义了一种标准的API,应用系统由此可以访问各种事务监控。

11. JTS(Java Transaction Service):

JTS是CORBA OTS事务监控的基本的实现。JTS规定了事务管理器的实现方式。该事务管理

器是在高层支持Java Transaction API(JTA)规范,并且在较底层实现OMG OTS

specification的Java映像。JTS事务管理器为应用服务器、资源管理器、独立的应用以

及通信资源管理器提供了事务服务。

12. JavaMail:

JavaMail是用于存取邮件服务器的API,它提供了一套邮件服务器的抽象类。不仅支持SM

TP服务器,也支持IMAP服务器。

JAF(JavaBeans Activation Framework):

JavaMail利用JAF来处理MIME编码的邮件附件。MIME的字节流可以被转换成Java对象,或

者转换自Java对象。大多数应用都可以不需要直接使用JAF。

[编辑本段]J2EE初学者需要注意的问题

体系结构简单介绍

一、J2EE提出的背景

1、企业级应用框架的需求

在许多企业级应用中,例如数据库连接、邮件服务、事务处理等都是一些通用企业需求模块,这些模块如果每次再开发中都由开发人员来完成的话,将会造成开发周期长和代码可靠性差等问题。于是许多大公司开发了自己的通用模块服务。这些服务性的软件系列统称为中间件。

2、为了通用必须要提出规范,不然无法达到通用

在上面的需求基础之上,许多公司都开发了自己的中间件,但其与用户的沟通都各有不同,从而导致用户无法将各个公司不同的中间件组装在一块为自己服务。从而产生瓶颈。于是提出标准的概念。其实J2EE就是基于JAVA技术的一系列标准。

注:中间件的解释中间件处在操作系统和更高一级应用程序之间。它充当的功能是:将应用程序运行环境与操作系统隔离,从而实现应用程序开发者不必为更多系统问题忧虑,而直接关注该应用程序在解决问题上的能力。我们后面说到的容器的概念就是中间件的一种。

二、相关名词解释

容器:充当中间件的角色

WEB容器:给处于其中的应用程序组件(JSP,SERVLET)提供一个环境,使JSP,SERVLET直接与容器中的环境变量接口交互,不必关注其它系统问题。主要由WEB服务器来实现。例如:TOMCAT,WEBLOGIC,WEBSPHERE等。该容器提供的接口严格遵守J2EE规范中的WEB APPLICATION标准。我们把遵守以上标准的WEB服务器就叫做J2EE中的WEB容器。

容器:Enterprise java bean容器。更具有行业领域特色。他提供给运行在其中的组件EJB各种管理功能。只要满足J2EE规范的EJB放入该容器,马上就会被容器进行高效率的管理。并且可以通过现成的接口来获得系统级别的服务。例如邮件服务、事务管理。

WEB容器和EJB容器在原理上是大体相同的,更多的区别是被隔离的外界环境。WEB容器更多的是跟基于HTTP的请求打交道。而EJB容器不是。它是更多的跟数据库、其它服务打交道。但他们都是把与外界的交互实现从而减轻应用程序的负担。例如SERVLET不用关心HTTP的细节,直接引用环境变量session,request,response就行、EJB不用关心数据库连接速度、各种事务控制,直接由容器来完成。

RMI/IIOP:远程方法调用internet对象请求中介协议,他们主要用于通过远程调用服务。例如,远程有一台计算机上运行一个程序,它提供股票分析服务,我们可以在本地计算机上实现对其直接调用。当然这是要通过一定的规范才能在异构的系统之间进行通信。RMI是JAVA特有的。

JNDI:JAVA命名目录服务。主要提供的功能是:提供一个目录系统,让其它各地的应用程序在其上面留下自己的索引,从而满足快速查找和定位分布式应用程序的功能。

JMS:JAVA消息服务。主要实现各个应用程序之间的通讯。包括点对点和广播。

JAVAMAIL:JAVA邮件服务。提供邮件的存储、传输功能。他是编程中实现邮件功能的核心。相当MS中的EXCHANGE开发包。

JTA:JAVA事务服务。提供各种分布式事务服务。应用程序只需调用其提供的接口即可。

JAF:JAVA安全认证框架。提供一些安全控制方面的框架。让开发者通过各种部署和自定义实现自己的个性安全控制策略。

EAI:企业应用集成。是一种概念,从而牵涉到好多技术。J2EE技术是一种很好的集成实现。

三、J2EE的优越性

1、基于JAVA技术,平台无关性表现突出

2、开放的标准,许多大型公司已经实现了对该规范支持的应用服务器。如BEA,IBM,ORACLE等。

3、提供相当专业的通用软件服务。

4、提供了一个优秀的企业级应用程序框架,对快速高质量开发打下基础

四、现状

J2EE是由SUN公司开发的一套企业级应用规范。现在最高版本是1.6。支持J2EE的应用服务器有IBM WEBSPHERE APPLICATION SERVER,BEA WEBLOGIC SERVER,JBOSS,ORACLE APPLICATION SERVER,SUN ONE APPLICATION SERVER等。

[编辑本段]J2EE的13种核心技术

为了联系实际,GOULD基于WEBLOGIC应用服务器(来自BEA SYSTEMS公司的一种广为应用的产品)环境来介绍J2EE的这些技术。

JAVA最初是在浏览器和客户端机器中粉墨登场的。当时,很多人质疑它是否适合做服务器端的开发。现在,随着对JAVA2平台企业版(J2EE)第三方支持的增多,JAVA被广泛接纳为开发企业级服务器端解决方案的首选平台之一。

J2EE平台由一整套服务(SERVICES)、应用程序接口(APIS)和协议构成,它对开发基于WEB的多层应用提供了功能支持。在本文中我将解释支撑J2EE的13种核心技术:JDBC, JNDI, EJBS, RMI, JSP, JAVA SERVLETS, XML, JMS, JAVA IDL, JTS, JTA, JAVA MAIL和 JAF,同时还将描述在何时、何处需要使用这些技术。当然,我还要介绍这些不同的技术之间是如何交互的。此外,为了让您更好地感受J2EE的真实应用,我将在WEBLOGIC应用服务器(来自BEA SYSTEMS公司的一种广为应用的产品)环境下来介绍这些技术。不论对于WEBLOGIC应用服务器和J2EE的新手,还是那些想了解J2EE能带来什么好处的项目管理者和系统分析员,相信本文一定很有参考价值......

Java 怎么在Main函数中,执行完异步任务后才退出主线程

要实现这个情况,必须知道以下几点

1、java中线程的结束是由run方法运行完成后自动结束的

2、在main线程(主线程)中,需要得到所有线程的引用。

3、知道jdk提供的CountDownLatch的用法

例子如下:

public static void main(String[] args) throws InterruptedException

{

//CountDownLatch作为计数器纪录有几个线程,例如有2个线程

CountDownLatch latch=new CountDownLatch(2);

Worker worker1=new Worker( latch);

Worker worker2=new Worker(latch);

worker1.start();//启动线程

worker2.start();//

//等待所有工人完成工作

latch.await();

System.out.println("all work done at"+sdf.format(new Date()));

}

class Worker extends Thread

{

private CountDownLatch latch;

public Worker(CountDownLatch latch)

{

this.latch= latch;

}

public void run()

{

xxxxx

//在run方法结束之前,讲线程计数器减一

latch.countDown();

}

}

OK,本文到此结束,希望对大家有所帮助。

java中的按位或是什么意思(java运算中&是什么意思,比如a=1;b=2;a&b=多少) 淘宝买卖(淘宝买卖纠纷平台解决不了投诉到哪里)