C软件工程师入职笔试题及答案.pdfVIP

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

一、简答题(共50分)

1.你常用的主机、OS、编译工具和调试工具是什么。如何查看系统进程信

息,你常用的进程管理命令有哪些?(问题尽量基于你常用的Unix环境作答)。

(10分)

答:我常用的是Sun主机,操作系统一般是Solaris8或Solaris10。编译工具包

括:g++,gcc,cc等。调试工具包括:gdb。(该项了解应聘者对编程环境的偏

好,无标准答案。)

常用的进程管理命令是:

查看:prstat-a或top

管理:plddpid显示链接到每个进程的动态链接库

pstackpid显示十六进制与符号堆跟踪信息

fuserfiles

pwdxpid查看进程运行目录

ptreepid查看进程树信息

2.C中的malloc和C++中的new有什么区别。(10分)

答:malloc和new有以下不同:

(1)new、delete是操作符,可以重载,只能在C++中使用。

(2)malloc、free是函数,可以覆盖,C、C++中都可以使用。

(3)new可以调用对象的构造函数,对应的delete调用相应的析构函数。

(4)malloc仅仅分配内存,free仅仅回收内存,并不执行构造和析构函数。

(5)new、delete返回的是某种数据类型指针,malloc、free返回的是void指

针。

注意:malloc申请的内存空间要用free释放,而new申请的内存空间要用delete

释放,不要混用。因为两者实现的机理不同。

3、简述结构化的程序设计、面向对象的程序设计的基本思想。(10分)

答:结构化的程序设计将数据和对数据的操作分离,程序是由一个个的函数组

成的,面向对象的程序设计将数据和操作封装在一起,程序是由一个个对象组

成的,对象之间通过接口进行通信,它能够较好地支持程序代码的复用。

4、一个oracle实例是由SGA和哪几个后台进程组成的?SGA有哪些组成部分

及简述它们的作用?PGA是什么??(10分)

答:后台进程:系统监控和进程监控进程(SMON和PMON)、数据库写进程

(DBWR)、日志写进程(LGWR)、归档进程(ARCH)、检查点

(CKPT);

其它可选进程:调度进程(Dnnn)、恢复进程(RECO)、快照进程

(SNPn)、锁进程(LCKn)、并行查询进程(Pnnn)。

数据写进程(dbwr):负责将更改的数据从数据库缓冲区高速缓存写入数据文

件;

日志写进程(lgwr):将重做日志缓冲区中的更改写入在线重做日志文件;

系统监控(smon):检查数据库的一致性如有必要还会在数据库打开时启动数据

库的恢复;

进程监控(pmon):负责在一个Oracle进程失败时清理资源;

检查点进程(chpt):负责在每当缓冲区高速缓存中的更改永久地记录在数据库中

时,更新控制文件和数据文件中的数据库状态信息;

归档进程(arcn):在每次日志切换时把已满的日志组进行备份或归档;

作业调度器(cjq):负责将调度与执行系统中已定义好的job,完成一些预定义的工

作;

恢复进程(reco):保证分布式事务的一致性,在分布式事务中,要么同时commit,要

么同时rollback。

SGA包含:db_cache、shared_pool、large_pool、java_pool

db_cache:数据库缓存(BlockBuffer)占据Oracle数据库SGA(系统共享内存

区)的主要部分,Oracle数据库通过使用LRU算法,将最近访问的数据块存放

到缓存中,从而优化对磁盘数据的访问;

shared_pool:共享池中保存数据字典高速缓冲和完全解读或编译的的PL/SQL

块和SQL语句及控制结构;

large_pool:使用MTS配置时,因为要在SGA中分配UGA来保持用户的会

话,就是用Large_pool来保持这个会话内存;使用RMAN做备份的时候,要使

用Large_pool这个内存结构来做磁盘I/O缓存器;

java_pool:为javaprocedure预备的内存区域,如果没有使用jav

文档评论(0)

180****7695 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档