2006年9月14日
我们知道,在子类继承父类之后,如果子类与父类有同名的字段和方法,那么子类中的子段会代替或隐藏父类的子段,说明子类字段覆盖了超类字段,但可以通过super关键字去访问超类字段。但是,在我们将子类对象向超类转型的时候就会发生这个奇怪的现象,子类对象居然可以看到父类曾经被覆盖掉的字段!就正如下面例子中一样:
1 class A{
2 boolean bb =false;
3 }
4
5 public class B extends A{
6 boolean bb = true;
7 //int a=1;
8 public static void main(String[] args) {
9 B b =new B();
10 A a ;
11 a= b;
12 //---??
13 System.out.println(a.bb);
14 //---这句可以理解
15 System.out.println(b.bb);
16 //---??
17 System.out.println( ((A)b).bb);
18 //----
19 }
20 /*运行结果
21 * false
22 * true
23 * false
24 * */
25 }
为什么会发生这样的情况呢?
关于这种情况的解释在[美]Peter van der Linden著的《Just Java2》中有了答案:
P106他说:
一定要注意:当把子类转换成超类时,子类可以见到或访问被隐藏的同名变量。Java允许名字重复的原因是,允许将来把新的字段加到超类中,而不影响已经使用了该名字的现有子类,子类将会继续使用自己的字段副本。
除非让子类以超类对象的形式出现,方法可以覆盖,但是字段不能被覆盖。注意:最好不要隐藏超类中的字段名。
所以我们在进行向上转型的时候一定要注意:不要访问子类中那些“覆盖”掉父类的字段(它并没有真正覆盖掉,在向上转型的时候就可以访问的到),要么将子类字段改名(在你知道父类代码的情况下),要么通过方法来访问字类字段(方法即使同名也肯定能覆盖掉)。
经过一个星期的艰苦奋斗终于解决了这个问题,特将经验摘录下来备忘。本文将解决以下的几种乱码问题。
中文存入
mysql
数据表出现的乱码,从
JSP
页面读取
mysql
中文数据出现乱码,以及在
sell
环境下查看数据库表中文数据出现乱码。
linux平台:ubuntu6.10
mysql版本:5.0
浏览器:firefox2.0
为了解决中文乱码的问题首先就是要同一字符集,我采用utf-8。
第一步:安装mysql后,修改配置文件/etc/mysql/my.cnf 找到相应项并添加如下字段,如下所示:(注意是添加,配置文件中其他不相关的内容下面并没有列出来)
[client]
default-character-set=utf8
[mysqld_safe]
default-character-set=utf8
[mysqld]
default-character-set=utf8
[mysql]
default-character-set=utf8
重新启动mysql服务,进入sell终端,进入mysql的命令提示符下输入如下指令:
mysql>show variables like '%char%';
如果出现的列表各项内容和以下相同表明配置成功了,
+----------------------+---------------------
| Variable_name | Value
+-----------------------+---------------------
| character_set_client | utf8
| character_set_connection | utf8
| character_set_database | utf8
| character_set_filesystem | binary
| character_set_results | utf8
| character_set_server | utf8
| character_set_system | utf8
| character_sets_dir | /usr/share/mysql/charsets/
+---------------------+----------------------
第二步:在要发送中文或者要读取中文的JSP页面(最好所有页面)都添加如下声明:
<%@page pageEncoding="UTF-8"%>
<%@ page contentType="text/html;charset=utf-8"%>
<% request.setCharacterEncoding("utf-8"); %>
在<head>标签对中添加如下:
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
注意在servlet中对请求进行响应的方法中同样要有:
response.setContentType("text/html;charset=utf-8");
第三步:(由于不明原因firefox发送的请求仍然是latin1的时候执行这一步)
在将请求的参数插入数据库之前还要再执行一次转码(将latin1编码转换为utf-8),例如:
String
utf8_str
= new String(
latin_str
.getBytes("latin1"),"utf-8");
这一步可以写在一个过滤器中,不怕麻烦也可以在每一次在将请求数据插入之前都进行一次转码。
另外:在连接数据库的时候可以不用加上字符集参数了,直接用用户名和密码连接就可以了,如连接:
con=DriverManager.getConnection("jdbc:mysql://localhost:3306/数据库名","用户名","密码");
摘要: 时间过的快么?人的感觉而已,时间还是那样地流过,但人们却有不同的感受,收获的越多,感觉时间过的越慢,认知的越少,时间也就过的越快。有三个月没写点什么东西了,为了让时间记住这三个月都发生了什么,趁现在还没有忘记还是记录下来罢,今天心情不好所以废话也就多点。
按时间顺序一个一个来吧。
... 阅读全文
关于ubuntu与xp双系统的安装过程
:
-
(正常安装完windows之后)分区:使用harddiskmanager或其它分区软件划分一个ext3主分区和swap分区,另外在扩展分区中划分出多个要供linux使用的的逻辑分区。
-
将windows系统分区的激活状态设置为关闭(不能设置为隐藏)。将linux主分区设置为激活。
-
光盘启动ubuntu的liveCD,进入系统后安装,手动编辑分区表:将/root挂载在linux主分区上,将/usr , /var , /home 挂载在逻辑分区上。grub安装在linux的主分区上(即/root分区),注意grub的分区计数是从0开始,系统目录挂载分区技数从1开始,假如linux系统分区是第一个硬盘的第三个分区,则系统目录挂载分区表示为:/dev/hda3其中a表示第一块硬盘3表示第三个分区,相应的grub表示为(hd0,2)数字0表示第一个硬盘,2表示第三个分区。
-
安装完毕后取出光盘重起进入ubuntu系统。
配置ubuntu系统
-
上网:sudo pppoeconf
-
更改源:sudo gedit /etc/apt/sources.list 按速度快慢(使用ping测试)将源地址添加在开头,最后加入官方源。
-
更新软件包信息:sudo apt-get update
-
添加中文支持。在语言支持中选chease并打勾,自动下载语言包和输入法。
-
在英文界面下添加输入法: sudo apt-get install im-switch libapt-pkg-perl sudo im-switch -s scim -z default 注销一次
-
下载可同软件的更新。
与window局域网互联
。
-
安装网络服务nfs 和 smb 修改静态IP。
-
添加一个window可访问的用户帐号: sudo adduser -a xxx 输入密码 添加smb用户 smbpasswd -a xxx 输入密码。
-
创建一个网络文件夹的本地挂载点 协议:window共享 服务器:对发ip 域:工作组名 用户名:登录对方window的帐号 连接名:随便。
双网卡与window实现共享上网,ububtu做主机
-
下载firestarter安装,配置:连接internet:pppo -》打开网络共享:与window互联的网卡—》添加策略:inbound traffic policy :Allow connection:对方IP。—》service: DNS ,SSH ,FTP ,HTTP ... 根据需要开放端口。
-
下载并安装bind9,配置bind9:sudo gedit /etc/bind/name.conf.options 在forwards 下添加域名解析服务器的IP地址。
其他注意
:
-
firefox与flash插件9.0存在兼容问题,使用较低的flash插件版本。
-
备份/var/cache/apt/下的所有软件包文件以避免以后重新下载。以后需要安装时只需copy相应的软件包到该目录下即可。
-
可以在使用在windows下安装的ghost8.3在dos下来备份和恢复linux ext3分区。
-
安装bin文件:先给予可执行权限chmod +x xxx.bin在sell下输入bin文件所在的路径执行即可,如 ~/backup/xxx.bin
另外注意备份windows的分区表,以防万一
摘要: DTD和Schema简介
DTD和Shema用来定义将用来表示数据的元素
DTD语法
Schema简介
使用 XML 模式,您会有更多的能力来定义什么样的 XML 文档是有效的
阅读全文
摘要: 《XML精要》
前言
开始学XML也有个把星期了,前后看了几本书关于XML基础的书,感觉讲的甚是凌乱,有些书甚至干脆直接在网上COPY些资料东抄一点西抄一点最后就出版了(比如《XML语言及应用---清华大学出版社》就干脆直接将网上的《XML初学进阶》抄下来,将例子改改就完了)现在中国大学治学的态度可见一斑,直到本周发现了一个IBM的在线XML教程,该教程将XML所有的知识分解为一个个单独的讲座,每堂课还介绍了所需要的前提知识以及所要用到到参考资料,而且教程将知识讲的非常的简练和精确,但可惜该教程是在2002年左右发表的了,在网上资源不是很好找而且比较散,所以我决定将我学的每趟讲座的精要和我个人的读书笔记整理出来形成一个连载,一来巩固我的学习,二来也可以供大家参考,取名《XML精要》。言归正传,那我就开始喽 阅读全文
一:语法结构:
嵌入
*.js
文件
<script language=”javScript” src=”url ”></script>
1.
定义结构:
a)
变量定义:
var xx = “xx”
无须匹配类型;
b)
函数定义:
function method(x , y){…}
参数同样不用匹配类型;
可以通过
arguments.length
属性来确定参数个数来创建不确定参数的函数如:
function noArguments(){
var len = arguments.length;
for(var i=0;i<len;i++){
var fristArgument = noArguments.arguments[i];
………//
通过
noArguments.arguments[i]
获得参数;
}
}
c)
对象定义:
定义方式一
function obj(x,y){
this.x=x;
this.y=y;
this.m1=method1;
this.m2=method2;
function method1(){…..}
function method2(){…..}
}
定义方式二
function obj(x,y){
this.x=x;
this.y=y;
this.m1=function method1(){……}
this.m2=function method2(){……}
}
d)
使用对象:
var obj1 = new obj();
var new_x = obj.x; //
是用属性的方式
1
var new_y = obj[‘y’]; //
是用属性的方式
2
二
内置对象:
a)
数组对象(
Array
):
var newArry =new Arry(n);
var newArry =new Arry(“one”,”two”,”there”,”four”);
注:属性和方法不再列出。
b)
字符串对象(
String
):
var newStr =”xxx”;
var newStr=new String(“xxx”);
对字符串的比较直接使用
”= =”
c)
数学对象(
Math
)
注意:使用数学对象时不需要创建该对象,直接使用即可;
例如:
Math.PI; //
属性的使用
Math.abs(x);//
方法的使用;
d)
日期对象(
Date
)
var date1 =new Date();
var date2 =new Date(“
日期子串
”);
var date3 =new Date(
年,月,日,
[
时,分,秒,毫秒
]);
var date4 =new Date(
毫秒
);
当使用JSP页面将中文数据添加到MySql数据库中的时候发现变为乱码,或者从mysql中读取中文的时候出现乱码,这些问题根源都是由于字符编码不一致造成的。要知道病源是什么我们才能对症下药,所以我将问题产生的过程简单描述一下(如有不对望高人赐教)
我们以一个从form表单读取数据并写入mysql数据库的例子来讲解;
HTML页面参数—(以浏览器的编码方式发送)—》JSP页面—(以JSP定义的编码方式被编译)—》被JSP引擎编译为*.class文件——》在JSP容器中运行——》传递给Mysql数据库—(以数据库的编码方式读取数据并存储)—》读取Mysql—(以数据库的编码方式读取)—》JSP页面接受后在浏览器中显示(以浏览器编码方式解码显示);
注意:这里的“浏览器编码”“JSP页面编码”“JSP页面输出编码”“JSP页面输入编码”“数据库的编码”可能存在潜在的不一直,当它们中的任意一个不相同的时候就会出现乱码;就好像传话游戏一样,张三要把话传给李四,李四把他听到的传给王五,要让王五知道张三说的什么就需要他们三个人使用的相同语言,如果李四是个火星人,他当然听不懂张三说什么,然后他还不厚道的对王五说火星话(乱码),结果王五就只能听到乱码了。(比喻比较汗~~^_^!)
好了,现在我们就依次把各个编码方式改为相同就可以了;
//-------------------------浏览器编码-----------------
<html>
<head><meta http-equiv="Content-Type" content="text/html; charset=GB2312"></head>
</html>
//---------------------------JSP页面-------------------
<%@ page pageEncoding="GB2312"%> //JSP页面编码:
<%@ page contentType="text/html;charset=gb2312"%> //JSP页面输出编码:
<% request.setCharacterEncoding("gb2312"); %> //JSP页面输入编码:
//------------------------MySql编码-------------------
Connection connect = java.sql.DriverManager.getConnection(
"jdbc:mysql://localhost/mydb?user=登陆帐号&password=你的密码&useUnicode=true&characterEncoding=gb2312");
//-------------------------------------------------------
注意:gb2312的写法(红色部分) 在浏览器和数据库中的写法要区分!
以上配置测试成功!(tomcat5.5+MySql5.0)
//另外看了网上的很多文章,比如通过函数转码啊~~改配置文件啊~~都不如这样来的简便且成功率高!
推荐!
运行环境 tomcat5.5+MySql5.0
编写一个简单的HTML表单:
<html>
<head>
</head>
<body>
<form action="http://127.0.0.1/test/login.jsp" method="post">
学号:<input type="text" name="id"><br>
姓名:<input type="text" name="name"><br>
<label>
<input type="radio" name="sex" value="boy" checked>
男</label>
<label>
<input type="radio" name="sex" value="girl">
女</label><br>
电话:<input type="text" name="tel"><br>
<input type="submit" value="提交">
<input type="reset" value="重填">
</form>
</body>
</html> 接这编写一个JSP文件用于读取表单数据
Connection conn = null;
Class.forName("com.mysql.jdbc.Driver").newInstance();
conn = java.sql.DriverManager.getConnection("jdbc:mysql://localhost/mydb","root","corsair");
if(conn==null){
System.out.println("get Conn Error");
}
Statement stmt=conn.createStatement();
ResultSet rs=null;
%>
<%
String id,name,sex,tel;
id=request.getParameter("id");
name=request.getParameter("name");
sex=request.getParameter("sex");
tel=request.getParameter("tel");
try{
stmt.executeUpdate("INSERT INTO inf_student(id,name,sex,tel) VALUES ('"+id+"','"+name+"','"+sex+"','"+tel+"')");
}catch(SQLException e){}
stmt.close();
conn.close();
%> 将以上文件保存在tomcat5.5的webapps目录下;然后启动tomcat5.5和mysql数据库,最后打开表单,插入数据提交,并可以mysqlQueryBrower查看到插入数据的情况了。
<%@ %>指令块。定义JSP文件的全局属性,该指令不能作用动态包含文件;
<%@ page
language="java"
extends="指定父类"
import="导入JAVA类"
session="false||true是否使用session对象"
buffer="定义缓冲区大小默认8kb"
autoFlush="false||true自动清除缓冲区"
isThreadSafe="false||true是否处理多请求"
info="定义相关信息.txt"
errorPage="url指定错误页"
contentType="编码方式"
isErroPage="false||true是否为处理异常页"
%>
<%@ include
file
="URL指定要包含的另外一个JSP文件,*.jspf,*.htmlf"%>
<%@ taglib
uri
="" prefix=""%>
常用的JSP动作元素
1
<jsp:useBean
id="指定该bean对象名"
scope="page||request||session||application bean的作用域"
class="bean的class文件名,注意不能与beanName属性一起使用"
beanName="*.class或*.ser或bean包的名字,紧当bean不存在于指定 的作用域时才使用 "
type="与class或beanName一起使用,指定要实例化的bean的类或接口"
>
<jsp:setProperty name="" property="" value="">实例话bean的初始特性值。
</jsp:/useBean>
2
<jsp:setProperty
name="对应<jsp:useBean>中的id"
property="*||bean属性名 通过request参数设定bean属性值"
value="为bean属性值指定值,需要指定bean属性名"
/>
3
<jsp:getProperty
name="对应<jsp:useBean>中的id"
property="对应想要获得的属性值名"
/>
4
<jsp:include>
page="要包含文件的相对地址"
flush="true||false 是否清空缓冲区"
<jsp:param name="" value="" 可以传递一个参数/>
</jsp:include>
5
<jsp:forward page="URL或者一个表达式,用于将请求的页面转向其他页面">
<jsp:param name="" value="">可以传递参数;
</jsp:forward>
6
<jsp:param
name="" value="">
<%! %>
变量和方法声明块,要使用“;”结尾
<% %>
脚本块 可以声明局部变量 但是不能定义方法!
<%= %>
表达式 注意内部不能使用“;”