仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 936|回复: 18
打印 上一主题 下一主题

[学习教程] JAVA网页编程之Java中文成绩及最优办理办法

[复制链接]
灵魂腐蚀 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-18 11:53:02 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
其实你不用Struts,spring这些工具,直接用jsp,servlet能够很方便地写出来,而且,可以根据个人的水平、爱好,有很多方案。而struts,spring这些工具的出来。办理|成绩|中文1、中文成绩的来历

盘算机最后的操纵体系撑持的编码是单字节的字符编码,因而,在盘算机中统统处置程序最后都是以单字节编码的英文为准举行处置。跟着盘算机的开展,为了顺应天下别的平易近族的言语(固然包含我们的汉字),人们提出了UNICODE编码,它接纳双字节编码,兼容英笔墨符和别的平易近族的双字节字符编码,以是,今朝,年夜多半国际性的软件外部均接纳UNICODE编码,在软件运转时,它取得当地撑持体系(多半工夫是操纵体系)默许撑持的编码格局,然后再将软件外部的UNICODE转化为当地体系默许撑持的格局显现出来。Java的JDK和JVM便是云云,我这里说的JDK是指国际版的JDK,我们年夜多半程序员利用的是国际化的JDK版本,以下一切的JDK均指国际化的JDK版本。我们的汉字是双字节编码言语,为了能让盘算机处置中文,我们本人制订的gb2312、GBK、GBK2K等尺度以顺应盘算机处置的需求。以是,年夜部分的操纵体系为了顺应我们处置中文的需求,均定制有中文操纵体系,它们接纳的是GBK,GB2312编码格局以准确显现我们的汉字。如:中文Win2K默许接纳的是GBK编码显现,在中文WIN2k中保留文件时默许接纳的保留文件的编码格局也是GBK的,即,一切在中文WIN2K中保留的文件它的外部编码默许均接纳GBK编码,注重:GBK是在GB2312基本上扩大来的。

因为Java言语外部接纳UNICODE编码,以是在JAVA程序运转时,就存在着一个从UNICODE编码和对应的操纵体系及扫瞄器撑持的编码格局转换输出、输入的成绩,这个转换历程有着一系列的步骤,假如个中任何一步堕落,则显现出来的汉字就会出是乱码,这就是我们罕见的JAVA中文成绩。

同时,Java是一个跨平台的编程言语,也即我们编写的程序不但能在中文windows上运转,也能在中文Linux等体系上运转,同时也请求能在英文等体系上运转(我们常常看到有人把在中文win2k上编写的JAVA程序,移植到英文Linux上运转)。这类移植操纵也会带来中文成绩。

另有,有人利用英文的操纵体系和英文的IE等扫瞄器,来运转带中笔墨符的程序和扫瞄中文网页,它们自己就不撑持中文,也会带来中文成绩。

几近一切的扫瞄器默许在传送参数时都是以UTF-8编码格局来传送,而不是按中文编码传送,以是,传送中文参数时也会有成绩,从而带来乱码征象。

总之,以上几个方面是JAVA中的中文成绩的次要来历,我们把以上缘故原由酿成的程序不克不及准确运转而发生的成绩称作:JAVA中文成绩。

  2、JAVA编码转换的具体历程

我们罕见的JAVA程序包含以下种别:
*间接在console上运转的类(包含可视化界面的类)
*JSP代码类(注:JSP是Servlets类的变型)
*Servelets类
*EJB类
*别的不成以间接运转的撑持类

这些类文件中,都有大概含有中笔墨符串,而且我们经常使用前三类JAVA程序和用户间接交互,用于输入和输出字符,如:我们在JSP和Servlet中失掉客户端送来的字符,这些字符也包含中笔墨符。不管这些JAVA类的感化怎样,这些JAVA程序的性命周期都是如许的:

*编程职员在必定的操纵体系上选择一个符合的编纂软件来完成源程序代码并以.java扩大名保留在操纵体系中,比方我们在中文win2k顶用记事本编纂一个java源程序;
*编程职员用JDK中的javac.exe来编译这些源代码,构成.class类(JSP文件是由容器挪用JDK来编译的);
*间接运转这些类或将这些类布署到WEB容器中往运转,并输入了局。
那末,在这些过程当中,JDK和JVM是怎样将这些文件怎样编码息争码并运转的呢?

这里,我们以中文win2k操纵体系为例申明JAVA类是怎样来编码和被解码的。


第一步,我们在中文win2k顶用编纂软件如记事本编写一个Java源程叙文件(包含以上五类JAVA程序),程叙文件在保留时默许接纳了操纵体系默许撑持GBK编码格局(操纵体系默许撑持的格局为file.encoding格局)构成了一个.java文件,也即,java程序在被编译前,我们的JAVA源程叙文件是接纳操纵体系默许撑持的file.encoding编码格局保留的,java源程序中含有中文信息字符和英文程序代码;要检察体系的file.encoding参数,能够用以下代码:
  publicclassShowSystemDefaultEncoding{
  publicstaticvoidmain(String[]args){
  Stringencoding=System.getProperty("file.encoding");
  System.out.println(encoding);
  }}

第二步,我们用JDK的javac.exe文件编译我们的Java源程序,因为JDK是国际版的,在编译的时分,假如我们没有效-encoding参数指定我们的JAVA源程序的编码格局,则javac.exe起首取得我们操纵体系默许接纳的编码格局,也即在编译java程序时,若我们不指定源程叙文件的编码格局,JDK起首取得操纵体系的file.encoding参数(它保留的就是操纵体系默许的编码格局,如WIN2k,它的值为GBK),然后JDK就把我们的java源程序从file.encoding编码格局转化为JAVA外部默许的UNICODE格局放进内存中。然后,javac把转换后的unicode格局的文件举行编译成.class类文件,此时.class文件是UNICODE编码的,它暂放在内存中,紧接着,JDK将此以UNICODE编码的编译后的class文件保留到我们的操纵体系中构成我们见到的.class文件。对我们来讲,我们终极取得的.class文件是内容以UNICODE编码格局保留的类文件,它外部包括我们源程序中的中笔墨符串,只不外此时它己经过file.encoding格局转化为UNICODE格局了。

这一步中,关于JSP源程叙文件是分歧的,关于JSP,这个历程是如许的:即WEB容器挪用JSP编译器,JSP编译器先检察JSP文件中是不是设置有文件编码格局,假如JSP文件中没有设置JSP文件的编码格局,则JSP编译器挪用JDK先把JSP文件用JVM默许的字符编码格局(也即WEB容器地点的操纵体系的默许的file.encoding)转化为一时的Servlet类,然后再把它编译成UNICODE格局的class类,并保留在一时文件夹中。如:在中文win2k上,WEB容器就把JSP文件从GBK编码格局转化为UNICODE格局,然后编译成一时保留的Servlet类,以呼应用户的哀求。

第三步,运转第二步编译出来的类,分为三种情形:

A、间接在console上运转的类
B、EJB类和不成以间接运转的撑持类(如JavaBean类)
C、JSP代码和Servlet类
D、JAVA程序和数据库之间
上面我们分这四种情形来看。
A、间接在console上运转的类

这类情形,运转该类起首必要JVM撑持,即操纵体系中必需安装有JRE。运转历程是如许的:起首java启动JVM,此时JVM读出操纵体系中保留的class文件并把内容读进内存中,此时内存中为UNICODE格局的class类,然后JVM运转它,假如此时此类必要吸收用户输出,则类会默许用file.encoding编码格局对用户输出的串举行编码并转化为unicode保留进内存(用户能够设置输出流的编码格局)。程序运转后,发生的字符串(UNICODE编码的)再回交给JVM,最初JRE把此字符串再转化为file.encoding格局(用户能够设置输入流的编码格局)传送给操纵体系显现接口并输入到界面上。

关于这类间接在console上运转的类,它的转化历程可用加倍明白的暗示出来:

(欠好意义,图传不下去,只好让人人本人往想像图的模样了,我想看了上文是能够想来图来的。)
以上每步的转化都必要准确的编码格局转化,才干终极不呈现乱码征象。

B、EJB类和不成以间接运转的撑持类(如JavaBean类)

因为EJB类和不成以间接运转的撑持类,它们一样平常不与用户间接交互输出和输入,它们经常与别的的类举行交互输出和输入,以是它们在第二步被编译后,就构成了内容是UNICODE编码的类保留在操纵体系中了,今后只需它与别的的类之间的交互在参数传送过程当中没有丧失,则它就会准确的运转。
这类EJB类和不成以间接运转的撑持类,它的转化历程可用加倍明白的暗示出来:



(欠好意义,图传不下去,只好让人人本人往想像图的模样了,我想看了上文是能够想来图来的。)
C、JSP代码和Servlet类

经由第二步后,JSP文件也被转化为Servlets类文件,只不外它不像尺度的Servlets一校存在于classes目次中,它存在于WEB容器的一时目次中,故这一步中我们也把它做为Servlets来看。

关于Servlets,客户端哀求它时,WEB容器挪用它的JVM来运转Servlet,起首,JVM把Servlet的class类从体系中读出并装进内存中,内存中是以UNICODE编码的Servlet类的代码,然后JVM在内存中运转该Servlet类,假如Servlet在运转的过程当中,必要承受从客户端传来的字符如:表单输出的值和URL中传进的值,此时假如程序中没有设定承受参数时接纳的编码格局,则WEB容器会默许接纳ISO-8859-1编码格局来承受传进的值并在JVM直达化为UNICODE格局的保留在WEB容器的内存中。Servlet运转后天生输入,输入的字符串是UNICODE格局的,紧接着,容器将Servlet运转发生的UNICODE格局的串(如html语法,用户输入的串等)间接发送到客户端扫瞄器上并输入给用户,假如此时指定了发送时输入的编码格局,则按指定的编码格局输入到扫瞄器上,假如没有指定,则默许按ISO-8859-1编码发送到客户的扫瞄器上。这类JSP代码和Servlet类,它的转化历程可用加倍明白地暗示出来:

(欠好意义,图传不下去,只好让人人本人往想像图的模样了,我想看了上文是能够想来图来的。)
D、Java程序和数据库之间


关于几近一切数据库的JDBC驱动程序,默许的在JAVA程序和数据库之间传送数据都是以ISO-8859-1为默许编码格局的,以是,我们的程序在向数据库内存储包括中文的数据时,JDBC起首是把程序外部的UNICODE编码格局的数据转化为ISO-8859-1的格局,然后传送到数据库中,在数据库保留数据时,它默许即以ISO-8859-1保留,以是,这是为何我们经常在数据库中读出的中文数据是乱码。
关于JAVA程序和数据库之间的数据传送,我们能够用明晰地暗示出来

(欠好意义,图传不下去,只好让人人本人往想像图的模样了,我想看了上文是能够想来图来的。)

3、剖析罕见的JAVA中文成绩几个必需分明的准绳

起首,经由下面的具体剖析,我们能够明晰地看到,任何JAVA程序的性命期中,其编码转换的关头历程是在于:最后编译成class文件的转码和终极向用户输入的转码历程。
其次,我们必需懂得JAVA在编译时撑持的、经常使用的编码格局有以下几种:
*ISO-8859-1,8-bit,同8859_1,ISO-8859-1,ISO_8859_1等编码
*Cp1252,美国英语编码,同ANSI尺度编码
*UTF-8,同unicode编码
*GB2312,同gb2312-80,gb2312-1980等编码
*GBK,同MS936,它是gb2312的扩大
及别的的编码,如韩文、日文、繁体中文等。同时,我们要注重这些编码间的兼容关系统以下:
unicode和UTF-8编码是逐一对应的干系。GB2312能够以为是GBK的子集,即GBK编码是在gb2312上扩大来的。同时,GBK编码包括了20902个汉字,编码局限为:0x8140-0xfefe,一切的字符能够逐一对应到UNICODE2.0中来。

再次,关于放在操纵体系中的.java源程叙文件,在编译时,我们能够指定它内容的编码格局,详细来讲用-encoding来指定。注重:假如源程序中含有中笔墨符,而你用-encoding指定为别的的编码字符,明显是要堕落的。用-encoding指定源文件的编码体例为GBK或gb2312,不管我们在甚么体系上编译含有中笔墨符的JAVA源程序都不会有成绩,它城市准确地将中文转化为UNICODE存储在class文件中。

然后,我们必需分明,几近一切的WEB容器在其外部默许的字符编码格局都是以ISO-8859-1为默许值的,同时,几近一切的扫瞄器在传送参数时都是默许以UTF-8的体例来传送参数的。以是,固然我们的Java源文件在收支口的中央指定了准确的编码体例,但其在容器外部运转时仍是以ISO-8859-1来处置的。

4、中文成绩的分类及其倡议最优办理举措

懂得以上JAVA处置文件的道理以后,我们就能够提出了一套倡议最优的办理汉字成绩的举措。
我们的方针是:我们在中文体系中编纂的含有中笔墨符串或举行中文处置的JAVA源程序经编译后能够移值就任何别的的操纵体系中准确运转,或拿到别的操纵体系中编译后能准确运转,能准确地传送中文和英文参数,能准确地和数据库交换中英笔墨符串。
我们的详细思绪是:在JAVA程序转码的出口和出口及JAVA程序同用户有输出输入转换的中央限定编码办法使之准确便可。

详细办理举措以下:

1、针对间接在console上运转的类
关于这类情形,我们倡议在程序编写时,假如必要从用户端吸收用户的大概含有中文的输出或含有中文的输入,程序中应当接纳字符流来处置输出和输入,详细来讲,使用以上面向字符型节点流范例:
对文件:FileReader,FileWrieter
其字节型节点流范例为:FileInputStream,FileOutputStream
对内存(数组):CharArrayReader,CharArrayWriter
其字节型节点流范例为:ByteArrayInputStream,ByteArrayOutputStream
对内存(字符串):StringReader,StringWriter
对管道:PipedReader,PipedWriter
其字节型节点流范例为:PipedInputStream,PipedOutputStream
同时,应当用以上面向字符型处置流来处置输出和输入:
BufferedWriter,BufferedReader
其字节型的处置流为:BufferedInputeStream,BufferedOutputStream
InputStreamReader,OutputStreamWriter
其字节型的处置流为:DataInputStream,DataOutputStream
个中InputStreamReader和InputStreamWriter用于将字撙节依照指定的字符编码集转换到字符流,如:
InputStreamReaderin=newInputStreamReader(System.in,"GB2312");
OutputStreamWriterout=newOutputStreamWriter(System.out,"GB2312");
比方:接纳以下的示例JAVA编码就到达了请求:

//Read.java
importjava.io.*;
publicclassRead{
publicstaticvoidmain(String[]args)throwsIOException{
Stringstr="
中文测试,这是外部硬编码的串"+"
testenglishcharacter";
Stringstrin="";
BufferedReaderstdin=newBufferedReader(newInputStreamReader(System.in,"gb2312"));//设置输出接口按中文编码
BufferedWriterstdout=newBufferedWriter(newOutputStreamWriter(System.out,"gb2312"));//设置输入接口按中文编码
stdout.write("请输出:");
stdout.flush();
strin=stdin.readLine();
stdout.write("这是从用户输出的串:"+strin);
stdout.write(str);
stdout.flush();
}}
同时,在编译程序时,我们用以下体例来举行:
javac-encodinggb2312Read.java
其运转了局如所示:




(欠好意义,图传不下去,只好让人人本人往想像图的模样了,我想看了上文是能够想来图来的。)

2、针对EJB类和不成以间接运转的撑持类(如JavaBean类)

因为这类类它们自己被别的的类挪用,不间接与用户交互,故对这类类来讲,我们的倡议的处置体例是外部程序中应当接纳字符流来处置程序外部的中笔墨符串(详细如下面一节中一样),同时,在编译类时用-encodinggb2312参数唆使源文件是中文格局编码的便可。


3、针对Servlet类

针对Servlet,我们倡议用以下办法:

在编译Servlet类的源程序时,用-encoding指定编码为GBK或GB2312,且在向用户输入时的编码部分用response对象的setContentType("text/html;charset=GBK");或gb2312来设置输入编码格局,一样在吸收用户输出时,我们用request.setCharacterEncoding("GB2312");如许不管我们的servlet类移植到甚么操纵体系中,只要客户真个扫瞄器撑持中文显现,就能够准确显现。以下是一个准确的示例:

//HelloWorld.java
packagehello;
importjava.io.*;
importjavax.servlet.*;
importjavax.servlet.http.*;
publicclassHelloWorldextendsHttpServlet
{
publicvoidinit()throwsServletException{}
publicvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)throwsIOException,ServletException
{
request.setCharacterEncoding("GB2312");//设置输出编码格局
response.setContentType("text/html;charset=GB2312");//设置输入编码格局
PrintWriterout=response.getWriter();//倡议利用PrintWriter输入
out.println("<hr>");
out.println("HelloWorld!ThisiscreatedbyServlet!测试中文!");
out.println("<hr>");
}
publicvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)throwsIOException,ServletException
{
request.setCharacterEncoding("GB2312");//设置输出编码格局
response.setContentType("text/html;charset=GB2312");//设置输入编码格局
Stringname=request.getParameter("name");
Stringid=request.getParameter("id");
if(name==null)name="";
if(id==null)id="";
PrintWriterout=response.getWriter();//倡议利用PrintWriter输入
out.println("<hr>");
out.println("你传进的中笔墨串是:"+name);
out.println("<hr>你输出的id是:"+id);
out.println("<hr>");
}
publicvoiddestroy(){}
}
请用javac-encodinggb2312HelloWorld.java来编译此程序。
测试此Servlet的程序以下所示:
<%@pagecontentType="text/html;charset=gb2312"%>
<%request.setCharacterEncoding("GB2312");%>
<html><head><title></title>
<Scriptlanguage="JavaScript">
functionSubmit(){
//经由过程URL传送中笔墨符串值给Servlet
document.base.action="./HelloWorld?name=中文";
document.base.method="POST";
document.base.submit();
}
</Script>
</head>

<bodybgcolor="#FFFFFF"text="#000000"topmargin="5">
<formname="base"method="POST"target="_self">
<inputname="id"type="text"value=""size="30">
<ahref="JavaScript:Submit()">传给Servlet</a>
</form></body></html>
其运转了局如所示:




(欠好意义,图传不下去,只好让人人本人往想像图的模样了,我想看了上文是能够想来图来的。)

4、JAVA程序和数据库之间

为制止JAVA程序和数据库之间数据传送呈现乱码征象,我们倡议接纳以下最优办法来处置:
1、关于JAVA程序的处置办法按我们指定的办法处置。
2、把数据库默许撑持的编码格局改成GBK或GB2312的。

如:在mysql中,我们能够在设置文件my.ini中到场以下语句完成:
在[mysqld]区增添:
default-character-set=gbk
并增添:
[client]
default-character-set=gbk
在SQLServer2K中,我们能够将数据库默许的言语设置为SimplifiedChinese来到达目标。

5、针对JSP代码

因为JSP是在运转时,由WEB容器举行静态编译的,假如我们没有指定JSP源文件的编码格局,则JSP编译器会取得服务器操纵体系的file.encoding值来对JSP文件编译的,它在移植时最简单出成绩,如在中文win2k中能够很好运转的jsp文件拿到英文linux中就不可,只管客户端都是一样的,那是由于容器在编译JSP文件时猎取的操纵体系的编码分歧酿成的(在中文wink中的file.encoding和在英文Linux中file.encoding是分歧的,且英文Linux的file.encoding对中文不撑持,以是编译出来的JSP类就会有成绩)。收集上会商的年夜多半是此类成绩,多是由于JSP文件移植平台时不克不及准确显现的成绩,关于这类成绩,我们懂得了JAVA中程序编码转换的道理,办理起来就简单多了。我们倡议的办理举措以下:

1、我们要包管JSP向客户端输入时是接纳中文编码体例输入的,即不管怎样我们起首在我们的JSP源代编中到场以下一行:

<%@pagecontentType="text/html;charset=gb2312"%>
2、为了让JSP能准确取得传进的参数,我们在JSP源文件头到场上面一句:
<%request.setCharacterEncoding("GB2312");%>
3、为了让JSP编译器能准确地解码我们的含有中笔墨符的JSP文件,我们必要在JSP源文件中指定我们的JSP源文件的编码格局,详细来讲,我们在JSP源文件头上到场上面的一句便可:
<%@pagepageEncoding="GB2312"%>或<%@pagepageEncoding="GBK"%>
这是JSP标准2.0新增添的指令。
我们倡议利用此办法来解JSP文件中的中文成绩,上面的代码是一个准确做法的JSP文件的测试程序:

//testchinese.jsp
<%@pagepageEncoding="GB2312"%>
<%@pagecontentType="text/html;charset=gb2312"%>
<%request.setCharacterEncoding("GB2312");%>
<%
Stringaction=request.getParameter("ACTION");
Stringname="";
Stringstr="";
if(action!=null&&action.equals("SENT"))
{
name=request.getParameter("name");
str=request.getParameter("str");
}
%>
<html>
<head>
<title></title>
<Scriptlanguage="JavaScript">
functionSubmit()
{
document.base.action="?ACTION=SENT&str=传进的中文";
document.base.method="POST";
document.base.submit();
}
</Script>
</head>
<bodybgcolor="#FFFFFF"text="#000000"topmargin="5">
<formname="base"method="POST"target="_self">
<inputtype="text"name="name"value=""size="30">
<ahref="JavaScript:Submit()">提交</a>
</form>
<%
if(action!=null&&action.equals("SENT"))
{
out.println("<br>你输出的字符为:"+name);
out.println("<br>你经由过程URL传进的字符为:"+str);
}
%>
</body>
</html>
如是此程序运转的了局表示图:




(欠好意义,图传不下去,只好让人人本人往想像图的模样了,我想看了上文是能够想来图来的。)


5、总结

在下面的具体剖析中,我们明晰地给出了JAVA在处置源程序过程当中的具体转换历程,为我们准确办理JAVA编程中的中文成绩供应了基本。同时,我们给出了以为是最优的办理JAVA中文成绩的举措。

还是要自己一点一点写代码,然后编译,改错再编译好那。还有最重要的是.net的编译环境非常好,你甚是不需要了解太多工具,对于简单的系统,你可以之了解一些语法就哦了。
精灵巫婆 该用户已被删除
沙发
发表于 2015-1-21 16:42:19 来自手机 | 只看该作者
是一种为 Internet发展的计算机语言
爱飞 该用户已被删除
板凳
发表于 2015-1-30 21:16:02 | 只看该作者
Java 不同于一般的编译执行计算机语言和解释执行计算机语言。它首先将源代码编译成二进制字节码(bytecode),然后依赖各种不同平台上的虚拟机来解释执行字节码。从而实现了“一次编译、到处执行”的跨平台特性。
分手快乐 该用户已被删除
地板
发表于 2015-2-6 16:01:41 | 只看该作者
是一种使网页(Web Page)产生生动活泼画面的语言
谁可相欹 该用户已被删除
5#
发表于 2015-2-25 15:02:49 | 只看该作者
是一种使网页(Web Page)由静态(Static)转变为动态(Dynamic)的语言
山那边是海 该用户已被删除
6#
发表于 2015-3-7 22:29:24 | 只看该作者
多重继承(以接口取代)等特性,增加了垃圾回收器功能用于回收不再被引用的对象所占据的内存空间,使得程序员不用再为内存管理而担忧。在 Java 1.5 版本中,Java 又引入了泛型编程(Generic Programming)、类型安全的枚举、不定长参数和自动装/拆箱等语言特性。
若天明 该用户已被删除
7#
发表于 2015-3-14 15:35:31 | 只看该作者
科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。
兰色精灵 该用户已被删除
8#
发表于 2015-3-14 17:45:24 | 只看该作者
是一种突破用户端机器环境和CPU
再见西城 该用户已被删除
9#
发表于 2015-3-20 03:25:12 | 只看该作者
自从Sun推出Java以来,就力图使之无所不包,所以Java发展到现在,按应用来分主要分为三大块:J2SE,J2ME和J2EE,这也就是Sun ONE(Open Net Environment)体系。J2SE就是Java2的标准版,主要用于桌面应用软件的编程;J2ME主要应用于嵌入是系统开发,如手机和PDA的编程;J2EE是Java2的企业版,主要用于分布式的网络程序的开发,如电子商务网站和ERP系统。
柔情似水 该用户已被删除
10#
发表于 2015-3-20 20:33:14 | 只看该作者
如果要向java web方向发展也要吧看看《Java web从入门到精通》学完再到《Struts2.0入门到精通》这样你差不多就把代码给学完了。有兴趣可以看一些设计模块和框架的包等等。
海妖 该用户已被删除
11#
发表于 2015-3-24 02:10:23 | 只看该作者
任职于太阳微系统的詹姆斯·高斯林等人于1990年代初开发Java语言的雏形,最初被命名为Oak,目标设置在家用电器等小型系统的程序语言
乐观 该用户已被删除
12#
发表于 2015-3-25 15:49:21 | 只看该作者
不过,每次的执行编译后的字节码需要消耗一定的时间,这同时也在一定程度上降低了 Java 程序的运行效率。
莫相离 该用户已被删除
13#
发表于 2015-3-28 11:24:36 | 只看该作者
Java是一种计算机编程语言,拥有跨平台、面向对java
第二个灵魂 该用户已被删除
14#
发表于 2015-3-30 02:58:40 | 只看该作者
吧,现在很流行的Structs就是它的一种实现方式,不过Structs用起来实在是很繁,我们只要学习其精髓即可,我们完全可以设计自己的MVC结构。然后你再研究一下软件Refactoring (重构)和极限XP编程,相信你又会上一个台阶。 做完这些,你不如整理一下你的Java代码,把那些经典的程序和常见的应用整理出来,再精心打造一番,提高其重用性和可扩展性。你再找几个志同道合的朋友成立一个工作室吧
透明 该用户已被删除
15#
发表于 2015-3-30 10:08:13 | 只看该作者
还好,SUN提供了Javabean可以把你的JSP中的 Java代码封装起来,便于调用也便于重用。
深爱那片海 该用户已被删除
16#
发表于 2015-3-31 07:28:10 | 只看该作者
Java是一种计算机编程语言,拥有跨平台、面向对java
灵魂腐蚀 该用户已被删除
17#
 楼主| 发表于 2015-3-31 18:33:26 | 只看该作者
不过,每次的执行编译后的字节码需要消耗一定的时间,这同时也在一定程度上降低了 Java 程序的运行效率。
老尸 该用户已被删除
18#
发表于 2015-4-4 10:30:42 | 只看该作者
如果要向java web方向发展也要吧看看《Java web从入门到精通》学完再到《Struts2.0入门到精通》这样你差不多就把代码给学完了。有兴趣可以看一些设计模块和框架的包等等。
小女巫 该用户已被删除
19#
发表于 2015-4-6 18:58:18 | 只看该作者
其实说这种话的人就如当年小日本号称“三个月拿下中国”一样大言不惭。不是Tomjava泼你冷水,你现在只是学到了Java的骨架,却还没有学到Java的精髓。接下来你得研究设计模式了。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-12-23 21:22

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表