2006-06-30

维基百科,王者归来!(Wikipedia Come Back!)

移动即时版维基百科可以正常访问!
只需关注维基百科指导条目: Wikipedia:如何访问维基百科
便可以及时得到如何访问维基百科的最新权威指南


WIKIPEDIA
Wikipedia:如何访问维基百科



本页最后修改于06:10 2006年6月30日。
powered by FIT

2006-06-29

昨天DNS瘫痪了

我不知道是只有长城宽带如此 还是中国大陆所有的isp都是这样,总之,最严重的时候,几乎解析不到任何的域名,但使用代理服务器就一切OK,说明应该是国内的DNS的问题

2006-06-28

千军易得一将难求 有感于巴西vs加纳

教练
加纳为什么要和巴西打对攻,正中巴西下怀啊!不知道加纳的教练是怎么想的?看了一下这个教练的简历,完全是个无名之辈,在非洲那么点成功都被吹上天了,真是无名又无实!如果加纳换上斯科拉里,今天绝对和巴西打防守反击,而且不出意外绝对搞定巴西了 夺冠都非常有可能 唉 真是兵熊熊一个、将熊熊一窝 替加纳这批黄金球员惋惜啊!说到这里不得不提这次法国的教练,也是个标准垃圾,法国黄金一代就这样完蛋了,误人子弟啊!而且国家队不像俱乐部不爽了可以另投明主,国家队的教练一旦是个垃圾,就只能任倒霉了……悲哀啊……任何垃圾教练都可以毁掉n多人的四年时光以及球迷四年的希望……加纳vs巴西这场看的太失望了……法国vs西班牙也不看了……估计法国凶多吉少……

裁判
今天的裁判一看就有种族歧视,感觉上很看不起来自非洲的有色人种,势利眼、人渣、黑哨!

2006-06-27

再次宣传:Wikipedia:如何访问维基百科

Wikipedia:如何访问维基百科

维基百科,自由的百科全书

跳转到: 导航, 搜索


目录

[隐藏]

直接访问

如果您不在中国大陆,或能直接访问维基百科,请直接访问,也可参考下面的使用HTTPS来保证您上维基的安全性。

使用HTTPS

维基媒体提供通过HTTPS安全协议上维基百科的方法。使用下面的网址即可:

访问其他语言版本,将上述URL中的zh、en换成相应的语言代码;访问其他项目,将上述URL中的wikipedia,wikinews替换为相应项目的名称,例如:

特殊:

问题是跨项目和跨语言连接不能工作。可部分解决的方法:用户页的自定义配置文件中加入Template:SSLFixupjs

  • 进入 Special:Mypage/monobook.js。你可以在沙箱或者自己的用户页写 [[Special:Mypage/monobook.js]]然后保存,通过生成的链接(如果之前没有编辑过,一般是红字)进入编辑。
  • 在编辑框输入{{Subst:SSLFixupjs|100}},然后保存。
  • 当页面重新显示后,Mozilla/Firefox用户点重新加载(或ctrl-r),IE/Opera用户点ctrl-f5, Safari用户点cmd-r,Konqueror用户点ctrl-r。这一步骤可以刷新页面,强行加载新的js文件。之后,就可以使用了。

本方法的特点:

  • 只对登陆用户有效,匿名IP用户不能用。
  • 若不用HTTPS访问维基,所添加的代码不起任何作用。
  • 若通过本方法访问跨项目和跨语言链接,在其它项目上也应有用户名并按将刚才提到的代码复制到该项目相应的配置文件中,否则在那个项目就不能使用本 功能。另外,目前维基文库上的这个模板稍有不同,请不要直接复制生成的代码,而是使用{{Subst:SSLFixupjs|100}}这种方法。
  • 由于upload.wikimedia.org域名现在也被阻断,因此可能看不到图片。需要结合使用其它方法才能看到图片。例如"使用自动配置文件"中的方法修改pac文件,仅需增加域名upload.wikimedia.org即可。

评估


域名劫持 IP封锁 字词过滤 允许的IP
无限读写

网页代理

很多网站提供网页代理服务,即在网页中输入网址即可通过该网站访问要上的网址。 网页代理大多不稳定,这里只举出少量例子。

加载过程中出现任何对话框,建议点接受或OK按钮,某些网页代理上维基可能无法登录/创建帐号或页面显示出错(因为部分代理不能用cookies或css)

评估

域名劫持 IP封锁 字词过滤 允许的IP
×

浏览器使用代理服务器

下文可能将"代理服务器"简称为"代理"

维基媒体代理服务器(推荐)

维基共有四组服务器,分别在韩国佛罗里达 阿姆斯特丹巴黎。中国大陆用户默认DNS到的服务器IP在韩国。目前恰恰仅有韩国服务器IP地址被封。为防止Tor滥用并解决此问题,维基媒体在 阿姆斯特丹开放了代理服务器,注意它们无法上非维基网站

维基媒体的代理服务器列表:

145.97.39.156:80
145.97.39.142:80
145.97.39.140:80
145.97.39.135:80
145.97.39.132:80
145.97.39.138:80
145.97.39.133:80
145.97.39.139:80
145.97.39.134:80
145.97.39.136:80
145.97.39.131:80
145.97.39.137:80
注1:您可以参考对IP地址段145.97.39.1-145.97.39.255服务器状态及开放服务检测
注2:维基媒体的代理服务器的优点是稳定,编辑条目不受限制,速度比较快,缺点是只能用于访问维基百科(可以通过代理服务器自动配置脚本克服,见下文)
它们一般可获得真实IP,为防止破坏,会根据IP判断是否允许用户读写维基百科。

评估


域名劫持 IP封锁 字词过滤 允许的IP
有限读写 ×

普通代理服务器

例如:

125.240.110.195:8080
125.240.200.194:80
125.240.200.194:8080
注1:来自某代理列表网站
注2:速度快,不会像维基媒体的代理一样影响访问其他网站,但不稳定、易过期,这些代理可能无编辑权。

评估

域名劫持 IP封锁 字词过滤 允许的IP
×

配置浏览器使用代理服务器

直接指定代理的地址和端口

下文将以145.97.39.132:80为例,实际配置中您可以择其他代理服务器。

IE

  1. 在桌面上用鼠标右键点IE的Internet Explorer图标
  2. 在出现的菜单中点属性(R)
  3. 选择"连接"选项卡
    • 如果您通过局域网上网,请点"局域网设置(L)...",然后在"代理服务器"下勾选"为LAN使用代理服务器(X)"
    • 如果您通过拨号上网(包括ADSL虚拟拨号)请在拨号和虚拟专用网络设置(N)里选中您正在使用的拨号连接,再点设置(S)...,然后在"代理服务器"下勾选"对此连接使用代理服务器(这些设置不会应用到其它连接)(X) "
  4. 在"地址(E)"后填入145.97.39.132(可在上文提到的 维基媒体代理服务器地址中任选),"端口(T)"内填入"80"(如果您使用其他代理服务器,则应根据实际情况填写,例如使用代理125.244.132.130:8080,地址就填入125.244.132.130,端口就填入8080)
  5. 点"确定" ,设置完毕。
  6. 测试,在IE的地址栏内输入 " http://zh.wikipedia.org" 或在这里点登陆维基百科

腾讯TT

  1. Image:TT1.JPG
    按照上图,在TT(Tencent Traveler)菜单内,点"工具(T)",再点"TT选项(T)..."得到以下界面Image:TT2.JPG
  2. 按照上图,点"代s理服务器设置",出现如下界面
    Image:TT3.JPG
  3. 按照以下内容,输入相关信息
    Image:TT4.JPG
    • 输入一:输入145.97.39.132(可在上文提到的 维基媒体代理服务器地址中任选)
    • 输入二:输入"80"(参见上文IE中端口设置的)
    • 输入三:输入"*.com; *.net; *.edu; *.cc; *.cn; *.au; *.kr; *.uk; *.za 10.*; *.ru; *.de; *.tw; *.li; *.info; *.va; *.sg; *.hk; *.mo; *.gov; *.biz; *.134; *.jp; bugzilla.wikimedia.org; *.info;"
  4. 完成以上内容的输入,按"确定"。

Maxthon(MyIE)

  • Maxthon使用IE的代理服务器
    Image:UseIEProxy.png
  • Maxthon添加代理服务器以供选择
    Image:MaxthonAddProxy.png
  • Maxthon使用非IE代理服务器
    Image:MaxthonUseProxy.png

Firefox

  • 未使用扩展
  • 已使用扩展
    • SwitchProxy扩展
    • xyzProxy扩展

TouchNet Browser

TouchNet Browser具有更新代理列表功能,可自动得到代理服务器(不是维基媒体的),所以设置代理相对容易。但该软件是共享软件。

  1. 下载
  2. 安装TouchNet Browser,适合Windows 95/98/2000/XP/2003
  3. 启动TouchNet Browser(以汉化版为例),点菜单"工具"->"多代理服务器"->"更新代理服务器列表",稍后可以在该菜单下看到若干代理服务器。
  4. 在菜单"工具"->"多代理服务器"下点其中一个地址,然后尝试访问维基百科,如果不能请另选其他。其中应有若干可以访问维基百科的代理服务器。

代理服务器自动配置脚本(pac)

  • 自动配置脚本范例一(感谢super1提供)
function FindProxyForURL(url, host){
host=host.toLowerCase();

if(
dnsDomainIs(host,"wikipedia.org")
||dnsDomainIs(host," wikisource.org")
||dnsDomainIs(host,"wikibooks.org")
||dnsDomainIs(host," wikimedia.org")
||dnsDomainIs(host,"wiktionary.org")
||dnsDomainIs(host,"wikinews.org")
||dnsDomainIs(host,"wikimediafoundation.org")
||dnsDomainIs(host,"mediawiki.org")
||dnsDomainIs(host,"wikiquote.org")
)
return "PROXY 145.97.39.139:80";
else return "DIRECT";
}
注1:145.97.39.139:80可改为任何可用代理服务器
注2:这里的含义为,只有维基相关网站使用代理服务器145.97.39.139:80,其他网站均不用代理,自动配置是否用代理,这是其主要优点
注3:请将该脚本保存为后缀pac的文件备用,例如保存后路径为C:\wikimedia.pac,注意:设置时直接写该路径无效
  • 针对IE的代理服务器自动配置脚本
function FindProxyForURL(url, host){
host=host.toLowerCase();

if(
dnsDomainIs(host,"wikipedia.org")
||dnsDomainIs(host," wikisource.org")
||dnsDomainIs(host,"wikibooks.org")
||dnsDomainIs(host," wikimedia.org")
||dnsDomainIs(host,"wiktionary.org")
||dnsDomainIs(host,"wikinews.org")
||dnsDomainIs(host,"wikimediafoundation.org")
||dnsDomainIs(host,"mediawiki.org")
||dnsDomainIs(host,"wikiquote.org")
)
return "PROXY 145.97.39.139:80;PROXY 145.97.39.136:80;PROXY 145.97.39.135:80;PROXY 145.97.39.134:80;PROXY 145.97.39.133:80;PROXY 145.97.39.132:80;PROXY 145.97.39.131:80;PROXY 127.0.0.1:8118";
//127.0.0.1:8118是给Privoxy留的,没有Privoxy也不影响使用,只要其他代理正常
else return "DIRECT";
}
注一:IE通过IE专有标准支持代理列表,其他浏览器包括Firefox都不支持IE代理列表。
注二:该脚本实现IE访问维基基时,根据需要(例如被关键词过滤阻断)自动以列表切换代理服务器,无需用户操作。因IE的代理缓存,在切换面有时会出现一些小故障。

IE设置pac脚本
  • 本机地址范例如下:
file://E:\GSW\wikipediaIE.pac
  • 一个可用的在线脚本地址:
http://androidgao.googlepages.com/wikipediaIE.pac 
  • 设置自动配置脚本
    1. Internet选项-连接
    2. 如果您是通过局域网上网请选择局域网设置,如果您是拨号上网(包括ADSL虚拟拨号),请选择您正在使用的拨号连接,然后点设置
    3. 无论以上哪种,接下来都选择使用自动配置脚本(打勾),并填入符合以上本机地址格式范例的本机脚本地址或者一个可用的在线脚本地址

Firefox设置pac脚本
  • 本机地址范例如下:
file:///E:/GSW/wikipedia.pac
  • 一个可用的在线脚本地址:
http://androidgao.googlepages.com/wikipedia.pac 
  • 未使用扩展

工具-选项-常规-连接设置-自动代理配置(URL)-填入符合以上本机地址格式范例的本机脚本地址或者一个可用的在线脚本地址

  • 已使用扩展
    • SwitchProxy扩展
      工具-SwitchProxy-Manage Proxies-Add-Standard-Next-Automatic proxy configuration URL-填入地址(参考未使用扩展的情况)
    • xyzProxy扩展

单纯使用代理服务器而不加密传输数据总是有效吗? 不一定。在浏览器中单纯使用代理服务器,而上网信息不使用加密传输,只可能对域名劫持IP封锁有效,而对主干路由器关键字过滤阻断无效,所以对于含有关键字的网页单纯使用代理服务器通常是无效的。解决该问题,可使用该文中提到的HTTPS方式以及Tor方式等。

(Windows)修改hosts

手工修改

  1. 点"开始"菜单->"运行"
  2. 输入以下内容后点确定
    notepad %windir%\system32\drivers\etc\hosts
  3. 在打开的文件末尾添加 这个hosts文件中的代码后保存。

评估

域名劫持 IP封锁 字词过滤 允许的IP
×


Tor相关软件

(Windows)Torpark

Torpark是整合TorFirefox的便携版。

  • 下载:到torpark.nfshost.com下载中文或其他语言的Torpark
  • 安装:绿色软件,只需解压就能运行使用,能便携到闪存盘中
  • 配置:无需任何手动配置,刚启动时有一段时间需Tor链接节点,请等待一会儿即可
  • 编辑限制:请看 借助Tor编辑维基的限制

评估

域名劫持 IP封锁 字词过滤 允许的IP

(Windows)Oignon

Oignon整合了Tor、Privoxy和FreeCap,用户到下载该软件及得到详细教程,感谢 User:Luckygod提供。

评估

域名劫持 IP封锁 字词过滤 允许的IP
?

Privoxy+Tor

下载、安装 Tor和Privoxy可从tor.eff.org www.privoxy.org免费下载,二者均提供Win32、Linux、BSD等平台的版本,请选择您需要的版本。

  • Debian:tor、privoxy是开源软件,有deb包,所以直接用以下命令安装即可。apt-get install tor privoxy
  • Windows下可将Tor运行为一个后台服务,以避免字符界面窗口,tor也已经可以通过多种软件无服务收缩到系统托盘。运行为服务的具体步骤如下:
    1. 把torrc文件复制到%AppData%\Tor(在我的电脑等处的地址栏中输入即可)
    2. 在cmd命令提示符中运行
tor -install
tor -service start

Privoxy+Tor配置

通过点击菜单Option->Edit main configration,可打开Privoxy的主配置文件

一般只需在Privoxy的主配置文件的首行加上以下语句即可:

forward-socks4a / localhost:9050 . 
注意:末尾没有"."则配置无效

浏览器设置Privoxy为代理服务器

方法和 直接指定代理的地址和端口中描述的相同,但填入的地址、端口是Privoxy的地址、端口,默认情况:

  • 地址:
localhost

127.0.0.1
  • 端口:
8118

评估

域名劫持 IP封锁 字词过滤 允许的IP

Vidalia

  • 首页:http://vidalia-project.net
  • 特点:完美整合Tor、Privoxy,图形配置,中文界面、帮助,开源软件,使用非常方便。

借助Tor编辑维基的限制

Tor是加密的安全软件,对中华人民共和国已知的封锁都有效,保证了可浏览任何被封锁的网站。 但同时使用同一个Tor出口的人会被当作同一个用户,因此经常出现一个破坏者被封导致许多Tor用户无法编辑维基,只能浏览。 当遇到这种情况时,您可以:

  • 查找其他任何不借助Tor的访问维基方法
  • 使用HTTPS协议访问 效果很好,但可能速度较慢
  • 等待Tor出口变成未被维基媒体封禁的IP

Privoxy不借助Tor访问维基

注意:维基媒体不再推荐该方法,建议使用HTTPS协议等其他方法,原方法如下:

在Privoxy的主配置文件添加:

forward-socks4a / localhost:9050 .
forward-socks4a zh.wikipedia.org localhost:9050 .
forward *.wikipedia.org 145.97.39.139:80
forward *.wikimedia.org 145.97.39.138:80
forward *.wiktionary.org 145.97.39.136:80
forward *.wikiquote.org 145.97.39.135:80
forward *.wikinews.org 145.97.39.137:80
forward *.wikibooks.org 145.97.39.132:80
forward-socks4a dumps.wikimedia.org localhost:9050 .
forward-socks4a download.wikimedia.org localhost:9050 .
forward-socks4a mail.wikimedia.org localhost:9050 .
forward-socks4a irc.wikimedia.org localhost:9050 .
forward-socks4a ftp.wikimedia.org localhost:9050 .
forward-socks4a news.wikimedia.org localhost:9050 .
forward-socks4a bugs.wikimedia.org localhost:9050 .
forward-socks4a bugzilla.wikimedia.org localhost:9050 .
forward-socks4a ganglia.wikimedia.org localhost:9050 .
forward-socks4a kate.wikimedia.org localhost:9050 .
forward-socks4a kohl.wikimedia.org localhost:9050 .
forward-socks4a noc.wikimedia.org localhost:9050 .
forward-socks4a stats.wikimedia.org localhost:9050 .
forward-socks4a ticket.wikimedia.org localhost:9050 .
forward-socks4a tools.wikimedia.org localhost:9050 .
forward-socks4a mail.wikipedia.org localhost:9050 .
forward-socks4a bugzilla.wikipedia.org localhost:9050 .
forward-socks4a bugs.wikipedia.org localhost:9050 .
forward-socks4a download.wikipedia.org localhost:9050 .
  • 注一,不要丢掉以上语句末尾的"."
  • 注二,可以看出该方法使用的代理服务器地址即为上文提到的 维基媒体代理服务器地址,因此您可以使用任一代理服务器地址替换他们

评估

域名劫持 IP封锁 字词过滤 允许的IP
?

评价访问方法的标准

中华人民共和国的网络封锁方法主要有:

其中针对维基百科的封锁方式主要是IP封锁+字词过滤。曾发生域名劫持。

另外,为防止破坏,维基媒体限制部分IP地址的编辑者,但不限制任何IP地址的阅读者:

  • 允许的IP・是否为维基媒体允许的IP地址。

所以,对各种访问方法的评估,都应以以上四个方面为标准。

将访问目的及最终访问效果细分为:

  • 无限阅读・仅能阅读,不受字词过滤阻断限制。
  • 有限阅读・仅能阅读,受到字词过滤阻断限制。
  • 无限读写・阅读+编辑,不受字词过滤阻断限制。
  • 有限读写・阅读+编辑,受到字词过滤阻断限制。



域名劫持 IP封锁 字词过滤 允许的IP
无法访问 * × * *
无法访问 × * * *
有限阅读 × ×
无限阅读 ×
有限读写 ×
无限读写

镜像网站

目前已失效。CNBlog.org曾长期为维基百科和维基新闻提供代理通道,为维基做出了贡献。

Google Secure Access

Google Secure Access已无限期停止服务

最新消息:Google的主页服务Google Page Creator被大陆封锁了

O Google Page Creator
Create your own web pages, quickly and easily
2/23/06 - Give us feedback - Discuss with others

注:
  • 但使用该服务创建的主页目前并没有被封锁,比如:http://androidgao.googlepages.com/
  • 使用一般的代理服务器就可以成功访问,比如:125.245.223.10:8080

访问Google的Blog网站(blogspot.com)的代理服务器自动配置脚本文件(pac文件)

http://androidgao.googlepages.com/blogspot.pac


您可以直接指向这个脚本,也可以下载到本机使用,如果您不熟悉pac脚本的使用,可以参考
http://androidgao.googlepages.com/%E5%A6%82%E4%BD%95%E8%AE%BF%E9%97%AE%E7%BB%B4%E5%9F%BA%E7%99%BE%E7%A7%91

FAQ:

为什么要使用pac脚本访问Google的Blog网站(blogspot.com)?
答:因为blogspot.com被中国大陆封锁了,在中国大陆必须使用代理服务器才能访问,而使用上述的脚本可以帮助您的浏览器智能的根据当前是否在访问blogspot.com设置代理服务器,而反问其他站点时,自动以不使用代理服务器的方式连接,保证了访问速度。

发现Google的Blog日志发布以后,标题就没有办法修改了,有什么办法吗?

我有个帖子题目里把黄健翔的名字写成黄建翔了 却没办法修改 真是郁闷啊……

呵呵 和Google强强联手 捞美元 大家帮忙 捞到了请吃饭

在我的Google blog和Google Pages上都放上了Google提供的广告,希望大家帮忙点击两下,捞到美元一定请吃饭的

http://androidgao.blogspot.com/
http://androidgao.googlepages.com/



当日收入: USD0.13

查看付款历史
您的付款当前已保留。若要取消保留,则需采取一定的操作。 点击此处了解详情。


网页展示次数 点击次数 网页点击率 网页 eCPM [ ?] 收入
AdSense for content 37 7 18.92% USD1.32 USD0.05

查询 点击次数 CTR eCPM [?] 收入
AdSense for search 15 4 26.67% USD5.12 USD0.08

点击次数 CTR 注册 转换 [ ?] 收入
推介 产品 3 10.00% 0 0 USD0.00
总收入
USD0.13



可惜的是MSN的space里没法放Google的广告,即使使用Custom Html模块也不行,因为这个模块禁止了script脚本,而Google的广告都使用了脚本,所以我只能做个图片链接过去……

啥时候 能在家偷偷数美元啊……

有感:应聘Java笔试时可能出现问题及其答案

CSDN - 文档中心 - Java 阅读:5110 评论: 14 参与评论


标题 有感:应聘Java笔试时可能出现问题及其答案 选择自 huijunzi 的 Blog
关键字 java 笔试 答案
出处

前段时间因为要参加一个笔试,在准备期间在网上找到了两条关于笔试题目的文章,其中一篇为<<有感:应聘Java笔试时可能出现问题>>,还有一篇忘了名字,读后深受启发。
在寻找这些答案的过程中,我将相关答案记录下来,就形成了以下这些东西。需要说明的是以下答案肯定有很多不完整甚至错误的地方,需要各位来更正与完善它,千万不要扔我的鸡蛋啊。
希望本文能够给即将奔赴笔试考场的同仁些许帮助,更希望更多的人加入到收集整理笔试题与完善答案的这些工作中来,为大家更好的获得工作机会做一点贡献。
在此感谢前面两文的作者的对笔试题目的收集与整理。
如有任何意见与建议请通过QQ:6045306,Mail:huijunzi@21cn.com与我联系

Java基础方面:

1、作用域public,private,protected,以及不写时的区别
答:区别如下:
作用域 当前类 同一package 子孙类 其他package
public √ √ √ √
protected √ √ √ ×
friendly √ √ × ×
private √ × × ×
不写时默认为friendly

2、ArrayList和Vector的区别,HashMap和Hashtable的区别
答:
就ArrayList与Vector主要从二方面来说.
一.同步性:Vector是线程安全的,也就是说是同步的,而ArrayList是线程序不安全的,不是同步的
二.数据增长:当需要增长时,Vector默认增长为原来一培,而ArrayList却是原来的一半
就HashMap与HashTable主要从三方面来说。
一.历史原因:Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现
二.同步性:Hashtable是线程安全的,也就是说是同步的,而HashMap是线程序不安全的,不是同步的
三.值:只有HashMap可以让你将空值作为一个表的条目的key或value

3、char型变量中能不能存贮一个中文汉字?为什么?
答:
是能够定义成为一个中文的,因为java中以unicode编码,一个char占16个字节,所以放一个中文是没问题的

4、多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么?
答:
多线程有两种实现方法,分别是继承Thread类与实现Runnable接口
同步的实现方面有两种,分别是synchronized,wait与notify

5、继承时候类的执行顺序问题,一般都是选择题,问你将会打印出什么?
答:
父类:
package test;
public class FatherClass
{
public FatherClass()
{
System.out.println("FatherClass Create");
}
}
子类:
package test;
import test.FatherClass;
public class ChildClass extends FatherClass
{
public ChildClass()
{
System.out.println("ChildClass Create");
}
public static void main(String[] args)
{
FatherClass fc = new FatherClass();
ChildClass cc = new ChildClass();
}
}
输出结果:
C:\>java test.ChildClass
FatherClass Create
FatherClass Create
ChildClass Create

6、内部类的实现方式?
答:
示例代码如下:
package test;
public class OuterClass
{
private class InterClass
{
public InterClass()
{
System.out.println("InterClass Create");
}
}
public OuterClass()
{
InterClass ic = new InterClass();
System.out.println("OuterClass Create");
}
public static void main(String[] args)
{
OuterClass oc = new OuterClass();
}
}
输出结果:
C:\>java test/OuterClass
InterClass Create
OuterClass Create
再一个例题:
public class OuterClass {
private double d1 = 1.0;
//insert code here
}
You need to insert an inner class declaration at line 3. Which two inner class declarations are

valid?(Choose two.)
A. class InnerOne{
public static double methoda() {return d1;}
}
B. public class InnerOne{
static double methoda() {return d1;}
}
C. private class InnerOne{
double methoda() {return d1;}
}
D. static class InnerOne{
protected double methoda() {return d1;}
}
E. abstract class InnerOne{
public abstract double methoda();
}
说明如下:
一.静态内部类可以有静态成员,而非静态内部类则不能有静态成员。 故 A、B 错
二.静态内部类的非静态成员可以访问外部类的静态变量,而不可访问外部类的非静态变量;return d1 出错。

故 D 错
三.非静态内部类的非静态成员可以访问外部类的非静态变量。 故 C 正确
四.答案为C、E

7、垃圾回收机制,如何优化程序?
希望大家补上,谢谢

8、float型float f=3.4是否正确?
答:
不正确。精度不准确,应该用强制类型转换,如下所示:float f=(float)3.4

9、介绍JAVA中的Collection FrameWork(包括如何写自己的数据结构)?
答:
Collection FrameWork如下:
Collection
├List
│├LinkedList
│├ArrayList
│└Vector
│ └Stack
└Set
Map
├Hashtable
├HashMap
└WeakHashMap
Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Elements)
Map提供key到value的映射

10、Java中异常处理机制,事件机制?

11、JAVA中的多形与继承?
希望大家补上,谢谢

12、抽象类与接口?
答:
抽象类与接口都用于抽象,但是抽象类(JAVA中)可以有自己的部分实现,而接口则完全是一个标识(同时有多重继承的功能)。

13、Java 的通信编程,编程题(或问答),用JAVA SOCKET编程,读服务器几个字符,再写入本地显示?
答:
Server端程序:
package test;
import java.net.*;
import java.io.*;

public class Server
{
private ServerSocket ss;
private Socket socket;
private BufferedReader in;
private PrintWriter out;
public Server()
{
try
{
ss=new ServerSocket(10000);
while(true)
{
socket = ss.accept();
String RemoteIP = socket.getInetAddress().getHostAddress();
String RemotePort = ":"+socket.getLocalPort();
System.out.println("A client come in!IP:"+RemoteIP+RemotePort);
in = new BufferedReader(new

InputStreamReader(socket.getInputStream()));
String line = in.readLine();
System.out.println("Cleint send is :" + line);
out = new PrintWriter(socket.getOutputStream(),true);
out.println ("Your Message Received!");
out.close();
in.close();
socket.close();
}
}catch (IOException e)
{
out.println("wrong");
}
}
public static void main(String[] args)
{
new Server();
}
};
Client端程序:
package test;
import java.io.*;
import java.net.*;

public class Client
{
Socket socket;
BufferedReader in;
PrintWriter out;
public Client()
{
try
{
System.out.println("Try to Connect to 127.0.0.1:10000 ");
socket = new Socket("127.0.0.1",10000);
System.out.println("The Server Connected!");
System.out.println("Please enter some Character:");
BufferedReader line = new BufferedReader(new

InputStreamReader(System.in));
out = new PrintWriter(socket.getOutputStream(),true);
out.println(line.readLine());
in = new BufferedReader(new InputStreamReader(socket.getInputStream ()));
System.out.println(in.readLine());
out.close();
in.close();
socket.close();
}catch(IOException e)
{
out.println("Wrong");
}
}
public static void main(String[] args)
{
new Client();
}
};

14、用JAVA实现一种排序,JAVA类实现序列化的方法(二种)? 如在COLLECTION框架中,实现比较要实现什么样的接口?
答:
用插入法进行排序代码如下
package test;
import java.util.*;
class InsertSort
{
ArrayList al;
public InsertSort(int num,int mod)
{
al = new ArrayList(num);
Random rand = new Random();
System.out.println("The ArrayList Sort Before:");
for (int i=0;i<num ;i++ )
{
al.add(new Integer(Math.abs(rand.nextInt ()) % mod + 1));
System.out.println("al["+i+"]="+al.get(i));
}
}
public void SortIt()
{
Integer tempInt;
int MaxSize=1;
for(int i=1;i<al.size();i++)
{
tempInt = (Integer)al.remove(i);
if(tempInt.intValue()>=((Integer)al.get(MaxSize-1)).intValue())
{
al.add(MaxSize,tempInt);
MaxSize++;
System.out.println(al.toString());
} else {
for (int j=0;j<MaxSize ;j++ )
{
if

(((Integer)al.get(j)).intValue()>=tempInt.intValue())
{
al.add(j,tempInt);
MaxSize++;
System.out.println(al.toString());
break;
}
}
}
}
System.out.println("The ArrayList Sort After:");
for(int i=0;i<al.size();i++)
{
System.out.println("al["+i+"]="+al.get(i));
}
}
public static void main(String[] args)
{
InsertSort is = new InsertSort(10,100);
is.SortIt();
}
}
JAVA类实现序例化的方法是实现java.io.Serializable接口
Collection框架中实现比较要实现Comparable 接口和 Comparator 接口

15、编程:编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串。 但是要保证汉字不被截半个,如"我ABC"4,应该截为"我AB",输入"我ABC汉DEF",6,应该输出为"我ABC"而不是"我ABC+汉的半个"。
答:
代码如下:
package test;

class SplitString
{
String SplitStr;
int SplitByte;
public SplitString(String str,int bytes)
{
SplitStr=str;
SplitByte=bytes;
System.out.println("The String is:'"+SplitStr+"';SplitBytes="+SplitByte);
}
public void SplitIt()
{
int loopCount;

loopCount=(SplitStr.length()%SplitByte==0)?(SplitStr.length()/SplitByte):(SplitStr.length()/Split

Byte+1);
System.out.println("Will Split into "+loopCount);
for (int i=1;i<=loopCount ;i++ )
{
if (i==loopCount){

System.out.println(SplitStr.substring((i-1)*SplitByte,SplitStr.length()));
} else {

System.out.println(SplitStr.substring((i-1)*SplitByte,(i*SplitByte)));
}
}
}
public static void main(String[] args)
{
SplitString ss = new SplitString("test中dd文dsaf中男大3443n中国43中国人

0ewldfls=103",4);
ss.SplitIt();
}
}

16、JAVA多线程编程。 用JAVA写一个多线程程序,如写四个线程,二个加1,二个对一个变量减一,输出。
希望大家补上,谢谢

17、STRING与STRINGBUFFER的区别。
答:
STRING的长度是不可变的,STRINGBUFFER的长度是可变的。如果你对字符串中的内容经常进行操作,特别是内容要修改时,那么使用StringBuffer,如果最后需要String,那么使用StringBuffer的toString()方法

Jsp方面

1、jsp有哪些内置对象?作用分别是什么?
答:
JSP共有以下9种基本内置组件(可与ASP的6种内部组件相对应):
 request 用户端请求,此请求会包含来自GET/POST请求的参数
response 网页传回用户端的回应
pageContext 网页的属性是在这里管理
session 与请求有关的会话期
application servlet 正在执行的内容
out 用来传送回应的输出
config servlet的构架部件
page JSP网页本身
exception 针对错误网页,未捕捉的例外

2、jsp有哪些动作?作用分别是什么?
答:
JSP共有以下6种基本动作
jsp:include:在页面被请求的时候引入一个文件。
jsp:useBean:寻找或者实例化一个JavaBean。
jsp:setProperty:设置JavaBean的属性。
jsp:getProperty:输出某个JavaBean的属性。
jsp:forward:把请求转到一个新的页面。
jsp:plugin:根据浏览器类型为Java插件生成OBJECT或EMBED标记

3、JSP中动态INCLUDE与静态INCLUDE的区别?
答:
动态INCLUDE用jsp:include动作实现
<jsp:include page="included.jsp" flush="true" />它总是会检查所含文件中的变化,适合用于包含动态页面,并且可以带参数
静态INCLUDE用include伪码实现,定不会检查所含文件的变化,适用于包含静态页面
<%@ include file="included.htm" %>

4、两种跳转方式分别是什么?有什么区别?
答:
有两种,分别为:
<jsp:include page="included.jsp" flush="true">
<jsp:forward page= "nextpage.jsp"/>
前者页面不会转向include所指的页面,只是显示该页的结果,主页面还是原来的页面。执行完后还会回来,相当于函数调用。 并且可以带参数.后者完全转向新页面,不会再回来。相当于go to 语句。

Servlet方面

1、说一说Servlet的生命周期?
答:
servlet有良好的生存期的定义,包括加载和实例化、初始化、处理请求以及服务结束。这个生存期由javax.servlet.Servlet接口的init,service和destroy方法表达。

2、Servlet版本间(忘了问的是哪两个版本了)的不同?
希望大家补上,谢谢

3、JAVA SERVLET API中forward() 与redirect()的区别?
答:
前者 仅是容器中控制权的转向,在客户端浏览器地址栏中不会显示出转向后的地址;后者则是完全的跳转,浏览器将会得到跳转的地址,并重新发送请求链接。这样,从 浏览器的地址栏中可以看到跳转后的链接地址。所以,前者更加高效,在前者可以满足需要时,尽量使用forward()方法,并且,这样也有助于隐藏实际的 链接。在有些情况下,比如,需要跳转到一个其它服务器上的资源,则必须使用sendRedirect()方法。

4、Servlet的基本架构
public class ServletName extends HttpServlet {
public void doPost(HttpServletRequest request, HttpServletResponse response) throws
ServletException, IOException {
}
public void doGet(HttpServletRequest request, HttpServletResponse response) throws
ServletException, IOException {
}
}

Jdbc、Jdo方面

1、可能会让你写一段Jdbc连Oracle的程序,并实现数据查询.
答:
程序如下:
package hello.ant;
import java.sql.*;
public class jdbc
{
String dbUrl="jdbc:oracle:thin:@127.0.0.1:1521:orcl";
String theUser="admin";
String thePw="manager";
Connection c=null;
Statement conn;
ResultSet rs=null;
public jdbc()
{
try{
Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
c = DriverManager.getConnection(dbUrl,theUser,thePw);
conn=c.createStatement();
}catch(Exception e){
e.printStackTrace();
}
}
public boolean executeUpdate(String sql)
{
try
{
conn.executeUpdate(sql);
return true;
}
catch (SQLException e)
{
e.printStackTrace();
return false;
}
}
public ResultSet executeQuery(String sql)
{
rs=null;
try
{
rs=conn.executeQuery(sql);
}
catch (SQLException e)
{
e.printStackTrace();
}
return rs;
}
public void close()
{
try
{
conn.close();
c.close();
}
catch (Exception e)
{
e.printStackTrace();
}
}
public static void main(String[] args)
{
ResultSet rs;
jdbc conn = new jdbc();
rs=conn.executeQuery("select * from test");
try{
while (rs.next())
{
System.out.println(rs.getString("id"));
System.out.println(rs.getString("name"));
}
}catch(Exception e)
{
e.printStackTrace();
}
}
}

2、Class.forName的作用?为什么要用?
答:
调用该访问返回一个以字符串指定类名的类的对象。

3、Jdo是什么?
答:
JDO是Java对象持久化的新的规范,为java data object的简称,也是一个用于存取某种数据仓库中的对象的标准化API。JDO提供了透明的对象存储,因此对开发人员来说,存储数据对象完全不需要额 外的代码(如JDBC API的使用)。这些繁琐的例行工作已经转移到JDO产品提供商身上,使开发人员解脱出来,从而集中时间和精力在业务逻辑上。另外,JDO很灵活,因为它 可以在任何数据底层上运行。JDBC只是面向关系数据库(RDBMS)JDO更通用,提供到任何数据底层的存储功能,比如关系数据库、文件、XML以及对 象数据库(ODBMS)等等,使得应用可移植性更强。

4、在ORACLE大数据量下的分页解决方法。一般用截取ID方法,还有是三层嵌套方法。
答:
一种分页方法
<%
int i=1;
int numPages=14;
String pages = request.getParameter("page") ;
int currentPage = 1;
currentPage=(pages==null)?(1):{ Integer.parseInt(pages)}
sql = "select count(*) from tables";
ResultSet rs = DBLink.executeQuery(sql) ;
while(rs.next()) i = rs.getInt(1) ;
int intPageCount=1;
intPageCount=(i%numPages==0)?(i/numPages):(i/numPages+1);
int nextPage ;
int upPage;
nextPage = currentPage+1;
if (nextPage>=intPageCount) nextPage=intPageCount;
upPage = currentPage-1;
if (upPage<=1) upPage=1;
rs.close();
sql="select * from tables";
rs=DBLink.executeQuery(sql);
i=0;
while((i<numPages*(currentPage-1))&&rs.next()){i++;}
%>
//输出内容
//输出翻页连接
合计:<%=currentPage%>/<%=intPageCount%><a href="List.jsp ?page=1">第一页</a><a

href="List.jsp?page=<%=upPage%>">上一页</a>
<%
for(int j=1;j<=intPageCount;j++){
if(currentPage!=j){
%>
<a href="list.jsp?page=<%=j%>">[<%=j%>]</a>
<%
}else{
out.println(j);
}
}
%>
<a href="List.jsp?page=<%=nextPage%>">下一页</a><a href="List.jsp?page=<%=intPageCount%>">最后页

</a>


Xml方面

1、xml有哪些解析技术?区别是什么?
答:
有DOM,SAX,STAX等
DOM:处理大型文 件时其性能下降的非常厉害。这个问题是由DOM的树结构所造成的,这种结构占用的内存较多,而且DOM必须在解析文件之前把整个文档装入内存,适合对 XML的随机访问SAX:不现于DOM,SAX是事件驱动型的XML解析方式。它顺序读取XML文件,不需要一次全部装载整个文件。当遇到像文件开头,文 档结束,或者标签开头与标签结束时,它会触发一个事件,用户通过在其回调事件中写入处理代码来处理XML文件,适合对XML的顺序访问
STAX:Streaming API for XML (StAX)

2、你在项目中用到了xml技术的哪些方面?如何实现的?
答:
用到了数据存贮,信息配置两方面。在做数 据交换平台时,将不能数据源的数据组装成XML文件,然后将XML文件压缩打包加密后通过网络传送给接收者,接收解密与解压缩后再同XML文件中还原相关 信息进行处理。在做软件配置时,利用XML可以很方便的进行,软件的各种配置参数都存贮在XML文件中。

3、用jdom解析xml文件时如何解决中文问题?如何解析?
答:
看如下代码,用编码方式加以解决
package test;
import java.io.*;
public class DOMTest
{
private String inFile = "c:\\people.xml";
private String outFile = "c:\\people.xml";
public static void main(String args[])
{
new DOMTest();
}
public DOMTest()
{
try
{
javax.xml.parsers.DocumentBuilder builder =

javax.xml.parsers.DocumentBuilderFactory.newInstance().newDocumentBuilder();
org.w3c.dom.Document doc = builder.newDocument();
org.w3c.dom.Element root = doc.createElement("老师");
org.w3c.dom.Element wang = doc.createElement("王");
org.w3c.dom.Element liu = doc.createElement("刘");
wang.appendChild(doc.createTextNode("我是王老师"));
root.appendChild(wang);
doc.appendChild (root);
javax.xml.transform.Transformer transformer =
javax.xml.transform.TransformerFactory.newInstance().newTransformer();
transformer.setOutputProperty(javax.xml.transform.OutputKeys.ENCODING , "gb2312");
transformer.setOutputProperty(javax.xml.transform.OutputKeys.INDENT, "yes");


transformer.transform(new javax.xml.transform.dom.DOMSource(doc),
new

javax.xml.transform.stream.StreamResult(outFile));
}
catch (Exception e)
{
System.out.println (e.getMessage());
}
}
}

4、编程用JAVA解析XML的方式.
答:
用SAX方式解析XML,XML文件如下:
<?xml version="1.0" encoding="gb2312"?>
<person>
<name>王小明</name>
<college>信息学院</college>
<telephone>6258113</telephone>
<notes>男,1955年生,博士,95年调入海南大学</notes>
</person>
事件回调类SAXHandler.java
import java.io.*;
import java.util.Hashtable;
import org.xml.sax.* ;
public class SAXHandler extends HandlerBase
{
private Hashtable table = new Hashtable();
private String currentElement = null;
private String currentValue = null;
public void setTable(Hashtable table)
{
this.table = table;
}
public Hashtable getTable()
{
return table;
}
public void startElement(String tag, AttributeList attrs)
throws SAXException
{
currentElement = tag;
}
public void characters(char[] ch, int start, int length)
throws SAXException
{
currentValue = new String(ch, start, length);
}
public void endElement(String name) throws SAXException
{
if (currentElement.equals(name))
table.put(currentElement, currentValue);
}
}
JSP内容显示源码,SaxXml.jsp:
<HTML>
<HEAD>
<TITLE>剖析XML文件people.xml</TITLE>
</HEAD>
<BODY>
<%@ page errorPage="ErrPage.jsp"
contentType="text/html;charset=GB2312" %>
<%@ page import="java.io.*" %>
<%@ page import=" java.util.Hashtable" %>
<%@ page import="org.w3c.dom.*" %>
<%@ page import="org.xml.sax.*" %>
<%@ page import="javax.xml.parsers.SAXParserFactory" %>
<%@ page import="javax.xml.parsers.SAXParser" %>
<%@ page import="SAXHandler" %>
<%
File file = new File("c:\\people.xml");
FileReader reader = new FileReader(file);
Parser parser;
SAXParserFactory spf = SAXParserFactory.newInstance();
SAXParser sp = spf.newSAXParser();
SAXHandler handler = new SAXHandler();
sp.parse(new InputSource(reader), handler);
Hashtable hashTable = handler.getTable();
out.println("<TABLE BORDER=2><CAPTION>教师信息表</CAPTION>");
out.println("<TR><TD>姓名</TD>" + "<TD>" +
(String)hashTable.get(new String("name")) + "</TD></TR>");
out.println("<TR><TD>学院</TD>" + "<TD>" +
(String)hashTable.get(new String("college"))+"</TD></TR>");
out.println("<TR><TD>电话</TD>" + "<TD>" +
(String)hashTable.get(new String("telephone")) + "</TD></TR>");
out.println("<TR><TD>备注</TD>" + "<TD>" +
(String)hashTable.get(new String("notes")) + "</TD></TR>");
out.println("</TABLE>");
%>
</BODY>
</HTML>

EJB方面

1、EJB2.0有哪些内容?分别用在什么场合? EJB2.0和EJB1.1的区别?
答:
规范内容包 括Bean提供者,应用程序装配者,EJB容器,EJB配置工具,EJB服务提供者,系统管理员。这里面,EJB容器是EJB之所以能够运行的核心。 EJB容器管理着EJB的创建,撤消,激活,去活,与数据库的连接等等重要的核心工作。JSP,Servlet,EJB,JNDI,JDBC, JMS.....

2、EJB与JAVA BEAN的区别?
答:
Java Bean 是可复用的组件,对Java Bean并没有严格的规范,理论上讲,任何一个Java类都可以是一个Bean。但通常情况下,由于Java Bean是被容器所创建(如Tomcat)的,所以Java Bean应具有一个无参的构造器,另外,通常Java Bean还要实现Serializable接口用于实现Bean的持久性。Java Bean实际上相当于微软COM模型中的本地进程内COM组件,它是不能被跨进程访问的。Enterprise Java Bean 相当于DCOM,即分布式组件。它是基于Java的远程方法调用(RMI)技术的,所以EJB可以被远程访问(跨进程、跨计算机)。但EJB必须被布署在 诸如Webspere、WebLogic这样的容器中,EJB客户从不直接访问真正的EJB组件,而是通过其容器访问。EJB容器是EJB组件的代理, EJB组件由容器所创建和管理。客户通过容器来访问真正的EJB组件。

3、EJB的基本架构
答:
一个EJB包括三个部分:
Remote Interface 接口的代码
package Beans;
import javax.ejb.EJBObject;
import java.rmi.RemoteException;
public interface Add extends EJBObject
{
//some method declare
}
Home Interface 接口的代码
package Beans;
import java.rmi.RemoteException;
import jaax.ejb.CreateException;
import javax.ejb.EJBHome;
public interface AddHome extends EJBHome
{
//some method declare
}
EJB类的代码
package Beans;
import java.rmi.RemoteException;
import javax.ejb.SessionBean;
import javx.ejb.SessionContext;
public class AddBean Implements SessionBean
{
//some method declare
}

J2EE,MVC方面

1、MVC的各个部分都有那些技术来实现?如何实现?
答:
MVC是Model-View- Controller的简写。"Model" 代表的是应用的业务逻辑(通过JavaBean,EJB组件实现), "View" 是应用的表示面(由JSP页面产生),"Controller" 是提供应用的处理过程控制(一般是一个Servlet),通过这种设计模型把应用逻辑,处理过程和显示逻辑分成不同的组件实现。这些组件可以进行交互和重 用。

2、应用服务器与WEB SERVER的区别?
希望大家补上,谢谢


3、J2EE是什么?
答:
Je22是Sun公司提出的多层(multi-diered),分 布式(distributed),基于组件(component-base)的企业级应用模型(enterpriese application model).在这样的一个应用系统中,可按照功能划分为不同的组件,这些组件又可在不同计算机上,并且处于相应的层次(tier)中。所属层次包括客户 层(clietn tier)组件,web层和组件,Business层和组件,企业信息系统(EIS)层。

4、WEB SERVICE名词解释。JSWDL开发包的介绍。JAXP、JAXM的解释。SOAP、UDDI,WSDL解释。
答:
Web Service描述语言WSDL
SOAP即简单对象访问协议(Simple Object Access Protocol),它是用于交换XML编码信息的轻量级协议。
UDDI 的目的是为电子商务建立标准;UDDI是一套基于Web的、分布式的、为Web Service提供的、信息注册中心的实现标准规范,同时也包含一组使企业能将自身提供的Web Service注册,以使别的企业能够发现的访问协议的实现标准。


5、BS与CS的联系与区别。
希望大家补上,谢谢

6、STRUTS的应用(如STRUTS架构)
答:
Struts是采用Java Servlet/JavaServer Pages技术,开发Web应用程序的开放源码的framework。 采用Struts能开发出基于MVC(Model-View-Controller)设计模式的应用构架。 Struts有如下的主要功能:
一.包含一个controller servlet,能将用户的请求发送到相应的Action对象。
二.JSP自由tag库,并且在controller servlet中提供关联支持,帮助开发员创建交互式表单应用。
三.提供了一系列实用对象:XML处理、通过Java reflection APIs自动处理JavaBeans属性、国际化的提示和消息。

设计模式方面

1、开发中都用到了那些设计模式?用在什么场合?
答:
每个模式都描述了一个在我们的环境中不断出现的问题,然后描述了该问题的解决方案的核心。通过这种方式,你可以无数次地使用那些已有的解决方案,无需在重复相同的工作。主要用到了MVC的设计模式。用来开发JSP/Servlet或者J2EE的相关应用。简单工厂模式等。


2、UML方面
答:
标准建模语言UML。用例图,静态图(包括类图、对象图和包图),行为图,交互图(顺序图,合作图),实现图,

JavaScript方面

1、如何校验数字型?
var re=/^\d{1,8}$|\.\d{1,2}$/;
var str=document.form1.all(i).value;
var r=str.match(re);
if (r==null)
{
sign=-4;
break;
}
else{
document.form1.all(i).value=parseFloat(str);
}


CORBA方面

1、CORBA是什么?用途是什么?
答:
CORBA 标准是公共对象请求代理结构(Common Object Request Broker Architecture),由对象管理组织 (Object Management Group,缩写为 OMG)标准化。它的组成是接口定义语言(IDL), 语言绑定(binding:也译为联编)和允许应用程序间互操作的协议。 其目的为:
用不同的程序设计语言书写
在不同的进程中运行
为不同的操作系统开发


LINUX方面

1、LINUX下线程,GDI类的解释。
答:
LINUX实现的就是基于核心轻量级进程的"一对一"线程模型,一个线程实体对应一个核心轻量级进程,而线程之间的管理在核外函数库中实现。
GDI类为图像设备编程接口类库。


相关文章
对该文的评论
sunzq13 ( 2004-11-17)
hao
sunzq13 ( 2004-11-17)
huijunzi ( 2004-09-27)
Java开发人员面试要点
一、Java基础知识
1. Java有那些基本数据类型,String是不是基本数据类型,他们有何区别。
2. 字符串的操作:
写一个方法,实现字符串的反转,如:输入abc,输出cba
写一个方法,实现字符串的替换,如:输入bbbwlirbbb,输出bbbhhtccc。
3. 数据类型之间的转换
如何将数值型字符转换为数字(Integer,Double)
如何将数字转换为字符
如何取小数点前两位,并四舍五入。
4. 日期和时间
如何取得年月日,小时分秒
如何取得从1970年到现在的毫秒数
如何获取某个日期是当月的最后一天
如何格式化日期
5. 数组和集合
6. 文件和目录(I/O)操作
如何列出某个目录下的所有文件
如何列出某个目录下的所有子目录
判断一个文件或目录是否存在
如何读写文件
7. Java多态的实现(继承、重载、覆盖)
8. 编码转换,怎样实现将GB2312编码的字符串转换为ISO-8859-1编码的字符串。
9. Java中访问数据库的步骤,Statement和PreparedStatement之间的区别。
10. 找出下列代码可能存在的错误,并说明原因:
二、JSP&Servlet技术
1. 描述JSP和Servlet的区别、共同点、各自应用的范围
2. 在Web开发中需要处理HTML标记时,应做什么样的处理,要筛选那些字符(< > & "")
3. 在JSP中如何读取客户端的请求,如何访问CGI变量,如何确定某个Jsp文件的真实路径。
4. 描述Cookie和Session的作用,区别和各自的应用范围,Session工作原理。
5. 列出Jsp中包含外部文件的方式,两者有何区别。
6. 说明Jsp中errorPage的作用,应用范围。
7. 介绍在Jsp中如何使用JavaBeans。
8. 简单介绍JSP的标记库
9. Jsp和Servlet中的请求转发分别如何实现。
三、J2EE相关知识
1. 介绍J2EE、J2SE、J2SE的区别。
2. J2EE是一种技术还是一种平台,他提供了那些技术。
3. 什么是Application Server,它有什么功能和优点。
4. 简单介绍连接池的优点和原理。
5. Web.xml的作用
四、其他
1. Web安全性的考虑(表单验证、浏览器Basic方式的验证,应用程序的安全性,SSL,代码考虑)
2. 简单介绍您所了解的MVC。
3. 简单介绍所了解的XML。
4. 文档和编码规范
5. Java中的分页、效率考虑。
6. 简单介绍您所了解的structs。

Class Test{
private String par1;
private String par2;
Test(){
}

public static void main(String[] arg){
int a ;
if(a){
System.out.println("par1="+par1);
}else{
System.out.println("par2=" + par2);
}
}
}
fox_blue ( 2004-07-06)
楼主,跳转的两种方式应该是forward 和 redirect 吧,后一种方式会产生一个新的请求(request) 而前者用同一个
yy2002happy ( 2004-04-16)
非常感谢!!!

所见所闻所思

博客归档