分页显示数据库表中的记录

分页显示数据库表中的记录
分页显示数据库表中的记录

利用以下技术来实现对Oracle数据库中的表Emp中的全部记录实行分页显示。

技术点:(JSP+Servlet+JavaBean+c3p0+Oracle)

1、com.sun.pojo类

代码:

package com.sun.pojo;

import java.io.Serializable;

import java.util.Date;

public class Emp implements Serializable {

private static final long serialVersionUID = 1L;

private Integer empno;// 员工编号

private String ename;// 员工姓名

private String job;// 工种

private Integer mgr;// 上级经理编号

private Date hiredate;// 入职日期

private Double sal;// 薪水

private Double comm;// 津贴

private Integer deptno;// 部门编号

public Emp() {

// no op

}

public Integer getEmpno() {

return empno;

}

public void setEmpno(Integer empno) { this.empno = empno;

}

public String getEname() {

return ename;

}

public void setEname(String ename) { this.ename = ename;

}

public String getJob() {

return job;

}

public void setJob(String job) {

this.job = job;

}

public Integer getMgr() {

return mgr;

}

public void setMgr(Integer mgr) {

this.mgr = mgr;

}

public Date getHiredate() {

return hiredate;

}

public void setHiredate(Date hiredate) { this.hiredate = hiredate;

}

public Double getSal() {

return sal;

}

public void setSal(Double sal) {

this.sal = sal;

}

public Double getComm() {

return comm;

}

public void setComm(Double comm) { https://www.360docs.net/doc/b915302878.html,m = comm;

}

public Integer getDeptno() {

return deptno;

}

public void setDeptno(Integer deptno) {

this.deptno = deptno;

}

}

2、分页封装类

package com.sun.page;

import java.util.List;

/**

* 分页封装类.可以适用于任何一张表

* @author Administrator

*

*/

@SuppressWarnings("unchecked")

public class Pager {

private static final int size = 5;//设置每页显示几行private int totalpage;//设置总页数--即(表的记录数/行数)+1或者(表的记录数/size)

private List list;//设置把分页后的数据放到此List集合

/**

*

* @return返回每页显示几行

*/

public static int getSize() {

return size;

}

/**

*

* @return返回的总页数

*/

public int getTotalpage() {

return totalpage;

}

/**

* 设置总页数--即(表的记录数/行数)+1或者(表的记录数/行数) *

* @param totalpage

* 总页数

*/

public void setTotalpage(int totalpage) { this.totalpage = totalpage;

}

public List getList() {

return list;

}

/**

* 设置把分页后的数据放到此List集合

*

* @param list

*/

public void setList(List list) {

this.list = list;

}

}

3、dao类--

3.1---连接数据库的工具类(使用了连接池) package com.sun.dao;

import java.beans.PropertyVetoException;

import java.sql.Connection;

import java.sql.Statement;

import java.sql.ResultSet;

import java.sql.SQLException;

import https://www.360docs.net/doc/b915302878.html,boPooledDataSource;

public class DBUtil {

private static ComboPooledDataSource cpd;// 创建c3p0连接池的数据源对象

// 使用单例模式创建连接池

static {

String driverName = "oracle.jdbc.driver.OracleDriver";

String url = "jdbc:oracle:thin:@127.0.0.1:1521:orcl";

String user = "scott";

String password = "tiger";

cpd = new ComboPooledDataSource();

try {

// 使用连接池连接数据库

cpd.setDriverClass(driverName);

cpd.setJdbcUrl(url);

cpd.setUser(user);

cpd.setPassword(password);

// 设置连接池管理属性

cpd.setMaxPoolSize(10);// 设置连接池中最大连接数目

cpd.setInitialPoolSize(5);// 设置连接池中初始化连接数目

cpd.setAcquireIncrement(3);// 自动增长数目

cpd.setMaxStatements(50);// 最大执行sql语句(一次可以执行多少条sql语句)

} catch (PropertyVetoException pve) {

pve.printStackTrace();

}

}

/**

* 获得数据库的连接

*

* @return Connection对象

*/

public static Connection getConnection() {

Connection conn = null;

try {

conn = cpd.getConnection();// 从c3p0连接池获得数据库连接} catch (SQLException sqle) {

sqle.printStackTrace();

}

return conn;

}

/**

* 关闭数据库连接

*

* @param conn

* Connection对象

* @param ps

* Statement对象

* @param rs

* ResultSet对象

*/

public static void close(Connection conn, Statement ps, ResultSet rs) { try {

if (rs != null) {

rs.close();

}

if (ps != null) {

ps.close();

}

if (conn != null) {

conn.close();

}

} catch (SQLException e) {

e.printStackTrace();

}

}

}

3.2----表的操作类package com.sun.dao;

import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet;

import java.sql.SQLException; import java.util.ArrayList;

import java.util.List;

import com.newer.page.Pager; import com.newer.pojo.Emp;

/**

* 把emp表按照固定的行数分页* @author Administrator

*

*/

public class EmpDao {

/**

*

* @param pageno

* 表示查询emp表中的第几页

* @return 返回一个List集合,集合中存放的是emp表中的第几页的记录

*/

public List find(int pageno) {

Connection conn = null;

PreparedStatement ps = null;

ResultSet rs = null;

List list = new ArrayList();

try {

conn = DBUtil.getConnection();

String sql = "select * from (select row_number() over (order by empno) rn,emp.* from emp) where rn>? and rn<=?";

//此页面开始行数的位置(不含)

//Pager.getSize()表示每一页要显示的行数。pageno表示第几页

int begin = Pager.getSize() * (pageno - 1);

//此页面结束行数的位置(含)

int end = Pager.getSize()*pageno ;

System.out.println("从第" + (begin+1) + " 条到第" + end + " 条数据");

ps = conn.prepareStatement(sql);

ps.setInt(1, begin);

ps.setInt(2, end);

rs = ps.executeQuery();

while (rs.next()) {// 循环结果集。

// 从结果集中获得一条(行)记录,且封装到POJO类emp

Emp emp = new Emp();

emp.setEmpno(rs.getInt("empno"));

emp.setEname(rs.getString("ename"));

emp.setJob(rs.getString("job"));

emp.setMgr(rs.getInt("mgr"));

emp.setHiredate(rs.getDate("hiredate"));

emp.setSal(rs.getDouble("sal"));

emp.setComm(rs.getDouble("comm"));

emp.setDeptno(rs.getInt("deptno"));

list.add(emp);// 把一行记录的对象添加到集合

}

} catch (SQLException e) {

e.printStackTrace();

} finally {

DBUtil.close(conn, ps, rs);

}

return list;

}

/**

* 查询任何一张表中的所有记录数需要多少页能够全部显示出来(每页显示固定的行数:Pager类中已经指定了)-实现分页功能的基础* 例如:一张表中有54条记录,现在每一页显示10条记录,则需要6页来显示。

*

* @param tablename

* 要查询的表名

* @return 返回所查询表需要分页显示的总页数

*/

public int getTotalPage(String tablename) {

Connection conn = null;

PreparedStatement ps = null;

ResultSet rs = null;

int total = 0;//所查询表的全部记录数

try {

conn = DBUtil.getConnection();

String sql = "select count(*) from " + tablename;

ps = conn.prepareStatement(sql);

rs = ps.executeQuery();

if (rs.next()) {

//所查询表当中的全部记录数目-->即一张表有多少条记录

total = rs.getInt(1);

}

} catch (SQLException e) {

e.printStackTrace();

} finally {

DBUtil.close(conn, ps, rs);

}

// Pager.getSize()表示:每页显示几行

return (total % Pager.getSize() == 0) ? (total / Pager.getSize())

: ((total / Pager.getSize()) + 1);

}

}

4、控制器---控制流程的Servlet类

package com.sun.servlet;

import java.io.IOException;

import java.io.PrintWriter;

import javax.servlet.ServletException;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import com.newer.dao.EmpDao;

import com.newer.page.Pager;

public class EmpServlet extends HttpServlet { private static final long serialVersionUID = 1L;

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException { this.doPost(request, response);

}

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException { request.setCharacterEncoding("utf-8");

response.setContentType("text/html;charset=utf-8");

PrintWriter out = response.getWriter();

//从请求页面获得要查看第几页

String spageno = request.getParameter("pageno");

int pageno = 1;

try{

pageno = Integer.parseInt(spageno);

}catch(NumberFormatException e){

e.printStackTrace();

pageno = 1;

}

EmpDao empDao = new EmpDao();

int totalpage = empDao.getTotalPage("emp");//获得emp表的总页数

if(pageno<=0){

pageno = 1 ;//首页

}else if(pageno > totalpage){

pageno = totalpage;//尾页

}

Pager pager = new Pager();

pager.setTotalpage(totalpage);//设置页面的总页数

pager.setList(empDao.find(pageno));//设置第几页的数据集合

request.setAttribute("pager", pager);//把pager对象绑定到request对象

//转发-->参数:第几页

request.getRequestDispatcher("listEmp.jsp?pageno="+ pageno).forward(request, response);

out.flush();

out.close();

}

}

5、视图层------jsp页面显示

文件名:index.jsp

<%@page language="java"pageEncoding="UTF-8"%>

<%@taglib prefix="c" uri="https://www.360docs.net/doc/b915302878.html,/jsp/jstl/core"%>

分页

分页 (JSP+Servlet+JavaBean+c3p0+Oracle)

<%

pageContext.setAttribute("color","yellow"); %>

<%

pageContext.setAttribute("color","white"); %>

IDempnoenamejobmgrhiredatesalcommdeptno
${rows.index+1}${emp.empno}${emp.ename}${emp.job}${emp.mgr}${emp.hiredate}${emp.sal}${https://www.360docs.net/doc/b915302878.html,m }${emp.deptno}

当前是第${param.pageno}页 

 

首页 

上一页 

下一页 

尾页 

总页数:${pager.totalpage}页 

6、web.xml配置

xmlns:xsi="https://www.360docs.net/doc/b915302878.html,/2001/XMLSchema-instanc e"

xsi:schemaLocation="https://www.360docs.net/doc/b915302878.html,/xml/ns/java ee

算法题

算法题(共32个题目) 200348. 在信号量机制中,若P(S)操作是可中断的,则会有什么问题? 此题答案为:答: P(S)的操作如下: Begin S.Value:= S.Value-1; ① If S.Value<0 Then ② Begin Insert(*,S.L); Block(*) ③ End End. 若P(S)可中断的,例如进程A在执行了语句①之后从CPU上退下了,假定此时S.Value=0;这时换另一进程B,B又将S.Value 的值减1使之为-1,在执行语句③时,B被阻塞;然后又换回A执行,由于A的"断点"是语句①之后,当它执行语句②时,由于这时S.Value已经是-1,故进程继续执行而被阻塞。这就出现了错误:本来A操作P(S)操作后,S.Value=0,是不应该被阻塞的,现在却被阻塞了。 200350. 何谓临界区?下面给出的两个进程互斥的算法是安全的吗?为什么?

#define true; # define false; Int flag[2]; flag[1]=flag[2]=false; enter-crtsec(i) int i; { While(flag[1-i]) flag[i]=true; } feave-crtsec(i) Int i; { flag[i]=false; } process I; … Enter-crtsec(i); In critical section; Leave-crtsec(i);

此题答案为:答:一次仅允许一个进程使用的资源称为临界资源,在进程中对临界资源访问的程序段称为临界区。 从概念上讲,系统中各进程在逻辑上是独立的,它们可以按各自的速度向前推进。但由于它们共享某些临界资源,因而产生了临界区问题。对于具有临界区问题的并发进程,它们之间必须互斥,以保证不会同时进入临界区。 这种算法不是安全的。因为,在进入临界区的enter-crtsec()不是一个原语操作,如果两个进程同时执行完其循环(此前两个flag均为false),则这两个进程可同时进入临界区。 53. 某车站售票厅,任何时刻最多可容纳20名购票者进入,当售票少于20名购票者时,则厅外的购票者可立即进入,否则需在外面等待。若把一个购票者看作一个进程,请回答下列问题: (1)用P、V操作管理这些并发进程时,应怎样定义信号量?写出信号量的初值以及信号量各种取值的含义。 (2)根据所定义的信号量,把应执行的P、V操作填入下述程序中,以保证进程能够正确地并发执行。 Cobegin PROCESS Pi(i=1,2,…) Begin 进入售票厅; 购票; 退出; End;

SQL数据库的备份、还原、压缩与数据转移的方法.

当前,全国各级审计机关普遍应用AO系统进行现场审计,但由于被审计单位使用的财务软件种类太多,AO系统不可能提供全部财务软件数据导入模板,虽然AO现场审计实施系统2008版比2005版在模板数量上有所增加,但仍然不能完全解决各级审计机关在实际审计工作遇到的数据导入难题,只能通过后台备份数据库,然后还原到审计人员电脑中进行处理后,再一步一步导入AO中。由于审计人员大部分非计算机专业,对数据库的基本操作了解不是很多,无形中影响了计算机辅助审计的开展。为此,笔者分析了大量的被审计单位的财务系统后台数据库,其中大部分财务软件使用了SQL作为后台数据库,因此总结了SQL数据库的备份、压缩与SQL数据库数据处理的方法,供审计人员在审计工作中借鉴使用。 一、备份数据库1、打开SQL企业管理器,在控制台根目录中依次点开Microsoft SQL Server 2、SQL Server组——>双击打开你的服务器——>双击打开数据库目录3、选择你的数据库名称(如财务数据库cwdata)——>然后点上面菜单中的工具——>选择备份数据库4、备份选项选择完全备份,目的中的备份到如果原来有路径和名称则选中名称点删除,然后点添加,如果原来没有路径和名称则直接选择添加,接着指定路径和文件名,指定后点确定返回备份窗口,接着点确定进行备份。二、还原数据库1、打开SQL企业管理器,在控制台根目录中依次点开Microsoft SQL Server;2、SQL Server组——>双击打开你的服务器——>点图标栏的新建数据库图标,新建数据库的名字自行取; 3、点击新建好的数据库名称(如财务数据库cwdata)——>然后点上面菜单中的工具——>选择恢复数据库; 4、在弹出来的窗口中的还原选项中选择从设备——>点选择设备——>点添加——>然后选择你的备份文件名——>添加后点确定返回,这时候设备栏应该出现您刚才选择的数据库备份文件名,备份号默认为1(如果您对同一个文件做过多次备份,可以点击备份号旁边的查看内容,在复选框中选择最新的一次备份后点确定)——>然后点击上方常规旁边的选项按钮; 5、在出现的窗口中选择在现有数据库上强制还原,以及在恢复完成状态中选择使数据库可以继续运行但无法还原其它事务日志的选项。在窗口的中间部位的将数据库文件还原为这里要按照你SQL的安装进行设置(也可以指定自己的目录),逻

分页管理实验报告

2015-2016学年第二学期 操作系统课程实验设计报告 班级网络2班 学号 201414620207 姓名韩金铖 成绩 指导教师于复兴

1、实验题目: (1)模拟请求分页存储管理中的硬件地址转换和产生却页中断的过程。 (2)采用先进先出(或LRU)算法实现分页管理的缺页调度。 2、实验目的: (1)通过实验模拟请求分页存储管理中的硬件地址转换和产生却页中断帮助理解在分页式存储管理中怎样虚拟存储器。 (2)通过采用先进先出(或LRU)算法实现分页管理的缺页调度帮助理解和掌握模拟分页式虚拟存储管理的缺页中断,帮助自己对请求分页管理的概念有一个清楚的理解。3、程序设计及实现过程: (1)请求分页储存管理是把作业的全部信息存在磁盘上,当作业被选中时,可把作业的开始几页先装入主存并启动运行。为此,在为作业建立页表时,应说明哪些页已在主存,哪些页尚未装入主存,页表格式为: 其中,标志表示对应页是否已经装入主存,“标志 = 0”表示该页尚未装入主存,“标志= 1”表示该页已在主存。 主存块号表示已装入主存的页所占用的块号。 外存地址表示该页在外存的地址。 (2)作业执行完时,指令中的逻辑地址指出了参加运算的操作数存放的页号和单元号,硬件地址转换机构按页号查页表,若该页对应的标志为“1”,则表示该页已在主存。根据关系式:绝对地址=块号*块长+单元号。 计算出欲访问的主存单元地址,将块长设成2的整次幂,可把块号作为地址寄存器的高位部分,单元号作为低位部分。两个拼接形成绝对地址。按计算出的绝对地址取操作数,完成一条指令的执行。 若访问的页对应标志为“0”,则表示不在主存,这时硬件发缺页中断信号,由操作系统按页表中的该页对应的外存地址把该页装入主存后,执行该指令。 (3)设计一个“地址变换”程序来模拟硬件的地址转换工作。当访问的页不在主存时,则形成绝对地址后不去模拟指令的执行,而用输出转换后的地址来代替一条指令的执行,当访问的页不在主存时,则输出“*”,表示产生了一次缺页中断。 该算法框图如下:

实验九:数据库备份及恢复

实验九:数据库备份及恢复 一、实验目的 1.熟悉数据库备份及恢复机制; 2.了解SQL Server的数据备份和恢复机制; 3.掌握SQL-Server中数据库备份和恢复的方法。 二、实验环境 已安装SQL Server 2005 企业版的计算机; 具有局域网环境,有固定IP; 三、实验学时 2学时 四、实验要求 1.了解创建备份设备和进行数据库完全备份操作的方法; 2.了解进行数据库恢复的步骤; 3.完成实验报告。 五、实验内容及步骤 以管理员帐号登录SQL Server Management Studio,以原有数据库stu为基础,请使用Management Stuio界面方式或T-SQL 语句实现以下操作: 1.针对数据库stu创建完全数据库备份集stu.bak,目标磁盘为D:\ user \ stu.bak; BACKUP DATABASE student TO DISK='C:\user\stu.bak' 2.在数据库stu中新建数据表ceshi,内容自定,然后针对数据库stu创建 差异备份; CREATE TABLE ceshi ( Sno char(9)NOT NULL primary key, Sname char(6)NOT NULL, Ssex char(2)NULL, Sage int NULL, Sdept varchar(8)NULL ) GO BACKUP DATABASE student TO DISK='C:\user\stu_differential.bak' WITH DIFFERENTIAL 3.向数据库stu的数据表ceshi插入部分记录,然后针对数据库stu创建 事务日志备份;

数据库备份与恢复

Oracle数据库备份与恢复的三种方法 2009-11-04 16:00 Oracle数据库有三种标准的备份方法,它们分别是导出/导入(EXP/IMP)、热备份和冷备份。导出备件是一种逻辑备份,冷备份和热备份是物理备份。 一、导出/导入(Export/Import) 利用Export可将数据从数据库中提取出来,利用Import则可将提取出来的数据送回到Oracle数据库中去。 1、简单导出数据(Export)和导入数据(Import) Oracle支持三种方式类型的输出: (1)、表方式(T方式),将指定表的数据导出。 (2)、用户方式(U方式),将指定用户的所有对象及数据导出。 (3)、全库方式(Full方式),瘵数据库中的所有对象导出。 数据导入(Import)的过程是数据导出(Export)的逆过程,分别将数据文件导入数据库和将数据库数据导出到数据文件。 2、增量导出/导入 增量导出是一种常用的数据备份方法,它只能对整个数据库来实施,并且必须作为SYSTEM来导出。在进行此种导出时,系统不要求回答任何问题。导出文件名缺省为export.dmp,如果不希望自己的输出文件定名为export.dmp,必须在命令行中指出要用的文件名。 增量导出包括三种类型: (1)、“完全”增量导出(Complete) 即备份三个数据库,比如: (2)、“增量型”增量导出 备份上一次备份后改变的数据,比如:

(3)、“累积型”增量导出 累计型导出方式是导出自上次“完全”导出之后数据库中变化了的信息。比如: 数据库管理员可以排定一个备份日程表,用数据导出的三个不同方式合理高效的完成。 比如数据库的被封任务可以做如下安排: 星期一:完全备份(A) 星期二:增量导出(B) 星期三:增量导出(C) 星期四:增量导出(D) 星期五:累计导出(E) 星期六:增量导出(F) 星期日:增量导出(G) 如果在星期日,数据库遭到意外破坏,数据库管理员可按一下步骤来回复数据库: 第一步:用命令CREATE DATABASE重新生成数据库结构; 第二步:创建一个足够大的附加回滚。 第三步:完全增量导入A: 第四步:累计增量导入E: 第五步:最近增量导入F:

Html页面分页算法和后台与数据库的交互

Html页面分页算法和后台与数据库的交互 var pageTotal=1; var lastPage="a1"; var infoType=""; var infoTypeList=null; var timesNum=10; //每页显示的条数 indexAction.getInfoMaster(loginUserMap,{ async : false, callback : function(data){ if(data!=null&&data.length!=0){ var html=""; pageTotal=data[0].pageTotal; if(pageTotal<7){ if(pageTotal!=1){ html="1  & nbsp;"; for(var i=2;i"+i+" &nb sp; "; } html+=""+pageTotal+"  ;  "; html+=" 下一页"; }else{ html=""; } document.getElementById("page").innerHTML=html; }else{ html="1   "; for(var i=2;i<5;i++) { html+=""+i+"  & nbsp;";

数据库备份和还原操作方法

数据库备份和还原 在收费系统运行一段时间后,如发生系统不正常要重装WINDOWS操作系统或更换电脑时,须按照下面“数据库备份”方法将原系统的数据文件备份,并将备份文件妥善保存(避免随系统重装而丢失数据),在重装系统或更换电脑后,按照软件的安装方法顺序安装SQL2000数据库和消费/水控管理软件,然后按照下面“数据还原”方法进行数据库还原,完成后系统中的数据即与原数据完全[相同。 数据库备份: 以ICSF为例,打开ICSF软件,选择菜单栏下的系统维护,然后选择数据备份。(系统维护——数据备份)如图(1-1): 1-1 数据备份完成后,可以在基本资料——系统参数里(1-2),在弹出的对话框上的备份路径二(手动备份)里可以找到数据备份的路径(1-3)。如图:

1-2 1-3 提示: 1、上述方法为手动备份,本系统在使用后正常腿出系统时也会自动进行 数据备份,如已经无法正常开启原电脑(无法进行手动备份)则可将 原电脑硬盘连接到其他电脑中,找到“备份路径一”所指向的路径, 找到备份文件夹,将其中修改日期最近的备份文件拷贝出来用于数据 还原。 2、在安装收费/水控系统时建议不要将安装目录选在C盘,避免因格式 化的操作是备份数据丢失,如果已经将软件安装在C盘,则建议将备 份文件路径指定为其他盘。 数据还原 数据还原,首先要找到备份的数据文件。如上所述,备份文件存放在E:\软件\ICSF5.74\Mdbbak上,根据路径找到Mdbbak文件夹并打开。 打开Mdbbak文件夹后,里面有类似这样的(1-4)BAK文件。 找寻最新的BAK文件,并把它与软件安装包(光盘)中IC挂接数据库.exe软件拷贝到电脑任意一个目录(文件夹)中,然后将备份文件重命名(光标放在备份文件 上点鼠标右键,选择重命名),改为ICSF.db。如图:(1-5)

sql server数据库备份

SQL Server 2005&2008备份与恢复--转 一、数据库存储概述 1、数据文件类型 · Primary data files:每个数据库都有一个单独的主要数据文件,默认以.mdf扩展名。主要数据文件不仅包含数据信息,还包含与该数据库结构相关的信息。创建数据库时,数据库结构相关信息不仅存在于master数据库中,同时还包含在primary data file上. · Secondary data files一个数据库可以有一个或者多个二级数据文件,默认以.ndf为扩展名。一般来说二级数据文件并不是必须的,因为二级数据文件不包含文件位置等信息。 · Transaction logs: 数据库必须至少有一个事务日志文件,默认以.ldf为扩展名。日志是整个数据库的命脉,事务日志不可读的话,将无法对数据库进行任何操作。 当你在数据库上进行数据操作时,数据并不是直接写入数据文件,而是先将相关操作信息写入事务日志文件。当一个事务结束时,该事务被标记为已提交,但这也并不意味着数据从日志文件写入了数据文件中。一个标记为已提交的事务仅仅意味着所有与该事务相关的元素已经成功完成。The buffer cache may be updated, but not necessarily the data file. 检查点(checkpoint)会周期性的发生。检查点发生时,是确认所有已提交的事务,不管是在buffer cache 或者事务日志中,都被写入相关的数据文件中。检查点(checkpoint)可以通过以下方式来触发: 1、显示调用checkpoint命令; 2、Recover Interval 实例设置的周期达到(用来标识多久发生一次checkpoint) 3、做了数据库备份(在简单模式下); 4、数据库文件结构被改变(在简单模式下);

分页管理的缺页调度—LRU算法

南通大学操作系统实验课 实验报告 学生姓名 所在院系 专业 学号 指导教师 南通大学 2014年 5 月 30 日

虚拟存储器管理 采用LRU算法实现分页管理的缺页调度 一、实验目的 为了使大的进程(其地址空间超过主存可用空间)或多个进程的地址空间之和超过实际主存空间时,仍能运行,引入了虚拟存储器的概念。使进程的一部分地址空间在主存,另一部分在辅存,由操作系统实现多级存储器的自动管理,实现主存空间的自动覆盖。模拟请求分页虚拟存储器管理技术中的硬件地址变换、缺页中断以及页式淘汰算法,处理缺页中断。 通过本实验,使学生对请求分页管理的概念有一个清楚的理解。 二、实验要求 书写实验报告,应该包括以下几项内容: (1)实验题目; (2)程序中使用的数据结构及主要符号说明; (3)程序流程图和带有详细注释的源程序; (4)执行程序名,并打印程序运行时的系统状态的初值、每次调入调出的页号和运行结果;(5)通过实验后的收获与体会及对实验的改进意见和见解。 三、简要概述 当采用LRU算法时,用一个数组P构成堆栈,堆栈中各个元素为进程已在主存的页号,为了进行页面置换,可设置一个栈指针HEAD,初始化为0。假定分配给每个进程的内存块数固定不变,为M。当队列满需要淘汰时,操作系统选择栈底的元素淘汰,其他元素向下移一个位置,将新调入页放HEAD指示的栈顶。当访问的页在栈中时,还应调整页从当前位置到栈顶。采用LRU淘汰算法的流程如下所示。

四、流程图

五、结果 六、总结与感悟 经过了这学期的操作系统实验,我对操作系统实验有了全新的认识。尤其是当拿到一个任务时,如何去分析,先干什么,接着干什么,最后干什么,有了比较明确的思路。 拿到一个题目后,我们应该先对这个题目进行概要的分析、设计,分析出这个程序是干什么用的,应该实现什么功能,这些功能应该包含哪些函数。概要设计做好后,我们就要开始做详细设计,将做好的概要设计进行完善,把每个函数要实现的功能用伪代码写出来,或者是用流程图画出来,这样我们就能基本上知道每个程序应该如何实现它自身的功能,写源代码时也就不会那么盲目。 写源代码是将详细设计转化为C++代码的过程,详细设计做好后,我们只需在其基础上将一些简单的或者是用汉语代替的语句用C++语句写出来,再将一些语法错误改过来,并将概要设计和详细设计时未考虑到的东西在语句中完善,最终形成一个可执行的C++文件。刚开始的时候,我根据书上的提示自己编写好程序输入电脑,然后编译的时候,出现了许许多多各种各样的问题,回头查看程序,自己却很难找到问题所在,于是查阅各种资料,问了身边很多同学,终于将程序顺利调试出来了。通过这个系统的实现,我从输入代码跟运行调试的整个过程中学习到了很多东西,也了解到系统出现问题的时候的各种错误应该如何解决。

mysql数据库备份与恢复

my sql数据库备份与恢复 windows下实现mysql数据库定时备份功能一、进入mysql的bin目录 二、导出: [mysql bin path]>mysqldump--opt-d-u root-p dbn> backup-file.sql Enter password:****** 三、导入: [mysql bin path]>mysql-u root-p dbn<backup-file.sql Enter password:****** 四、收尾工作:清理sql文件,导出时会在bin目录下生成backup-file.sql 文件,在导入工作完成后就没用了,可以删了,当然留着也可以。

我自己的用的备份语句: d: cd\mysql\mysql5.1.30\bin mysqldump--opt-uroot-p123456 bbs_sikaozhoubao_com>E:\backup\bbs_sikaozhoubao_com\%date:~ 0,4%%date:~5,2%%date:~8,2%%time:~0,2%%time:~3,2%%time:~6,2%.sq l 更多的说明: 导出要用到MySQL的mysqldump工具,基本用法是: shell>mysqldump[OPTIONS]database[tables] 如果你不给定任何表,整个数据库将被导出。 通过执行mysqldump--help,你能得到你mysqldump的版本支持

的选项表。 注意,mysqldump没有--quick或--opt选项,mysqldump将在导出结果前装载整个结果集到内存中,如果你正在导出一个大的数据库,这将可能是一个问题。 mysqldump支持下列选项: --add-locks 在每个表导出之前增加LOCK TABLES并且之后UNLOCK TABLE。(为了使得更快地插入到MySQL)。 --add-drop-table 在每个create语句之前增加一个drop table。

经过优化测试的SQL分页存储过程

经过优化测试的SQL分页存储过程 2009-10-24 23:20 建立一个 Web 应用,分页浏览功能必不可少。这个问题是数据库处理中十分常见的问题。经典的数据分页方法是:ADO 纪录集分页法,也就是利用ADO自带的分页功能(利用游标)来实现分页。但这种分页方法仅适用于较小数据量的情形,因为游标本身有缺点:游标是存放在内存中,很费内存。游标一建立,就将相关的记录锁住,直到取消游标。游标提供了对特定集合中逐行扫描的手段,一般使用游标来逐行遍历数据,根据取出数据条件的不同进行不同的操作。而对于多表和大表中定义的游标(大的数据集合)循环很容易使程序进入一个漫长的等待甚至死机。 更重要的是,对于非常大的数据模型而言,分页检索时,如果按照传统的每次都加载整个数据源的方法是非常浪费资源的。现在流行的分页方法一般是检索页面大小的块区的数据,而非检索所有的数据,然后单步执行当前行。 最早较好地实现这种根据页面大小和页码来提取数据的方法大概就是“俄罗斯存储过程”。这个存储过程用了游标,由于游标的局限性,所以这个方法并没有得到大家的普遍认可。 后来,网上有人改造了此存储过程,下面的存储过程就是结合我们的办公自动化实例写的分页存储过程: CREATE procedure pagination1 (@pagesize int, --页面大小,如每页存储20条记录 @pageindex int --当前页码 ) as set nocount on begin declare @indextable table(id int identity(1,1),nid int) --定义表变量declare @PageLowerBound int --定义此页的底码 declare @PageUpperBound int --定义此页的顶码 set @PageLowerBound=(@pageindex-1)*@pagesize set @PageUpperBound=@PageLowerBound+@pagesize set rowcount @PageUpperBound insert into @indextable(nid) select gid from TGongwen where fariqi >dateadd(day,-365,getdate()) order by fariqi desc select O.gid,O.mid,O.title,O.fadanwei,O.fariqi from TGongwen O,@indextable t where O.gid=t.nid and t.id>@PageLowerBound and t.id<=@PageUpperBound order by t.id end set nocount off

实验10 数据库备份与还原

实验10 数据库备份与还原 创建备份 (1)选择【stu】数据库右击,单击【属性】。 (2)单击【选项】页,将【恢复模式】设置为【完整】。 (3)选择【stu】数据库右击,依次选择【任务】、【备份】,将打开【备份数据库】对话框 备份数据库 (4)在【备份类型】列表框中,选择【完整】。注意:创建完整数据库备份之后,才可以创建差异数据库备份。 注:选择【差异】即进行差异备份;选择【事务日志】即进行日志备份;若要备份日志尾部(即活动的日志),则需在【选择页】窗格中单击【选项】,再选中【备份日志尾部,并使数据库处于还原状态】。 (5)对于【备份组件】,选择【数据库】。 (6)单击【添加】按钮,打开【选择备份目标】对话框:

选择备份目标 (8)选择备份路径和输入备份文件名。 若想将数据库备份到备份设备上,则应在选择备份设备作为备份目标(如果不存在备份设备,应该先创建),再选择相应的备份设备即可。 创建备份设备 (1)右击【备份设备】,然后单击【新建备份设备】,打开【备份设备】对话框:

(2)在【设备名称】文本框中输入新建设备名,如【dev1】。 (3)在【文件】框中指定备份设备对应的备份文件及路径。 还原备份 在【还原数据库】对话框的【要还原的源】部分中选择【从数据库】,以从SQL Server 识别的备份集中还原。也可选择【从设备】并指定备份文件和包含要存储的备份的设备来从备用备份中还原。 (1)选择【数据库】右击,依次选择【任务】、【还原】,将出现【还原数据库】对话框: 还原数据库 (2)在【常规】页上,还原数据库的名称将显示在【目标数据库】列表框中。若要创建新数据库,请在列表框中输入数据库名。此处输入【stu】。 (3)选择【源设备】,在【备份媒体】列表框中选择【文件】,单击【添加】按钮选择【stu.bak】返回【指定备份】对话框:

SQL SERVER2000数据备份与恢复

SQL Server2000数据备份与恢复 Author looger 1.数据库备份 1.1展开服务器组,然后展开服务器。展开“数据库”文件夹,右击数据库,指向“所 有所有”子菜单,然后单击“备份数据库”命令。 1.2在“名称”框内输入备份集名称,在“描述”框中输入对备份集的描述。在“备 份”选项中选择备份方式。

1.3点击“添加”按钮以添加现有的目的地或创建新的目的地,点击按钮可以选择一个备份文件

1.4点击按钮后,在下面出现的窗口中选择一个文件作为备份文件,可以在“文件名” 后面的文本框中输入一个新的文件名以创建一个备份文件。 1.5此时刚才选择的文件被加入到备份文件中。如果要添加其他的文件,则可以点击“添 加”按钮添加其他的文件。在"重写"选项下,单击“追加到媒体”,将备份追加到备份设备上任何现有的备份中;点击“重写现有媒体”,将重写备份设备中任何现有的备份

1.6可以选择“调度”复选框调度备份操作在以后执行或定期执行。点击“调度”后 面的按钮可以对调度进行设置 1.7在点击按钮后,可以在下面的对话框中设置调度的名称和调度的类型。如果需要调 度反复出现,则可以点击“更改”按钮

1.8点击“更改”按钮后,可以在下面的窗口中设置作业发生的时机 1.9单击“选项”选项卡。选择“完成后验证备份”复选框,在备份时对备份进行验 证。选择“检查媒体集名称和备份集到期时间”,检查备份媒体以防意外重写。在“媒体集名称”框中,输入将用于备份操作的媒体的名称。如果仅指备份集到期时间,则将其保留为空

2.数据库的恢复 2.1展开服务组,然后展开服务器。展开“数据库”文件夹,右击数据库, 指向“所有任务”子菜单,然后单击“还原数据库”命令 2.2在“还原为数据库”框中,如果要还原的数据库名称与显示的默认数据库名称不同,请在其中进行输入或选择。若要用新名称还原数据库,请输入新的数据库名称

clock算法和请求分页EAT计算

若循环链表存在当前访问页时(访问页在某物理块中),直接将其访问位改为1,指针p 不移动(命中后指针不移动);否则,若当前p指针指向页面的访问位为0,则淘汰该页,调入新页,将其访问位改为1,指针p 移到下一个物理块;若当前p指针指向页面的访问位为1,则将其访问位改为0,并移动p指针到下一个物理块,并重复查找。

假设系统为某进程分配了3个物理块,考虑页面走向为:7、0、1、2、0、3、0、4,求采用CLOCK页面淘汰算法时缺页中断的次数。 表1-1 CLOCK算法的详细流程

基本分页管理方式中有效访问时间的计算 有效访问时间(EAT ),是指给定逻辑地址找到内存中对应物理地址单元中的数据所用的总时 间 (1) 没有快表的情况 访存一次所需的时间为t ,有效访问时间分为:查找页表找到对应页表项,需要访存一次,消耗时间t ;通过对应页表项中的物理地址访问对应内存单元,需要访存一次,消耗时间t 。因此,EAT=t+t=2t (2) 存在快表的情况 设访问快表的时间为a ,访存一次时间为t ,快表的命中率为b ,则有效访问时间分为:查找对应页表项的平均时间()(1)a b t a b ?++-。其中a 表示快表命中所需的查找时间;t+a 表示查找快表未命中时,需要再访存读取页表找到对应页表项,两种情况的概率分别为b 和1-b ,可以计算得到期望值,即平均时间。通过页表项中的物理地址访存一次取出所需数据,消耗时间t 。因此,()(1)EAT a b t a b t =?++-+ 请求分页管理方式中有效时间的计算 与基本分页管理方式相比,请求分页管理方式中多了缺页中断这种情况,需要耗费额外的时间,因此计算有效访问时间时,要将缺页这种情况考虑进去。 首先考虑要访问的页面所在的位置,有如下三种情况。 访问的页在主存中,且访问页在快表中(在快表中就表明在内存中),则EAT=查找快表

oracle数据库备份与恢复实施方案

oracle数据库备份与恢复方案

————————————————————————————————作者:————————————————————————————————日期:

oracle数据库 备份与恢复方案 文件控制?受控?不受控 文档编号日期项目名称版本号 分册名称第册/共册总页数正文附录 编制审批生效日期

目录 一、编写目的 (1) 二、备份工具及备份方式 (1) 三、软件备份 (1) 四、软件恢复 (1) 五、数据备份 (2) 六、备份的存储 (2) 七、备份数据的保存规定 (2) 八、备份介质的格式 (3) 九、数据恢复 (4)

一、编写目的 本文档主要说明公司项目在实施现场的软件及数据的备份和恢复方案。 二、备份工具及备份方式 1.备份工具 Oracle RMAN(Recovery Manager):是一种用于备份(backup)、还原(restore)和恢复(recover)数据库的Oracle 工具。RMAN只能用于ORACLE8或更高的版本中。它能够备份整个数据库或数据库部件,如表空间、数据文件、控制文件、归档文件以及Spfile参数文件。RMAN也允许您进行增量数据块级别的备份,增量RMAN备份是时间和空间有效的,因为他们只备份自上次备份以来有变化的那些数据块。 2.备份方式 (1)自动备份:由Windows 计划任务调度完成; (2)手工备份:完成特殊情况下的备份,分热备份和冷备份,热备份是指在不关闭数据库情况下进行备份,冷备份则需要停止Oracle实例服务。 三、软件备份 1.以七天为一个周期每天23:00将所有软件拷贝到其他存储介质上 2.超出七天的备份依次删除 3.每月一号将上月最后7天的备份文件刻录到光盘上 四、软件恢复 1.找出最近的备份程序覆盖到正式运行环境的相应目录中

SQL数据库备份与还原

SQL数据库的备份与还原 温馨提示:当学籍系统、综合素质评价系统有数据更新时,管理员一定要及时的做好数据库的备份工作,以防止意外情况的发生。正确、及时的进行数据库备份能减少数据丢失后恢复数据库的工作量。所以为了避免数据在灾难后无法恢复,必须对数据库进行备份。 一、SQL数据库的备份: 1、依次打开开始菜单→程序→Microsoft SQL Server 2008 →SQL Server Management Studio →数据库:Dsideal_school_db既是我们需要备份的学籍数据库 图(1) 2、选择要备份的数据库“Dsideal_school_db”,点击鼠标右键→任务→备份,如图(2):

图(2) 3、在打开的“备份数据库—Dsideal_school_db”对话框中,先点击删除,然后点击“添加”,如图(3):

首先点击“删除” 然后点击“添加” 图(3) 4、在弹出的“选择备份目标”对话框中,点击“”,如图(4) 图(4) 5、选择好备份的路径(如D盘的江西-学籍-数据库备份文件夹中),文件类型选择“所有文件”,“文件名”那个位置填写上您要备份的数据库的名字(最好在您备份的数据库的名字后

面加上日期,以方便以后查找),之后连续点击“确定”按钮即可完成数据库的备份操作,如图(5): 图(5 二、SQL数据库的还原:

1、选择您要还原的数据库“Dsideal_school_db”,点击鼠标右键→任务→还原→数据库,如图(6): 图(6) 2、在出现的“还原数据库— school_web_db”对话框中选择“源设备”,然后点击后面的“”按钮,如图(7):

海量数据库的查询优化及分页算法方案

海量数据库的查询优化及分页算法方案 随着“金盾工程”建设的逐步深入和公安信息化的高速发展,公安计算机应用系统被广泛应用在各警种、各部门。与此同时,应用系统体系的核心、系统数据的存放地――数据库也随着实际应用而急剧膨胀,一些大规模的系统,如人口系统的数据甚至超过了1000万条,可谓海量。那么,如何实现快速地从这些超大容量的数据库中提取数据(查询)、分析、统计以及提取数据后进行数据分页已成为各地系统管理员和数据库管理员亟待解决的难题。 在以下的文章中,我将以“办公自动化”系统为例,探讨如何在有着1000万条数据的MS SQL SERVER数据库中实现快速的数据提取和数据分页。以下代码说明了我们实例中数据库的“红头文件”一表的部分数据结构: CREA TE TABLE [dbo].[TGongwen] ( --TGongwen是红头文件表名 [Gid] [int] IDENTITY (1, 1) NOT NULL , --本表的id号,也是主键 [title] [varchar] (80) COLLA TE Chinese_PRC_CI_AS NULL , --红头文件的标题 [fariqi] [datetime] NULL , --发布日期 [neibuY onghu] [varchar] (70) COLLA TE Chinese_PRC_CI_AS NULL , --发布用户 [reader] [varchar] (900) COLLA TE Chinese_PRC_CI_AS NULL , --需要浏览的用户。每个用户中间用分隔符“,”分开 ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] GO 下面,我们来往数据库中添加1000万条数据: declare @i int set @i=1 while @i<=250000 begin insert into Tgongwen(fariqi,neibuyonghu,reader,title) values('2004-2-5','通信科','通信科,办公室,王局长,刘局长,张局长,admin,刑侦支队,特勤支队,交巡警支队,经侦支队,户政科,治安支队,外事科','这是最先的25万条记录') set @i=@i+1 end GO declare @i int set @i=1 while @i<=250000 begin insert into Tgongwen(fariqi,neibuyonghu,reader,title) values('2004-9-16','办公室','办公室,通信科,王局长,刘局长,张局长,admin,刑侦支队,特勤支队,交巡警支队,经侦支队,户政科,外事科','这是中间的25万条记录') set @i=@i+1 end GO declare @h int set @h=1 while @h<=100 begin

SQL数据库备份与恢复操作流程

1.数据库备份 1)打开“开始”——“程序”——Microsoft SQL Server——企业管理器,进入之后,将页面左边的“控制台根目录”下的“+”一个一个都点开,一直到点开“数据库”前的“+”。可以看到第一个数据库应该是CORPSCAN,在这个数据库上面点右键,选择“所有任务”中的“备份数据库”,如下图所示: 2)在弹出的选择框中点“添加”按钮:

3)弹出如下的窗口: 且必须给这个备份文件起一个文件名(一般我们都以日期做为备份文件名),如

下图所示: 上述备份文件就是放在D:\ 这个目录下,文件名为20051120。然后点“确定”。4)可以看到“备份到”那里有个路径和文件名了,其它什么都不用动,然后点“确定”就可以了,如下图所示: 备份文件成功后会有提示信息,可以到备份的目录下找到备份的文件。

2.数据库还原 和数据库的备份操作类似。具体流程如下: 1)打开“开始”——“程序”——Microsoft SQL Server——企业管理器,进入之后,将页面左边的“控制台根目录”下的“+”一个一个都点开,一直到点开“数据库”前的“+”。可以看到第一个数据库应该是CORPSCAN,在这个数据库上面点右键,选择“所有任务”中的“还原数据库”,如下图所示: 2)在弹出的页面上,在“还原”那里选择“从设备”,然后点一下“选择设备”,如图所示:

3)在弹出的页面上点一下“添加”按钮,就出现“选择还原目的”的对话框,在“文件名”后面有个浏览按钮,在那里选择要还原的文件(就是之前备份的数据库文件),然后点“确定”,再确定,再确定,就可以了,还原成功之后会有提示的:

SQL数据库的备份与还原、分离与附加

SQL数据库的备份与还原 一、SQL数据库的备份: 1、依次打开开始菜单→程序→Microsoft SQL Server 2008 →SQL Server Management Studio →数据库:以Dsideal_school_db为例 图(1) 2、选择要备份的数据库“Dsideal_school_db”,点击鼠标右键→任务→备份,如图(2):

图(2) 3、在打开的“备份数据库—Dsideal_school_db”对话框中,先点击删除,然后点击“添加”,如图(3):

首先点击“删除” 然后点击“添加” 图(3) 4、在弹出的“选择备份目标”对话框中,点击“”,如图(4) 图(4) 5、选择好备份的路径(如D盘的江西-学籍-数据库备份文件夹中),文件类型选择“所有文件”,“文件名”那个位置填写上您要备份的数据库的名字(最好在您

备份的数据库的名字后面加上日期,以方便以后查找),之后连续点击“确定”按钮即可完成数据库的备份操作,如图(5): 图(5 二、SQL数据库的还原:

1、选择您要还原的数据库“Dsideal_school_db”,点击鼠标右键→任务→还原→数据库,如图(6): 图(6) 2、在出现的“还原数据库— school_web_db”对话框中选择“源设备”,然后点击后面的“”按钮,如图(7):

3、在出现的“指定备份”对话框中,点击“添加”按钮,如图(8): 图(8) 4、找到数据库备份的路径,选择您所要还原的数据库“Dsideal_school_db”(注 意:文件类型选择所有文件),然后连续“两次”点击“确定”按钮,如图(9):

实验六 分页内存管理算法模拟

实验七分页内存管理算法模拟 姓名:黄中圣 学号:20140288 班级:14级计科三班 一、实验目的 1、熟悉基本分页存储管理。 2、建立描述分页内存管理中的页目录表、页表结构。 3、实现进行虚拟内存到物理内存的映射算法。 二、实验理论基础及教材对应关系 1、操作系统中内存管理。 2、基本分页内存、分段内存管理。 3、页目录表、页表的作用,以及虚拟地址到物理地址的映射关系。 三、实验内容与步骤 题目:分页存储管理的设计与实现。 某系统采用了两级页表机制,可使页表所占用内存尽量少,分页地址变换机构如下图所示:

分页地址变换机构 页目录表共1024项,每个页表1024项,每页的大小是4K个字节。地址转换时,先由分段部件生成线性地址,再由上面所述的分页部件,根据线性地址中的页目录索引在页目录表中找相应的项,该项值为所需页表在内存的块号,找到该页表后,然后按第21-12位的页表索引找到所需页的物理内存起始地址,把它与12位偏移直接相加得到32位的物理地址。 设系统有如表1中所示的10个段,已知:1-8段从内存的200000H处开始由低地址到高地址连续存放,映射到3G+4M开始的线性地址空间;9段(缓冲区)放在400000H开始的内存,映射的线性地址同物理地址;显存从B8000H 开始,映射到3G开始的线性地址空间。 表1

(1)、请设计并填写页目录表和页表(需说明每张表的内存地址)内存的物理地址200000H(=0010 0000 0000 [0000 0000 0000])映射到的线性地址为3G+4M(=[1100 0000 01] [00 0000 0000] [0000 0000 0000]), 内存的物理地址400000H(= 0100 0000 0000 [0000 0000 0000])映射到的线性地址为400000H(=[0000 0000 01] [00 0000 0000] [0000 0000 0000]), 内存的物理地址B8000H(=1011 1000 [0000 0000 0000])映射到的线性地址为3G(=[1100 0000 00] [00 0000 0000] [0000 0000 0000]), 页目录表#0索引为0000 0000 01,该项值为所需页表在内存的块号,找到该页表后,00 0000 0000为页表索引,该值找到所需页的物理内存起始地址,又12位偏移值为0000 0000 0000,所以物理内存起始地址为:400000H 页目录表#1索引为1100 0000 00,该项值为所需页表在内存的块号,找到该页表后,00 0000 0000为页表索引,该值找到所需页的物理内存起始地址,又12位偏移值为0000 0000 0000,所以物理内存起始地址为:B8000H 页目录表#1索引为1100 0000 01,该项值为所需页表在内存的块号,找到该页表后,00 0000 0000为页表索引,该值找到所需页的物理内存起始地址,又12位偏移值为0000 0000 0000,所以物理内存起始地址为:200000H 所以设置页目录表1张,内存地址为...., 页表3张内存起始地址分别为0000 0000 01,1100 0000 00,1100 0000 01 (2)、线性地址为:C0401010H、C0404010H、C0414010H,则物理地址是多少,所在段的段名是什么?(需写出计算的详细步骤) C0401010=(1100 0000 01)(00 0000 0001) (0000 0001 0000)物理地址为: 0010 0000 0001 (0000 0001 0000)=201010H在第2段 C0404010=(1100 0000 01)(00 0000 0100) (0000 0100 0000)物理地址为: 0010 0000 0100 (0000 0100 0000)=204040H在第5段 C0414010=(1100 0000 01)(00 0001 0100) (0000 0001 0000)物理地址为: 0010 0001 0100 (0000 0001 0000)=214010H在第6段 实验步骤: 1、定义页目录表、页表的数据结构,以及必要的数据。 #define Page_Size 4096 // 页面大小

相关文档
最新文档