??xml version="1.0" encoding="utf-8" standalone="yes"?>欧美成人免费在线视频,天堂8中文在线最新版在线,丁香花高清电影在线观看完整版 http://www.aygfsteel.com/fcailiao/zh-cnFri, 20 Jun 2025 01:15:21 GMTFri, 20 Jun 2025 01:15:21 GMT60Mysql的常用命令详l介l?/title><link>http://www.aygfsteel.com/fcailiao/archive/2007/10/11/151965.html</link><dc:creator>hanzao</dc:creator><author>hanzao</author><pubDate>Thu, 11 Oct 2007 02:24:00 GMT</pubDate><guid>http://www.aygfsteel.com/fcailiao/archive/2007/10/11/151965.html</guid><wfw:comment>http://www.aygfsteel.com/fcailiao/comments/151965.html</wfw:comment><comments>http://www.aygfsteel.com/fcailiao/archive/2007/10/11/151965.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.aygfsteel.com/fcailiao/comments/commentRss/151965.html</wfw:commentRss><trackback:ping>http://www.aygfsteel.com/fcailiao/services/trackbacks/151965.html</trackback:ping><description><![CDATA[Mysql的常用命?br /> <br />     一、连接MYSQL?<br /> <br /> 格式Q?mysql -hL地址 -u用户?Qp用户密码 <br /> <br /> 1、例1Q连接到本机上的MYSQL?<br /> <br />      首先在打开DOSH口Q然后进入目?mysqlbinQ再键入命omysql -uroot -pQ回车后提示你输密码Q如果刚安装好MYSQLQ超U用户root是没有密码的Q故直接回R卛_q入到MYSQL中了QMYSQL的提C符是: mysql> <br /> <br /> 2、例2Q连接到q程L上的MYSQL。假设远E主机的IP为:110.110.110.110Q用户名为root,密码为abcd123。则键入以下命oQ?<br /> <br /> mysql -h110.110.110.110 -uroot -pabcd123 <br /> <br /> Q注:u与root可以不用加空|其它也一P <br /> <br /> 3、退出MYSQL命oQ?exit Q回车);quit; 你也可以用control-D退出?<br /> <br /> <p>4、查看版本号和当前日?</p> <p>mysql> select version(),current_date(); <br /> +----------------+-----------------+ <br /> | version() | current_date() | <br /> +----------------+-----------------+ <br /> | 3.23.25a-debug | 2001-05-17 | <br /> +----------------+-----------------+ <br /> 1 row in set (0.01 sec) <br /> mysql><br /> <br /> 此命令要求mysql服务器告诉你它的版本号和当前日期。尝试用不同大小写操作上q命令,看结果如何。结果说明mysql命o的大写l果是一致的?</p> <br />      二、修改密码?<br /> <br /> 格式Qmysqladmin -u用户?-p旧密?password 新密?<br /> <br /> 1、例1Q给root加个密码ab12。首先在DOS下进入目录mysqlbinQ然后键入以下命?<br /> <br /> mysqladmin -uroot -password ab12 <br /> <br /> 注:因ؓ开始时root没有密码Q所?p旧密码一就可以省略了?<br /> <br /> 2、例2Q再root的密码改为djg345?<br /> <br /> mysqladmin -uroot -pab12 password djg345 <br /> <br />      三、增加新用户。(注意Q和上面不同Q下面的因ؓ是MYSQL环境中的命oQ所以后面都带一个分号作为命令结束符Q?<br /> <br /> 格式Qgrant select on 数据?* to 用户名@dL identified by ""密码"" <br /> <br /> ?、增加一个用户test1密码为abcQ让他可以在ML上登录,q对所有数据库有查询、插入、修攏V删除的权限。首先用以root用户q入MYSQLQ然后键入以下命令: <br /> <br /> grant select,insert,update,delete on *.* to test1@""%"" Identified by ""abc""; <br /> <br /> 但例1增加的用h十分危险的,你想如某个h知道test1的密码,那么他就可以在internet上的M一台电脑上d你的mysql数据库ƈ对你的数据可以ؓ所Ʋؓ了,解决办法见例2?<br /> <br />      ?、增加一个用户test2密码为abc,让他只可以在localhost上登录,q可以对数据库mydbq行查询、插入、修攏V删除的操作 Qlocalhost指本C机,即MYSQL数据库所在的那台LQ,q样用户即用知道test2的密码,他也无法从internet上直接访问数? 库,只能通过MYSQLL上的web|讉K了?<br /> <br /> grant select,insert,update,delete on mydb.* to test2@localhost identified by ""abc""; <br /> <br /> 如果你不想test2有密码,可以再打一个命令将密码消掉?<br /> <br /> grant select,insert,update,delete on mydb.* to test2@localhost identified by """"; <br /> <br />      在上我们讲了登录、增加用戗密码更改等问题。下我们来看看MYSQL中有x据库斚w的操作。注意:你必首先登录到MYSQL中,以下操作都是在MYSQL的提C符下进行的Q而且每个命o以分L束?<br /> <br /> 一、操作技?<br /> <br /> 1、如果你打命令时Q回车后发现忘记加分P你无重打一遍命令,只要打个分号回R可以了。也是说你可以把一个完整的命o分成几行来打Q完后用分号作结束标志就OK?<br /> <br /> 2、你可以使用光标上下键调Z前的命o。但以前我用q的一个MYSQL旧版本不支持。我现在用的是mysql-3.23.27-beta-win?<br /> <br /> 3、一条命令可以分成多行输入,直到出现分号“Q?#8221;为止Q如Q?br /> mysql> select <br /> -> USER() <br /> -> , <br /> -> now() <br /> ->; <br /> +--------------------+---------------------+ <br /> | USER() | now() | <br /> +--------------------+---------------------+ <br /> | ODBC@localhost | 2001-05-17 22:59:15 | <br /> +--------------------+---------------------+ <br /> 1 row in set (0.06 sec) <br /> mysql><br /> <p>注意中间的逗号和最后的分号的用方法?/p> <br /> <p>4、一行多命o </p> <p>输入如下命oQ?</p> <p>mysql> SELECT USER(); SELECT NOW(); <br /> +------------------+ <br /> | USER() | <br /> +------------------+ <br /> | ODBC@localhost | <br /> +------------------+ <br /> 1 row in set (0.00 sec) </p> <p>+---------------------+ <br /> | NOW() | <br /> +---------------------+ <br /> | 2001-05-17 23:06:15 | <br /> +---------------------+ <br /> 1 row in set (0.00 sec) <br /> mysql><br /> </p> <p><br /> 注意中间的分P命o之间用分号隔开?</p> <br /> 二、显C命?<br /> <br /> 1、显C数据库列表?<br /> <br /> show databases; <br /> <br /> 刚开始时才两个数据库Qmysql和test。mysql库很重要它里面有MYSQL的系l信息,我们改密码和新增用户Q实际上是用这个库q行操作?<br /> <br /> 2、显C库中的数据表: <br /> <br /> use mysqlQ?Q/打开库,学过FOXBASE的一定不会陌生吧 <br /> <br /> show tables; <br /> <br /> 3、显C数据表的结构: <br /> <br /> describe 表名; <br /> <br /> 4、徏库: <br /> <br /> create database 库名; <br /> <br /> 5、徏表: <br /> <br /> use 库名Q?<br /> <br /> create table 表名 (字段讑֮列表)Q?<br /> <br /> 6、删库和删表: <br /> <br /> drop database 库名; <br /> <br /> drop table 表名Q?<br /> <br /> 7、将表中记录清空Q?<br /> <br /> delete from 表名; <br /> <br /> 8、显C中的记录Q?<br /> <br /> select * from 表名; <br /> <br /> 三、一个徏库和以及插入数据的实?<br /> <br /> drop database if exists school; //如果存在SCHOOL则删?<br /> <br /> create database school; //建立库SCHOOL <br /> <br /> use school; //打开库SCHOOL <br /> <br /> create table teacher //建立表TEACHER <br /> <br /> ( <br /> <br /> id int(3) auto_increment not null primary key, <br /> <br /> name char(10) not null, <br /> <br /> address varchar(50) default ’深圳’, <br /> <br /> year date <br /> <br /> ); //l束 <br /> <br /> //以下为插入字D?<br /> <br /> insert into teacher values(’’,’glchengang’,’深圳一?#8217;,’1976-10-10’); <br /> <br /> insert into teacher values(’’,’jack’,’深圳一?#8217;,’1975-12-23’); <br /> <br />      注:在徏表中Q?Q将ID设ؓ长度?的数字字D?int(3)q让它每个记录自动加一:auto_incrementq不能ؓI?not null而且让他成ؓdDprimary keyQ?Q将NAME设ؓ长度?0的字W字D(3Q将ADDRESS设ؓ长度50的字W字D,而且~省gؓ深圳。varchar和char有什么区? 呢,只有{以后的文章再说了。(4Q将YEAR设ؓ日期字段?<br /> <br /> 如果你在mysql提示W键入上面的命o也可以,但不方便调试。你可以以上命令原样写入一个文本文件中假设为school.sqlQ然后复制到c:""下,q在DOS状态进入目?"mysql""binQ然后键入以下命令: <br /> <br /> mysql -uroot -p密码 < c:""school.sql <br /> <br /> 如果成功Q空Z行无M昄Q如有错误,会有提示。(以上命o已经调试Q你只要?/的注释去掉即可用)?<br /> <br /> 四、将文本数据转到数据库中 <br /> <br /> 1、文本数据应W合的格式:字段数据之间用tab键隔开Qnull值用""n来代? <br /> <br /> 例: <br /> <br /> 3 rose 深圳二中 1976-10-10 <br /> <br /> 4 mike 深圳一?1975-12-23 <br /> <br /> 2、数据传入命?load data local infile ""文g?" into table 表名; <br /> <br /> 注意Q你最好将文g复制?"mysql""bin目录下,q且要先用use命o打表所在的库?<br /> <br /> 五、备份数据库Q(命o在DOS?"mysql""bin目录下执行) <br /> <br /> mysqldump --opt school>school.bbb <br /> <br /> 注释:数据库school备䆾到school.bbb文gQschool.bbb是一个文本文Ӟ文g名Q取,打开看看你会有新发现?<br /> <br />      后记Q其实MYSQL的对数据库的操作与其它的SQLcL据库大同异Q您最好找本将SQL的书看看?a href=""></a> <img src ="http://www.aygfsteel.com/fcailiao/aggbug/151965.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.aygfsteel.com/fcailiao/" target="_blank">hanzao</a> 2007-10-11 10:24 <a href="http://www.aygfsteel.com/fcailiao/archive/2007/10/11/151965.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>[转]MYSQL 字符集问?/title><link>http://www.aygfsteel.com/fcailiao/archive/2007/10/11/151946.html</link><dc:creator>hanzao</dc:creator><author>hanzao</author><pubDate>Thu, 11 Oct 2007 01:39:00 GMT</pubDate><guid>http://www.aygfsteel.com/fcailiao/archive/2007/10/11/151946.html</guid><wfw:comment>http://www.aygfsteel.com/fcailiao/comments/151946.html</wfw:comment><comments>http://www.aygfsteel.com/fcailiao/archive/2007/10/11/151946.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.aygfsteel.com/fcailiao/comments/commentRss/151946.html</wfw:commentRss><trackback:ping>http://www.aygfsteel.com/fcailiao/services/trackbacks/151946.html</trackback:ping><description><![CDATA[[原文]http://www.aygfsteel.com/wldandan/archive/2007/09/04/142669.html<br /> 前一D|_一直被mysql的字W集困扰Q今天就q方面的知识ȝ一?<br /> MySQL的字W集支持(Character Set Support)有两个方面:<br />      字符?Character set)和排序方?Collation)?br /> 对于字符集的支持l化到四个层? <br />      服务?server)Q数据库(database)Q数据表(table)和连?connection)?br /> <br /> <br /> 1.MySQL默认字符? <p>  MySQL对于字符集的指定可以l化C个数据库Q一张表Q一列,应该用什么字W集?/p> <p>但是Q传l的 E序在创建数据库和数据表时ƈ没有使用那么复杂的配|,它们用的是默认的配置Q那么,默认的配|从何而来呢?</p>     (1)~译MySQL Ӟ指定了一个默认的字符集,q个字符集是 latin1Q?br />     (2)安装MySQL Ӟ可以在配|文?(my.ini) 中指定一个默认的的字W集Q如果没指定Q这个值承自~译时指定的Q?br />     (3)启动mysqld Ӟ可以在命令行参数中指定一个默认的的字W集Q如果没指定Q这个值承自配置文g中的配置,此时 <strong>character_set_server</strong> 被设定ؓq个默认的字W集Q?br />     (4)当创Z个新的数据库Ӟ除非明确指定Q这个数据库的字W集被缺省设定ؓ<strong>character_set_server</strong>Q?br />     (5)当选定了一个数据库Ӟ<strong>character_set_database</strong> 被设定ؓq个数据库默认的字符集;<br />     (6)在这个数据库里创Z张表Ӟ表默认的字符集被讑֮?<strong>character_set_database</strong>Q也是q个数据库默认的字符集;<br />     (7)当在表内讄一栏时Q除非明指定,否则此栏~省的字W集是表默认的字符集;<br /> <p>单的ȝ一下,如果什么地斚w不修改,那么所有的数据库的所有表的所有栏位的都用 latin1 存储Q不q我们如果安?MySQLQ一般都会选择多语a支持Q也是_安装E序会自动在配置文g中把 <strong>default_character_set</strong> 讄?UTF-8Q这保证了缺省情况下Q所有的数据库的所有表的所有栏位的都用 UTF-8 存储?/p> <br /> 2.查看默认字符?默认情况下,mysql的字W集是latin1(ISO_8859_1)<br /> 通常Q查看系l的字符集和排序方式的设定可以通过下面的两条命令:<br />      mysql> SHOW VARIABLES LIKE 'character%';<br /> +--------------------------+---------------------------------+<br /> | Variable_name            | Value                           |<br /> +--------------------------+---------------------------------+<br /> | character_set_client     | latin1                          |<br /> | character_set_connection | latin1                          |<br /> | character_set_database   | latin1                          |<br /> | character_set_filesystem | binary                          |<br /> | character_set_results    | latin1                          |<br /> | character_set_server     | latin1                          |<br /> | character_set_system     | utf8                            |<br /> | character_sets_dir       | D:"mysql-5.0.37"share"charsets" |<br /> +--------------------------+---------------------------------+<br /> <br />   mysql> SHOW VARIABLES LIKE 'collation_%';<br /> +----------------------+-----------------+<br /> | Variable_name        | Value           |<br /> +----------------------+-----------------+<br /> | collation_connection | utf8_general_ci |<br /> | collation_database   | utf8_general_ci |<br /> | collation_server     | utf8_general_ci |<br /> +----------------------+-----------------+<br /> <br /> 3.修改默认字符?br />   (1) 最单的修改ҎQ就是修改mysql的my.ini文g中的字符集键|<br /> ?   default-character-set = utf8<br />       character_set_server =  utf8<br />    修改完后Q重启mysql的服务,service mysql restart<br />    使用 mysql> SHOW VARIABLES LIKE 'character%';查看Q发现数据库~码均已Ҏutf8<br /> +--------------------------+---------------------------------+<br /> | Variable_name            | Value                           |<br /> +--------------------------+---------------------------------+<br /> | character_set_client     | utf8                            |<br /> | character_set_connection | utf8                            |<br /> | character_set_database   | utf8                            |<br /> | character_set_filesystem | binary                          |<br /> | character_set_results    | utf8                            |<br /> | character_set_server     | utf8                            |<br /> | character_set_system     | utf8                            |<br /> | character_sets_dir       | D:"mysql-5.0.37"share"charsets" |<br /> +--------------------------+---------------------------------+<br /> <br />    (2) q有一U修改字W集的方法,是使用mysql的命?br />      mysql> SET character_set_client = utf8 ;<br />      mysql> SET character_set_connection = utf8 ;<br />      mysql> SET character_set_database = utf8 ;<br />      mysql> SET character_set_results = utf8 ;<br />      mysql> SET character_set_server = utf8 ;<br /> <br />      mysql> SET collation_connection = utf8 ;<br />      mysql> SET collation_database = utf8 ;<br />      mysql> SET collation_server = utf8 ;<br /> <br /> <br /> 一般就设|了表的默认字符集ؓutf8q且通过UTF-8~码发送查询,你会发现存入数据库的仍然是ؕ码。问题就出在q个connectionq接层上。解x法是在发送查询前执行一下下面这句: <p>SET NAMES 'utf8';</p> 它相当于下面的三句指令:<br /> SET character_set_client = utf8;<br /> SET character_set_results = utf8;<br /> SET character_set_connection = utf8;<br /> <br /> ȝ: <br /> <span>因此Q用什么数据库版本Q不是3.xQ还?.0.xq是4.1.xQ其实对我们来说不重要,重要的有二: <br />   1) 正确的设定数据库~码.MySQL4.0以下版本的字W集L默认ISO8859-1QMySQL4.1在安装的时候会让你选择。如果你准备使用UTF- 8Q那么在创徏数据库的时候就要指定好UTF-8(创徏好以后也可以改,4.1以上版本q可以单独指定表的字W集) <br />   2) 正确的设定数据库connection~码.讄好数据库的编码后Q在q接数据库时候,应该指定connection的编码,比如使用jdbcq接Ӟ指定q接为utf8方式.</span> <img src ="http://www.aygfsteel.com/fcailiao/aggbug/151946.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.aygfsteel.com/fcailiao/" target="_blank">hanzao</a> 2007-10-11 09:39 <a href="http://www.aygfsteel.com/fcailiao/archive/2007/10/11/151946.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>java反射机制[基础学习]http://www.aygfsteel.com/fcailiao/archive/2007/10/07/150800.htmlhanzaohanzaoSun, 07 Oct 2007 03:34:00 GMThttp://www.aygfsteel.com/fcailiao/archive/2007/10/07/150800.htmlhttp://www.aygfsteel.com/fcailiao/comments/150800.htmlhttp://www.aygfsteel.com/fcailiao/archive/2007/10/07/150800.html#Feedback0http://www.aygfsteel.com/fcailiao/comments/commentRss/150800.htmlhttp://www.aygfsteel.com/fcailiao/services/trackbacks/150800.html

一、反的概念 Q?/font>

Java中,反射是一U强大的工具。它使您能够创徏灉|的代码,q些代码可以在运行时装配Q无需在组件之间进行源? 表链接。反允许我们在~写与执 行时Q我们的程序代码能够接入装载到JVM中的cȝ内部信息Q而不是源代码中选定的类协作的代码。这使反成为构建灵zȝ应用的主要工兗但需注意? 是:如果使用不当Q反的成本很高?/font>

二、Java中的cd:

Reflection ?Java E序开发语a的特征之一Q它允许q行中的 Java E序对自w进行检查,或者说“自审”Qƈ能直接操作程?的内部属性。Java 的这一能力在实际应用中也许用得不是很多Q但是在其它的程序设计语a中根本就不存在这一Ҏ。例如,Pascal、C 或?C+ + 中就没有办法在程序中获得函数定义相关的信息?/font>

1Q检类Q?/strong>

1.1 reflection的工作机?/strong>

考虑下面q个单的例子Q让我们看看 reflection 是如何工作的?/font>

import java.lang.reflect.*;
public class DumpMethods {
     public static void main(String args[]) {
         try {
             Class c = Class.forName(args[0]);
             Method m[] = c.getDeclaredMethods();
             for (int i = 0; i < m.length; i++)
                 System.out.println(m[i].toString());
         } catch (Throwable e) {
             System.err.println(e);
         }
     }
}

按如下语句执行:

java DumpMethods java.util.Stack

它的l果输出为:

public java.lang.Object java.util.Stack.push(java.lang.Object)

public synchronized java.lang.Object java.util.Stack.pop()

public synchronized java.lang.Object java.util.Stack.peek()

public boolean java.util.Stack.empty()

public synchronized int java.util.Stack.search(java.lang.Object)

q样列Zjava.util.Stack cȝ各方法名以及它们的限制符和返回类型?/font>

q个E序使用 Class.forName 载入指定的类Q然后调?getDeclaredMethods 来获取这个类中定义了的方法列表。java.lang.reflect.Methods 是用来描q某个类中单个方法的一个类?/font>

1.2 Javacd中的主要方?/strong>

对于以下三类lg中的M一cL?-- 构造函数、字D和Ҏ -- java.lang.Class 提供四种独立的反调用,以不同的方式来获得信息。调用都遵@一U标准格式。以下是用于查找构造函数的一l反调用:

         Constructor getConstructor(Class[] params) -- 获得使用Ҏ的参数类型的公共构造函敎ͼ

         Constructor[] getConstructors() -- 获得cȝ所有公共构造函?/font>

         Constructor getDeclaredConstructor(Class[] params) -- 获得使用特定参数cd的构造函?与接入别无?

         Constructor[] getDeclaredConstructors() -- 获得cȝ所有构造函?与接入别无?

获得字段信息的Class 反射调用不同于那些用于接入构造函数的调用Q在参数cd数组中用了字段名:

         Field getField(String name) -- 获得命名的公共字D?/font>

         Field[] getFields() -- 获得cȝ所有公共字D?/font>

         Field getDeclaredField(String name) -- 获得cd明的命名的字D?/font>

         Field[] getDeclaredFields() -- 获得cd明的所有字D?

用于获得Ҏ信息函数Q?/font>

         Method getMethod(String name, Class[] params) -- 使用特定的参数类型,获得命名的公共方?/font>

         Method[] getMethods() -- 获得cȝ所有公共方?/font>

         Method getDeclaredMethod(String name, Class[] params) -- 使用特写的参数类型,获得cd明的命名的方?/font>

         Method[] getDeclaredMethods() -- 获得cd明的所有方?

1.3开始?ReflectionQ?/strong>

用于 reflection 的类Q如 MethodQ可以在 java.lang.relfect 包中扑ֈ。用这些类的时候必要遵@三个步骤Q第一步是获得你想操作的类?java.lang.Class 对象。在q行中的 Java E序中,?java.lang.Class cL描述cd接口{?/font>

下面是获得一?Class 对象的方法之一Q?/font>

Class c = Class.forName("java.lang.String");

q条语句得到一?String cȝcd象。还有另一U方法,如下面的语句Q?/font>

Class c = int.class;

或?/font>

Class c = Integer.TYPE;

它们可获得基本类型的cM息。其中后一U方法中讉K的是基本cd的封装类 (?Integer) 中预先定义好?TYPE 字段?/font>

W二步是调用诸如 getDeclaredMethods 的方法,以取得该cM定义的所有方法的列表?/font>

一旦取得这个信息,可以进行第三步了——?reflection API 来操作这些信息,如下面这D代码:

Class c = Class.forName("java.lang.String");

Method m[] = c.getDeclaredMethods();

System.out.println(m[0].toString());

它将以文本方式打印出 String 中定义的W一个方法的原型?/font>

在下面的例子中,q三个步骤将Z?reflection 处理Ҏ应用E序提供例证?/font>

模拟 instanceof 操作W?/font>

得到cM息之后,通常下一个步骤就是解军_?Class 对象的一些基本的问题。例如,Class.isInstance Ҏ可以用于模拟 instanceof 操作W:

class A {
}

public class instance1 {
   public static void main(String args[]) {
       try {
           Class cls = Class.forName("A");
           boolean b1 = cls.isInstance(new Integer(37));
           System.out.println(b1);
           boolean b2 = cls.isInstance(new A());
           System.out.println(b2);
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

在这个例子中创徏了一?A cȝ Class 对象Q然后检查一些对象是否是 A 的实例。Integer(37) 不是Q但 new A() 是?/font>

1.4 扑ևcȝҎ

扑և一个类中定义了些什么方法,q是一个非常有价g非常基础?reflection 用法。下面的代码实Cq一用法Q?/font>

import java.lang.reflect.*;

public class method1 {
   private int f1(Object p, int x) throws NullPointerException {
       if (p == null)
           throw new NullPointerException();
       return x;
   }

   public static void main(String args[]) {
       try {
           Class cls = Class.forName("method1");
           Method methlist[] = cls.getDeclaredMethods();
           for (int i = 0; i < methlist.length; i++) {
               Method m = methlist[i];
               System.out.println("name = " + m.getName());
               System.out.println("decl class = " + m.getDeclaringClass());
               Class pvec[] = m.getParameterTypes();
               for (int j = 0; j < pvec.length; j++)
                   System.out.println("param #" + j + " " + pvec[j]);
               Class evec[] = m.getExceptionTypes();
               for (int j = 0; j < evec.length; j++)
                   System.out.println("exc #" + j + " " + evec[j]);
               System.out.println("return type = " + m.getReturnType());
               System.out.println("-----");
           }
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

q? 个程序首先取?method1 cȝ描述Q然后调?getDeclaredMethods 来获取一pd?Method 对象Q它们分别描qC定义在类中的每一个方法,包括 public Ҏ、protected Ҏ、package Ҏ?private Ҏ{。如果你在程序中使用 getMethods 来代?getDeclaredMethodsQ你q能获得l承来的各个Ҏ的信息?/font>

取得?Method 对象列表之后Q要昄q些Ҏ的参数类型、异常类型和q回值类型等׃难了。这些类型是基本cdq是cȝ型,都可以由描述cȝ对象按顺序给出?/font>

输出的结果如下:

name = f1

decl class = class method1

param #0 class java.lang.Object

param #1 int

exc #0 class java.lang.NullPointerException

return type = int

-----

name = main

decl class = class method1

param #0 class [Ljava.lang.String;

return type = void

-----


1.5 获取构造器信息

获取cL造器的用法与上述获取Ҏ的用法类|如:

import java.lang.reflect.*;

public class constructor1 {
   public constructor1() {
   }

   protected constructor1(int i, double d) {
   }

   public static void main(String args[]) {
       try {
           Class cls = Class.forName("constructor1");
           Constructor ctorlist[] = cls.getDeclaredConstructors();
           for (int i = 0; i < ctorlist.length; i++) {
               Constructor ct = ctorlist[i];
               System.out.println("name = " + ct.getName());
               System.out.println("decl class = " + ct.getDeclaringClass());
               Class pvec[] = ct.getParameterTypes();
               for (int j = 0; j < pvec.length; j++)
                   System.out.println("param #" + j + " " + pvec[j]);
               Class evec[] = ct.getExceptionTypes();
               for (int j = 0; j < evec.length; j++)
                   System.out.println("exc #" + j + " " + evec[j]);
               System.out.println("-----");
           }
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

q个例子中没能获得返回类型的相关信息Q那是因为构造器没有q回cd?/font>

q个E序q行的结果是Q?/font>

name = constructor1

decl class = class constructor1

-----

name = constructor1

decl class = class constructor1

param #0 int

param #1 double

-----

1.6获取cȝ字段(?

扑և一个类中定义了哪些数据字段也是可能的,下面的代码就在干q个事情Q?/font>

?Q?br /> import java.lang.reflect.*;

public class field1 {
   private double d;
   public static final int i = 37;
   String s = "testing";

   public static void main(String args[]) {
       try {
           Class cls = Class.forName("field1");
           Field fieldlist[] = cls.getDeclaredFields();
           for (int i = 0; i < fieldlist.length; i++) {
               Field fld = fieldlist[i];
               System.out.println("name = " + fld.getName());
               System.out.println("decl class = " + fld.getDeclaringClass());
               System.out.println("type = " + fld.getType());
               int mod = fld.getModifiers();
               System.out.println("modifiers = " + Modifier.toString(mod));
               System.out.println("-----");
           }
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

q? 个例子和前面那个例子非常怼。例中用了一个新东西 ModifierQ它也是一?reflection c,用来描述字段成员的修饰语Q如“private int”。这些修饰语自n由整数描qͼ而且使用 Modifier.toString 来返回以“官方”序排列的字W串描述 (?#8220;static”?#8220;final”之前)。这个程序的输出是:

name = d

decl class = class field1

type = double

modifiers = private

-----

name = i

decl class = class field1

type = int

modifiers = public static final

-----

name = s

decl class = class field1

type = class java.lang.String

modifiers =

-----

?:

import java.lang.reflect.*;
import java.awt.*;

class SampleGet {

    public static void main(String[] args) {
        Rectangle r = new Rectangle(100, 325);
        printHeight(r);

    }

    static void printHeight(Rectangle r) {
        Field heightField;
        Integer heightValue;
        Class c = r.getClass();
        try {
            heightField = c.getField("height");//取得heightq个变量
            heightValue = (Integer) heightField.get(r);//取得heightq个变量的?br />             System.out.println("Height: " + heightValue.toString());
        } catch (NoSuchFieldException e) {
            System.out.println(e);
        } catch (SecurityException e) {
            System.out.println(e);
        } catch (IllegalAccessException e) {
            System.out.println(e);
        }
    }
}

输出: Height:325

和获取方法的情况一下,获取字段的时候也可以只取得在当前cMx了的字段信息 (getDeclaredFields)Q或者也可以取得父类中定义的字段 (getFields) ?/font>


1.7 ҎҎ的名U来执行Ҏ

文本到这里,所丄例子无一例外都与如何获取cȝ信息有关。我们也可以?reflection 来做一些其它的事情Q比如执行一个指定了名称的方法。下面的CZ演示了这一操作Q?/font>

?:

import java.lang.reflect.*;
public class method2 {
   public int add(int a, int b) {
       return a + b;
   }
   public static void main(String args[]) {
       try {
           Class cls = Class.forName("method2");
           Class partypes[] = new Class[2];
           partypes[0] = Integer.TYPE;
           partypes[1] = Integer.TYPE;
           Method meth = cls.getMethod("add", partypes);
           method2 methobj = new method2();
           Object arglist[] = new Object[2];
           arglist[0] = new Integer(37);
           arglist[1] = new Integer(47);
           Object retobj = meth.invoke(methobj, arglist);
           Integer retval = (Integer) retobj;
           System.out.println(retval.intvalue());
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

假如一个程序在执行的某处的时候才知道需要执行某个方法,q个Ҏ的名U是在程序的q行q程中指定的 (例如QJavaBean 开发环境中׃做这L?Q那么上面的E序演示了如何做到?/font>

? 例中QgetMethod 用于查找一个具有两个整型参C名ؓ add 的方法。找到该Ҏq创Z相应?Method 对象之后Q在正确的对象实例中执行它。执行该Ҏ的时候,需要提供一个参数列表,q在上例中是分别包装了整?37 ?47 的两?Integer 对象。执行方法的q回的同h一?Integer 对象Q它装了返回?84?/font>

?Q?/p>

import java.lang.reflect.Method;

//Base.java 抽象基类
//Son1.java 基类扩展1
//Son2.java 基类扩展2
//Util.java

//Base.java 抽象基类只是一个定?br /> abstract class Base {

}

//Son1.java 是已l实现的Base
class Son1 extends Base {
    private int id;

    private String name;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public void son1Method(String s) {
        System.out.println(s);
    }
}

// Son2.java 是已l实现的Base
class Son2 extends Base {
    private int id;

    private double salary;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public double getSalary() {
        return salary;
    }

    public void setSalary(double salary) {
        this.salary = salary;
    }
}

// Util.java 演示了如何根据指定的cdQ类字段名和所对应的数据,得到一个类的实?br /> public class Util {
    // 此方法的最大好处是没有cdSon1,Son2 可以通过参数来指定,E序里面Ҏ不用出现
    public static Base utilDo(String beanName,
            String methodName, String paraValue) {
        Base base = null;
        try {
            Class cls = Class.forName(beanName);//生成c?br />             base = (Base) cls.newInstance();//生成cȝ对象
            Class[] paraTypes = new Class[] { String.class};
            Method method = cls.getMethod(methodName, paraTypes);// fieldSetter为方法的名称;paraTypesҎ的参数数l?要用cȝ形式
            String[] paraValues = new String[] { paraValue };
            method.invoke(base, paraValues);//执行Ҏ
        } catch (Throwable e) {
            System.err.println(e);
        }
        return base;
    }

    public static void main(String[] args) {
        Son1 son1 = (Son1) Util.utilDo("test.Reflection.Son1",
                "setName", "I am son1");// 表示cȝ字符串一定要是类?#8220;全类?#8221;,q里?/font>test.Reflection.Son1
        System.out.println("son1.getName() :" + son1.getName());
    }
}

输出Qson1.getName() :I am son1

1.8 创徏新的对象

对于构造器Q则不能像执行方法那栯行,因ؓ执行一个构造器意味着创徏了一个新的对?(准确的说Q创Z个对象的q程包括分配内存和构造对?。所以,与上例最怼的例子如下:

import java.lang.reflect.*;

public class constructor2 {
   public constructor2() {
   }

   public constructor2(int a, int b) {
       System.out.println("a = " + a + " b = " + b);
   }

   public static void main(String args[]) {
       try {
           Class cls = Class.forName("constructor2");
           Class partypes[] = new Class[2];
           partypes[0] = Integer.TYPE;
           partypes[1] = Integer.TYPE;
           Constructor ct = cls.getConstructor(partypes);
           Object arglist[] = new Object[2];
           arglist[0] = new Integer(37);
           arglist[1] = new Integer(47);
           Object retobj = ct.newInstance(arglist);
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

Ҏ指定的参数类型找到相应的构造函数ƈ执行它,以创Z个新的对象实例。用这U方法可以在E序q行时动态地创徏对象Q而不是在~译的时候创建对象,q一炚w常有价倹{?/font>

1.9 改变字段(?的?/font>

reflection 的还有一个用处就是改变对象数据字D늚倹{reflection 可以从正在运行的E序中根据名U找到对象的字段q改变它Q下面的例子可以说明q一点:

import java.lang.reflect.*;

public class field2 {
   public double d;

   public static void main(String args[]) {
       try {
           Class cls = Class.forName("field2");
           Field fld = cls.getField("d");
           field2 f2obj = new field2();
           System.out.println("d = " + f2obj.d);
           fld.setDouble(f2obj, 12.34);
           System.out.println("d = " + f2obj.d);
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

q个例子中,字段 d 的D变ؓ?12.34?/font>

1.10 使用数组

本文介绍?reflection 的最后一U用法是创徏的操作数l。数l在 Java 语言中是一U特D的cȝ型,一个数l的引用可以赋给 Object 引用。观察下面的例子看看数组是怎么工作的:

import java.lang.reflect.*;

public class array1 {
   public static void main(String args[]) {
       try {
           Class cls = Class.forName("java.lang.String");
           Object arr = Array.newInstance(cls, 10);
           Array.set(arr, 5, "this is a test");
           String s = (String) Array.get(arr, 5);
           System.out.println(s);
       } catch (Throwable e) {
           System.err.println(e);
       }
   }
}

例中创徏?10 个单位长度的 String 数组QؓW?5 个位|的字符串赋了|最后将q个字符串从数组中取得ƈ打印了出来?/font>

下面q段代码提供了一个更复杂的例子:

import java.lang.reflect.*;

public class array2 {
   public static void main(String args[]) {
       int dims[] = new int[]{5, 10, 15};
       Object arr = Array.newInstance(Integer.TYPE, dims);
       Object arrobj = Array.get(arr, 3);
       Class cls = arrobj.getClass().getComponentType();
       System.out.println(cls);
       arrobj = Array.get(arrobj, 5);
       Array.setInt(arrobj, 10, 37);
       int arrcast[][][] = (int[][][]) arr;
       System.out.println(arrcast[3][5][10]);
   }
}
? 中创Z一?5 x 10 x 15 的整型数l,qؓ处于 [3][5][10] 的元素赋了gؓ 37。注意,多维数组实际上就是数l的数组Q例如,W一?Array.get 之后Qarrobj 是一?10 x 15 的数l。进而取得其中的一个元素,即长度ؓ 15 的数l,q?Array.setInt 为它的第 10 个元素赋倹{?/font>

注意创徏数组时的cd是动态的Q在~译时ƈ不知道其cd?/font>



hanzao 2007-10-07 11:34 发表评论
]]>
վ֩ģ壺 ̨| | | | | | «Ϫ| ͨ| п| п| | Dz| ̨| | ֦| | | IJ| ľ| ˺| | | ɽ| | ֣| ½| կ| ֿ| ʯ| گ| ƽ| °| | β| ¦| | | ³ľ| | ͩ| ˳|