所采用的mysql数据库是rpm包方式安装
1. Master:修改/etc/my.cnf文件[mysqld]
[mysqld]
server-id = 1
log-bin
innodb_flush_log_at_trx_commit=1
sync_binlog=1
datadir=/var/lib/mysql
2. Slave:修改/etc/my.cnf文件[mysqld]
[mysqld]
server-id=2
datadir=/var/lib/mysql
3. Master:在master数据库设置用来同步的slave用户权限
GRANT REPLICATION SLAVE ON *.*
TO ' *本站禁止HTML标签噢* '@' *本站禁止HTML标签噢* '
IDENTIFIED BY ' *本站禁止HTML标签噢* ';
例: grant replication slave on *.* to 'repl'@'192.168.1.2' identified by '123456';
4.Master上锁表:flush tables with read lock;
解锁:unlock tables;
5. Master数据导到slave
打包/var/lib/mysql目录,然后scp拷贝到从库上,覆盖从库/var/lib/mysql目录
6. Master查看日志节点和Position信息
查看主库信息获得日志文件以及position
mysql> show master status;
+------------------+------------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+------------+--------------+------------------+
| mysql-bin.000596 | 1050931156 | | |
+------------------+------------+--------------+------------------+
7.从库同步
mysql>STOP SLAVE;
mysql>CHANGE MASTER TO
>MASTER_HOST=' *本站禁止HTML标签噢* ',
>MASTER_USER=' *本站禁止HTML标签噢* ',
>MASTER_PASSWORD=' *本站禁止HTML标签噢* ',
>MASTER_LOG_FILE='<see xtrabackup_binlog_info>',
>MASTER_LOG_POS=<see xtrabackup_binlog_info>;
mysql>START SLAVE;
执行完上述命令后
mysql> show slave status \G
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.1.2
Master_User: repl
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000596
Read_Master_Log_Pos: 1036007396
Relay_Log_File: localhost-relay-bin.000221
Relay_Log_Pos: 1036007533
Relay_Master_Log_File: mysql-bin.000596
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB:
Replicate_Do_Table:
Replicate_Ignore_Table:
Replicate_Wild_Do_Table:
Replicate_Wild_Ignore_Table:
Last_Errno: 0
Last_Error:
Skip_Counter: 0
Exec_Master_Log_Pos: 1036007396
Relay_Log_Space: 1036007533
Until_Condition: None
Until_Log_File:
Until_Log_Pos: 0
Master_SSL_Allowed: No
Master_SSL_CA_File:
Master_SSL_CA_Path:
Master_SSL_Cert:
Master_SSL_Cipher:
Master_SSL_Key:
Seconds_Behind_Master: 0
1 row in set (0.00 sec)
同步完成
[查看全文]
1.使用MyISAM而不是InnoDB
MySQL有很多数据库引擎,但是你最可能碰到的就是MyISAM和InnoDB。
MySQL默认使用的是MyISAM。但是,很多情况下这都是一个很糟糕的选择,除非你在创建一个非常简单抑或实验性的数据库。外键约束或者事务处理对于数据完整性是非常重要的,但MyISAM都不支持这些。另外,当有一条记录在插入或者更新时,整个数据表都被锁定了,当使用量增加的时候这会产生非常差的运行效率。
结论很简单:使用InnoDB。
2.使用PHP的mysql函数
PHP自产生之日就提供了MySQL库函数(or near as makes no difference)。很多应用仍然在使用类似mysql_connect、mysql_query、mysql_fetch_assoc等的函数,尽管PHP手册上说:
如果你在使用MySQL v4.1.3或者更新版本,强烈推荐使用您使用mysqli扩展。
mysqli(MySQL的加强版扩展)有以下几个优点:
可选的面向对象接口
prepared表达式,这有利于阻止SQL注入攻击,还能提高性能
支持更多的表达式和事务处理
另外,如果你想支持多种数据库系统,你还可以考虑PDO。
3.没有处理用户输入
这或者可以这样说#1:永远不要相信用户的输入。用服务器端的PHP验证每个字符串,不要寄希望与JavaScript。最简单的SQL注入攻击会利用如下的代码:
$username = $_POST["name"]; $password = $_POST["password"]; $sql = “SELECT userid FROM usertable WHERE username=’$username’ AND password=’$password’;”; // run query…
只要在username字段输入“admin’;–”,这样就会被黑到,相应的SQL语句如下:
SELECT userid FROM usertable WHERE username=’admin’;
狡猾的黑客可以以admin登录,他们不需要知道密码,因为密码段被注释掉了。
4.没有使用UTF-8
美国、英国和澳大利亚的我们很少考虑除英语之外的其他语言。我们很得意地完成了自己的“杰作”却发现它们并不能在其他地方正常运行。
UTF-8解决了很多国际化问题。虽然在PHP v6.0之前它还不能很好地被支持,但这并不影响你把MySQL字符集设为UTF-8。
5.相对于SQL,偏爱PHP
如果你接触MySQL不久,那么你会偏向于使用你已经掌握的语言来解决问题,这样会导致写出一些冗余、低效率的代码。比如,你不会使用MySQL自带的AVG()函数,却会先对记录集中的值求和然后用PHP循环来计算平均值。
此外,请注意PHP循环中的SQL查询。通常来说,执行一个查询比在结果中迭代更有效率。
所以,在分析数据的时候请利用数据库系统的优势,懂一些SQL的知识将大有裨益。
6.没有优化数据库查询
99%的PHP性能问题都是由数据库引起的,仅仅一个糟糕的SQL查询就能让你的web应用彻底瘫痪。MySQL的EXPLAIN statement、Query Profiler,还有很多其他的工具将会帮助你找出这些万恶的SELECT。
7.不能正确使用数据类型
MySQL提供了诸如numeric、string和date等的数据类型。如果你想存储一个时间,那么使用DATE或者DATETIME类型。如果这个时候用INTEGER或者STRING类型的话,那么将会使得SQL查询非常复杂,前提是你能使用INTEGER或者STRING来定义那个类型。
很多人倾向于擅自自定义一些数据的格式,比如,使用string来存储序列化的PHP对象。这样的话数据库管理起来可能会变得简单些,但会使得MySQL成为一个糟糕的数据存储而且之后很可能会引起故障。
8.在查询中使用*
永远不要使用*来返回一个数据表所有列的数据。这是懒惰:你应该提取你需要的数据。就算你需要所有字段,你的数据表也不可避免的会产生变化。
9.不使用索引或者过度使用索引
一般性原则是这样的:select语句中的任何一个where子句表示的字段都应该使用索引。
举个例子,假设我们有一个user表,包括numeric ID(主键)和email address。登录的时候,MySQL必须以一个email为依据查找正确的ID。如果使用了索引的话(这里指email),那么MySQL就能够使用更快的搜索算法来定位email,甚至可以说是即时实现。否则,MySQL就只能顺序地检查每一条记录直到找到正确的email address。
有的人会在每个字段上都添加索引,遗憾的是,执行了INSERT或者UPDATE之后这些索引都需要重新生成,这样就会影响性能。所以,只在需要的时候添加索引。
10.忘记备份!
虽然比较罕见,但是数据库还是有崩溃的危险。硬盘有可能损坏,服务器有可能崩溃,web主机提供商有可能会破产!丢失MySQL数据将会是灾难性的,所以请确保你已经使用了自动备份或者已经复制到位。
11.Bonus mistake-不考虑使用其他数据库
对于PHP开发人员来说,MySQL可能是使用最广泛的数据库系统,但并不是唯一的选择。PostgreSQL和Firebird是最强有力的竞争者:这个两者都是开源的,而且都没有被公司收购。微软提供了sql server Express,甲骨文提供了10g Express,这两者都是企业级数据库的免费版本。有时候,对于一个较小的web应用或者嵌入式应用,SQLite也不失为一个可行的替代方案。
[查看全文]
本帖最后由 Bugsong 于 2012-12-26 11:47 编辑
原创发表于:离线使用Opera Dragonfly 1.1 | 大D综合研究院
原文链接:http://www.dadclab.com/archives/815
本文采用知识共享署名-非商业性使用-相同方式共享 2.5 中国大陆许可协议进行许可。
协议查看链接:http://creativecommons.org/licenses/by-nc-sa/2.5/cn/
Opera是一款由挪威Opera Software ASA制作的支持多页面标签式浏览的网络浏览器,功能强大,支持Windows/Linux/Mac等多种操作系统,同时还支持手机、PDA、游戏终端以及其它联网设备如任天堂Wii、NDS及NDSi,索尼Mylo等等。
Bugsong蛮喜欢使用这个浏览器的。哈哈。。在WordPress主题的更改过程中,更少不了Opera的帮助。。其中帮助最大的便是Opera的开发人员工具——Opera Dragonfly了,因为加载的时候会有一只蜻蜓挥动翅膀,便取名为蜻蜓。。P.S话说Opera中文版的名字为“朱雀”,台湾版为“三太子”~~嘿嘿。。
话说蜻蜓加载的时候不像Firebug调用本地资源,蜻蜓是调用Opera服务器上的资源,这样在无法接入网络或者网速奇慢的时候,使用该功能变成了问题。。还好我们可以在Opera的服务器上下载到Opera Dragonfly,释放到本地,再设置一下就OK了~
方法如下:
1、首先到http://dragonfly.opera.com/app/zips/下载Dragonfly的程序,这里是英文版,需要中文的同学在这个网址下找一找,会有中文版的文件的。。文件名为client-zh-cn.zip,解压掩盖英文程序的文件。
2、释放到本地目录。
3、打开opera浏览器,在地址栏输入:Opera:config进入设置界面,修改developer tools选项下developer tools url,改成file://localhost/你的文件路径/client-en.xml,保存。
P.P.S中文版的路径为file://localhost/你的文件路径/client-zh-cn.xml
重启浏览器后生效~
[查看全文]
本帖最后由 Bugsong 于 2012-12-26 11:47 编辑
原创发表于:硬件解码和视频格式那点事 | 大D综合研究院
原文链接:http://www.dadclab.com/archives/818
本文采用知识共享署名-非商业性使用-相同方式共享 2.5 中国大陆许可协议进行许可。
协议查看链接:http://creativecommons.org/licenses/by-nc-sa/2.5/cn/
零、软解
在硬件解码出现之前,所有的音视频编码都是由CPU执行软件解码器,著名的软解码器CoreAVC,其性能可以跟一些硬件解码器相媲美。
硬件解码即使用GPU资源来处理音视频解码,采用相关技术通过后期处理来完成显示画面
软件解码即使用CPU来全程处理音视频解码。
一、硬解技术观礼
Nvdia:Nv显卡在硬件解码方面推出了PureVideo技术和PureVideo HD技术。
Amd:Amd显卡在硬件解码方面推出了AMD Avivo技术和AMD Avivo HD技术。
Intel:Intel显卡在硬件解码方面推出了Intel Clear Video技术。
SiS:Real Video技术。
VIA(VIA是在收购了S3 Graphics之后才设计图形处理核心业务):Chromotion技术。
二、简介硬解技术这里仅介绍NV/AMD/Intel三家的技术。
Nvidia:
1、PureVideo
Nv开发的PureVideo技术支持MPEG2,VC-1以及WMV9硬件解码,同时加入了众多提升视频清晰度的技术,在音频方面增加了杜比数字环绕声解码。
支持该技术的显卡有:
GeForce6系列显卡,但NV40/NV45/NV48显示核心的显卡不支持WMV9硬件加速。
GeForce7系列显卡。
2、PureVideo HD(第一代)
PureVideo HD(第一代)技术主要添加了H.264硬件解码的支持和支持HDMI输出。
增加了图像色彩校正技术。
仅仅需要更新驱动程序即可支援该技术。
支持该技术的显卡有:
GeForce6系列显卡。
GeForce7系列显卡。
GeForce6150集成显卡(集成于nForce4/C51)
3、PureVideo HD(第二代)
第二代PureVideo HD技术支持HDCP数字版权技术。
支持边缘强化和噪声消除技术。
增加支持WMV-HD和MPEG-HD硬件解码。
支持该技术的显卡有:
GeForce8系列(G80核心 8800显卡显卡除外)以及GeForce8之后全系列GeForce显卡。
P.S:GeForce6100集成显卡(集成于nForce4/C51)不支持所有硬件解码技术
AMD:
1、AMD Avaio
AMD/ATI的Avaio技术在解码支持方面全面支持所有的高清视频编码格式。同样集成众多提升清晰度的技术。
支持该技术的显卡有:
ATi X1300/X1600/X1800/X1900系列。
ATi HD2000/HD3000/HD4000系列。
AMD HD5000/HD6000系列。
2、AMD Avaio HD
该技术对GPU增加了UVD通用视频解码器,对显卡硬件加速的工作形式进行了调整,开始全程参与硬件解码。
增加了UVD通用视频解码器的显卡有:
ATI HD2400/HD2600系列及以后的AMD显卡产品。
Intel:
Intel在图形处理方面一直居于NV以及AMD的后面。在显卡高清解码上从Intel GMA X4500(G45系列主板集成显卡)才开始支持。
三、视频格式那点事首先区分一下编码格式和封装格式。
在音视频文件上,最常见的格式便是AVI/RM/RMVB/MP4/MKV等等,这些体现在格式上的都是封装格式。
封装格式形象的来讲,就是一个容器,像一个杯子,用于盛放视频和音频内容。
封装格式并不代表该视频是否可以硬解,是否可以硬解,需要封装格式和编码格式都满足才可以进行硬件解码。
当然。。也有高清专属的格式。。比如m2ts和ts。(这也是封装格式)
不同的封装格式,能存放的视音频轨道数量也是不同的。在常见的视频格式中,MKV可以存放很多的音视频轨道,这就是为什么在网上下载到的多国语言的电影多用MKV格式的原因。
四、最常见的高清编码格式
MPEG-2/MPEG-4:
标准英文名称为Moving Picture Expert Group,最初用于高质量工业标准图像的编码,在高清视频流行后也用于高清视频流,DVD光盘中的.VOB文件就基于MPEG-2编码,而MPEG-4于1998年出现,专门针对高质量视频设计,压缩比较MPEG-2更高,比特率可以伸缩,是较为常见的一种高清视频编码格式。
H.264:
目前最热的高清编码格式,不少1080p影片都用此编码,是ITU-T的VCEG和活动图像编码专家组的联合视频组(JVT:joint video team)开发的一个数字视频编码标准,基于DPCM加变换编码的混合编码模式,视频质量优秀,但在解码时对硬件的要求较高。
VC-1:
非常高效的高清视频编码标准,最早来源于微软,从WMV9演化而来,在压缩效率和清晰度方面和H.264旗鼓相当,但二者更有不同,一般来说来源于H.264编码的文件所占空间小一些,VC-1在解码时计算更少,对硬件的要求更低。
以上几种编码格式的视频加上MP4/MKV/AVI/m2ts/ts等支持硬件解码的封装格式。。就可以硬件解码了哦~~嘿嘿……
说说RM吧。。可能有些朋友要问了,那些1080P的RMVB电影不是高清么?
Bugsong认为,这种影片只能叫做大分辨率影片,RealMedia在视频压缩上的能力非常之强大,但是压缩后的视频颜色不准确,细节不完整,仅仅是大分辨率影片而已了。
RM和RMVB的区别就是RMVB支持变长码率,可以在动作少的画面采用低码率,在动作激烈的场面使用高码率,来达到更好地压缩率。
在彻底无损不压缩的状态,仅仅是一部5分钟的静止画面+字幕的影片,就需要30G以上的硬盘空间。。
对编解码器有兴趣的同学,可以访问维基百科哦~上面有很明确的介绍。。
五、怎样辨别高清视频嘛。这个问题。。
其实大家多逛逛人人美剧/CHD联盟/圣城家园就可以了。。
在这些站点下载到的视频,名称都像是这样的。
Transformers.Dark.Of.The.Moon.2011.BluRay.720p.x264.AC3.mkv
好理解了吧。720P表示分辨率为1280×720,x264表示采用H.264/AVC视频编码,AC3是音频编码格式。
有的还会有Chi_Eng,这个表示英语原声+中文字幕。
[查看全文]

本帖最后由 米奥十八 于 2013-5-20 00:51 编辑
没人有发,于是不要脸的来个借花献佛
外观党福音
作为完全搞不懂程序的人来说,不知道他和vc6.0有什么区别,如果一定要说点什么的话,大概就是——
哇,看起来好牛逼的样子!#17x
【作为外观党的我来说也就只能这样了……
下载地址:
http://www.microsoft.com/visualstudio/chs/downloads
点击express版的
如图,请下载这个
大小为635mb,解压后有4个多G
官方内置中文版的,直接点点点点就可以安装了,反正你们都懂得
安装的试用期只有30天,到网站注册一个用户,可以得到code,在电脑上激活就可以免费使用了
vs2012 express 版开发的软件不可以商用,请一定注意这一点哦#24x
[查看全文]
The C++ Programming Language (3rd Edition)
副标题: Special Edition (3rd Edition)
作者: Bjarne Stroustrup
出版社: Addison-Wesley Professional
出版年: 2000-02-11
页数: 1019
定价: $74.99
装帧: Hardcover
ISBN: 9780201700732
C++之父Stroustrup博士写的
将其对C++语言要义的理解、对编程精髓的把握、致C++程序员的箴言融会在这本书中
值得收藏和细细品味。
英文原版
封面:
阅读截图:
百度网盘下载:
本帖最后由 安小白 于 2012-12-27 23:23 编辑
!26~第一次瞎晃悠看到这个论坛!035~感觉还不错哟,新人来报道啦,看到一大堆新手任务,我了个汗,好多帖子都不能回复,权限不够!1~ 呼吸,话说明年4月分马上要找工作了,现在分享一下老师发给我们的面试的一小部分J2EE试题
1、垃圾回收的优点和原理。
Java语言中一个显著的特点就是引入了垃圾回收机制,使c++程序员最头疼的内存管理的问题迎刃而解,它使得Java程序员在编写程序的时候不再需要考虑内存管理。由于有个垃圾回收机制,Java中的对
象不再有“作用域”的概念,只有对象的引用才有“作用域”。垃圾回收可以有效的防止内存泄露,有效
的使用可以使用的内存。垃圾回收器通常是作为一个单独的低级别的线程运行,不可预知的情况下对内存
堆中已经死亡的或者长时间没有使用的对象进行清楚和回收,程序员不能实时的调用垃圾回收器对某个对
象或所有对象进行垃圾回收。
2、请说出你所知道的线程同步的方法。
wait():使一个线程处于等待状态,并且释放所持有的对象的lock。
sleep():使一个正在运行的线程处于睡眠状态,是一个静态方法,调用此方法要捕捉
InterruptedException异常。
notify():唤醒一个处于等待状态的线程,注意的是在调用此方法的时候,并不能确切的唤醒某一
个等待状态的线程,而是由JVM确定唤醒哪个线程,而且不是按优先级。
Allnotity():唤醒所有处入等待状态的线程,注意并不是给所有唤醒线程一个对象的锁,而是让它
们竞争。
3、在java中一个类被声明为final类型,表示了什么意思?
表示该类不能被继承,是顶级类。
4、 Error与Exception有什么区别?
Error表示系统级的错误和程序不必处理的异常,
Exception表示需要捕捉或者需要程序进行处理的异常。
5、&和&&的区别。
&是位运算符。&&是布尔逻辑运算符。
6、Collection 和 Collections的区别。
Collections是个java.util下的类,它包含有各种有关集合操作的静态方法。
Collection是个java.util下的接口,它是各种集合结构的父接口。
7、 HashMap和Hashtable的区别。
都属于Map接口的类,实现了将惟一键映射到特定的值上。
HashMap 类没有分类或者排序。它允许一个 null 键和多个 null 值。
Hashtable 类似于 HashMap,但是不允许 null 键和 null 值。它也比 HashMap 慢,因为它是同步的。
8、GC是什么? 为什么要有GC? .
GC是垃圾收集器。Java 程序员不用担心内存管理,因为垃圾收集器会自动进行管理。要请求垃圾收
集,可以调用下面的方法之一:System.gc()
Runtime.getRuntime().gc()
9、谈谈final, finally, finalize的区别。
final—修饰符(关键字)如果一个类被声明为final,意味着它不能再派生出新的子类,不能作为父类被继承。因此一个类不能既被声明为 abstract的,又被声明为final的。将变量或方法声明为final,可以保证它们在使用中不被改变。被声明为final的变量必须在声明时给定初值,而在以后的引用]中只能读取,不可修改。被声明为final的方法也同样只能使用,不能重载。
finally—再异常处理时提供 finally 块来执行任何清除操作。如果抛出一个异常,那么相匹配的 catch 子句就会执行,然后控制就会进入 finally 块(如果有的话)。
finalize—方法名。Java 技术允许使用 finalize() 方法在垃圾收集器将对象从内存中清除出去
之前做必要的清理工作。这个方法是由垃圾收集器在确定这个对象没有被引用时对这个对象调用的。它是在 Object 类中定义的,因此所有的类都继承了它。子类覆盖 finalize() 方法以整理系统资源或者执行其他清理工作。finalize() 方法是在垃圾收集器删除对象之前对这个对象调用的。
10、String s = new String("xyz");创建了几个String Object?
两个对象,一个是"xyz",一个是指向"xyz"的引用对象s。
11、Math.round(11.5)等於多少? Math.round(-11.5)等於多少?
Math.round(11.5)返回(long)12,Math.round(-11.5)返回(long)-11;
12、Java有没有goto?
Goto—java中的保留字,现在没有在java中使用。
13、 sleep() 和 wait() 有什么区别?
sleep()方法是使线程停止一段时间的方法。在sleep 时间间隔期满后,线程不一定立即恢复执行。
这是因为在那个时刻,其它线程可能正在运行而且没有被调度为放弃执行,除非(a)"醒来"的线程具有更
高的优先级 (b)正在运行的线程因为其它原因而阻塞。
wait()是线程交互时,如果线程对一个同步对象x 发出一个wait()调用,该线程会暂停执行,被调对象进入等待状态,直到被唤醒或等待时间到。
数组有没有length()这个方法? String有没有length()这个方法?
在java里面数组没有length()这个方法,有length的属性。String有有length()这个方法。在c#数组和string只有length属性,没有方法.
14、 error和exception有什么区别?
1 Error表示系统级的错误和程序不必处理的异常,
Exception表示需要捕捉或者需要程序进行处理的异常。
2 error 表示恢复不是不可能但很困难的情况下的一种严重问题。比如说内存溢出。不可能指望程序能处理这样的情况。
exception 表示一种设计或实现问题。也就是说,它表示如果程序运行正常,从不会发生的情况。
15、List, Set, Map是否继承自Collection接口?
List,Set是 ,Map不是
16、是否可以继承String类?
String类是final类故不可以继承。
17、 构造器Constructor是否可被override?
不能重写 Overriding,但可以被重载Overloading。
18、 try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行,什么时候被
执行,在return前还是后?
会执行,在return前执行。
19、用最有效率的方法算出2乘以8等於几?
2 << 3
20、作用域public,private,protected,以及不写时的区别
区别如下:
作用域当前类同一package 子孙类 其他package
public √ √ √ √
protected √ √ √ ×
friendly √ √ × ×
private √ × × ×
不写时默认为friendly
21、 abstract class和interface有什么区别?
声明方法的存在而不去实现它的类被叫做抽象类(abstract class),它用于要创建一个体现某些基本行
为的类,并为该类声明方法,但不能在该类中实现该类的情况。不能创建abstract 类的实例。然而可以
创建一个变量,其类型是一个抽象类,并让它指向具体子类的一个实例。不能有抽象构造函数或抽象静态
方法。Abstract 类的子类为它们父类中的所有抽象方法提供实现,否则它们也是抽象类为。取而代之,
在子类中实现该方法。知道其行为的其它类可以在类中实现这些方法。
接口(interface)是抽象类的变体。在接口中,所有方法都是抽象的。多继承性可通过实现这样
的接口而获得。接口中的所有方法都是抽象的,没有一个有程序体。接口只可以定义static final成员变
量。接口的实现与子类相似,除了该实现类不能从接口定义中继承行为。当类实现特殊接口时,它定义(
即将程序体给予)所有这种接口的方法。然后,它可以在实现了该接口的类的任何对象上调用接口的方法
。由于有抽象类,它允许使用接口名作为引用变量的类型。通常的动态联编将生效。引用可以转换到接口
类型或从接口类型转换,instanceof 运算符可以用来决定某对象的类是否实现了接口
22、ArrayList和Vector的区别,HashMap和Hashtable的区别
答:就ArrayList与Vector主要从二方面来说.
一.同步性:Vector是线程安全的,也就是说是同步的,而ArrayList是线程序不安全的,不是同步的
二.数据增长:当需要增长时,Vector默认增长为原来一培,而ArrayList却是原来的一半
就HashMap与HashTable主要从三方面来说。
一.历史原因:Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实
现
二.同步性:Hashtable是线程安全的,也就是说是同步的,而HashMap是线程序不安全的,不是同步
的
三.值:只有HashMap可以让你将空值作为一个表的条目的key或value
23、 char型变量中能不能存贮一个中文汉字?为什么?
是能够定义成为一个中文的,因为java中以unicode编码,一个char占16个字节,所以放一个中文是没问题的
24、 float型float f=3.4是否正确?
答:不正确。精度不准确,应该用强制类型转换,如下所示:float f=(float)3.4
STRING与STRINGBUFFER的区别。
答:STRING的长度是不可变的,STRINGBUFFER的长度是可变的。如果你对字符串中的内容经常进行操
作,特别是内容要修改时,那么使用StringBuffer,如果最后需要String,那么使用StringBuffer的toString()方法.
25、 说出ArrayList,Vector, LinkedList的存储性能和特性
ArrayList和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插
入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据
快而插入数据慢, Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差,而
LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记
录本项的前后项即可,所以插入速度较快。
继承时候类的执行顺序问题,以下代码显示什么结果。
父类:public class FatherClass {
public FatherClass() {
System.out.println("FatherClass Create"); }
}
子类: import 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(); }
} //执行java ChildClass
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 语句。
5.Class.forName的作用?
调用该访问返回一个以字符串指定类名的类的对象。
6.Servlet
Servlet的生命周期是什么?
servlet有良好的生存期的定义,包括加载和实例化、初始化、处理请求以及服务结束。这个生存期
由javax.servlet.Servlet接口的init,service和destroy方法表达。
7.servlet会话跟踪技术
用户认证,持久cookies,URL重写,隐藏表单字段,会话交换和持久
8.XML
xml有哪些解析技术?区别是什么?
答:主要有DOM,SAX等
DOM:处理大型文件时其性能下降的非常厉害。这个问题是由DOM的树结构所造成的,这种结构占用
的内存较多,而且DOM必须在解析文件之前把整个文档装入内存,适合对XML的随机访问
SAX:不同于DOM,SAX是事件驱动型的XML解析方式。它顺序读取XML文件,不需要一次全部装载整个
文件。当遇到像文件开头,文档结束,或者标签开头与标签结束时,它会触发一个事件,用户通过在其回
调事件中写入处理代码来处理XML文件,适合对XML的顺序访问
9.项目中主要用到xml技术的哪些方面?如何实现的?
答:用到了数据存贮,信息配置两方面。在做数据交换平台时,将不同数据源的数据组装成XML文件,
然后将XML文件压缩打包加密后通过网络传送给接收者,接收解密与解压缩后再同XML文件中还原相关信息
进行处理。
在做软件配置时,利用XML可以很方便的进行,软件的各种配置参数都存贮在XML文件中。
10.EJB
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组件。
EJB容器提供的服务
主要提供声明周期管理、代码产生、持续性管理、安全、事务管理、锁和并发行管理等服务。
EJB的角色和三个对象
EJB角色主要包括Bean开发者 应用组装者 部署者 系统管理员 EJB容器提供者 EJB服务器提供者
三个对象是Remote(Local)接口、Home(LocalHome)接口,Bean类
EJB 的几种类型
会话(Session)Bean ,实体(Entity)Bean 消息驱动的(Message Driven)Bean
会话Bean又可分为有状态(Stateful)和无状(Stateless)两种
实体Bean可分为Bean管理的持续性(BMP)和容器管理的持续性(CMP)两种
11.bean 实例的生命周期
对于Stateless Session Bean、Entity Bean、Message Driven Bean一般存在缓冲池管理,而对于
Entity Bean和Statefull Session Bean存在Cache管理,通常包含创建实例,设置上下文、创建EJB
Object(create)、业务方法调用、remove等过程,对于存在缓冲池管理的Bean,在create之后实例并不
从内存清除,而是采用缓冲池调度机制不断重用实例,而对于存在Cache管理的Bean则通过激活和去激活
机制保持Bean的状态并限制内存中实例数量。
12.weblogic
如何设定的weblogic的热启动模式(开发模式)与产品发布模式?
可以在管理控制台中修改对应服务器的启动模式为开发或产品模式之一。或者修改服务的启动文件或
者commenv文件,增加
set PRODUCTION_MODE=true
如何启动服务时不需输入用户名与密码?
修改服务启动文件,增加 WLS_USER和WLS_PW项。也可以在boot.properties文件中增加加密过的用
户名和密码.
在weblogic管理制台中对一个应用域(或者说是一个网站,Domain)进行jms及ejb或连接池等相关信息进行
配置后,实际保存在什么文件中?
保存在此Domain的config.xml文件中,它是服务器的核心配置文件。
如何查看在weblogic中已经发布的EJB?
可以使用管理控制台,在它的Deployment中可以查看所有已发布的EJB
说说weblogic中一个Domain的缺省目录结构?比如要将一个简单的helloWorld.jsp放入何目录下,然的在浏
览器上就可打入http://主机:端口号//helloword.jsp就可以看到运行结果了? 又比如这其中用到了一个
13.自己写的javaBean该如何办?
Domain目录/服务器目录/applications,将应用目录放在此目录下将可以作为应用访问,如果是Web
应用,应用目录需要满足Web应用目录要求,jsp文件可以直接放在应用目录中,Javabean需要放在应用目
录的WEB-INF目录的classes目录中,设置服务器的缺省应用将可以实现在浏览器上无需输入应用名。
在weblogic中发布ejb需涉及到哪些配置文件
不同类型的EJB涉及的配置文件不同,都涉及到的配置文件包括ejb-jar.xml,weblogic-ejb-
jar.xmlCMP实体Bean一般还需要weblogic-cmp-rdbms-jar.xml
EJB需直接实现它的业务接口或Home接口吗,请简述理由.
远程接口和Home接口不需要直接实现,他们的实现代码是由服务器产生的,程序运行中对应实现类
会作为对应接口类型的实例被使用。
JAVA华为面试题
JAVA方面:
1 面向对象的特征有哪些方面
2 String是最基本的数据类型吗?
3 int 和 Integer 有什么区别
4 String 和StringBuffer的区别
5运行时异常与一般异常有何异同?
6 说出一些常用的类,包,接口,请各举5个
7 说出ArrayList,Vector, LinkedList的存储性能和特性
8.设计4个线程,其中两个线程每次对j增加1,另外两个线程对j每次减少1。写出程序。
9. JSP的内置对象及方法。
10.用socket通讯写出客户端和服务器端的通讯,要求客户发送数据后能够回显相同的数据。
11用socket通讯写出客户端和服务器端的通讯,要求客户发送数据后能够回显相同的数据。
12.EJB是基于哪些技术实现的?并说出SessionBean和EntityBean的区别,StatefulBean和StatelessBean
的区别。
13.EJB包括(SessionBean,EntityBean)说出他们的生命周期,及如何管理事务的?
14.说出数据连接池的工作机制是什么?
15同步和异步有和异同,在什么情况下分别使用他们?举例说明。
16应用服务器有那些?
17你所知道的集合类都有哪些?主要方法?
18给你一个:驱动程序A,数据源名称为B,用户名称为C,密码为D,数据库表为T,请用JDBC检索出表T的所有
数据。
19说出在JSP页面里是怎么分页的?
数据库方面:
20.存储过程和函数的区别
21事务是什么?
22. 游标的作用?如何知道游标已经到了最后?
23.触发器分为事前触发和事后触发,这两种触发有和区别。语句级触发和行级触发有何区别。
!13~希望这些对一些学习J2EE的童鞋有一点帮助。。
[查看全文]