段寄存器有啥作用
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了段寄存器有啥作用相关的知识,希望对你有一定的参考价值。
段寄存器里放的是地址还是数据还是其他的东西,能具体跟我讲下吗
1, 代码段寄存器CS:存放当前正在运行的程序代码所在段的段基值,表示当前使用的指令代码可以从该段寄存器指定的存储器段中取得,相应的偏移值则由IP提供。2, 数据段寄存器DS:指出当前程序使用的数据所存放段的最低地址,即存放数据段的段基值。
3, 堆栈段寄存器SS:指出当前堆栈的底部地址,即存放堆栈段的段基值。
4, 附加段寄存器ES:指出当前程序使用附加数据段的段基址,该段是串操作指令中目的串所在的段。
段寄存器里放的是地址还是数据还是其他的东西?是放的段基值,通俗说就是段的起始点(具体地址是段基值+偏移),这个数值是地址不是数据。 参考技术A 寄存器是CPU内部的元件,寄存器拥有非常高的读写速度,所以在寄存器之间的数据传送非常快。
寄存器的用途:
1.可将寄存器内的数据执行算术及逻辑运算。
2.存于寄存器内的地址可用来指向内存的某个位置,即寻址。
3.可以用来读写数据到电脑的周边设备。
8086 有8个8位数据寄存器,
这些8位寄存器可分别组成16位寄存器:
AH&AL=AX:累加寄存器,常用于运算;
BH&BL=BX:基址寄存器,常用于地址索引;
CH&CL=CX:计数寄存器,常用于计数;
DH&DL=DX:数据寄存器,常用于数据传递。
为了运用所有的内存空间,8086设定了四个段寄存器,专门用来保存段地址:
CS(Code Segment):代码段寄存器;
DS(Data Segment):数据段寄存器;
SS(Stack Segment):堆栈段寄存器;
ES(Extra Segment):附加段寄存器。
当一个程序要执行时,就要决定程序代码、数据和堆栈各要用到内存的哪些位置,通过设定段寄存器 CS,DS,SS 来指向这些起始位置。通常是将DS固定,而根据需要修改CS。所以,程序可以在可寻址空间小于64K的情况下被写成任意大小。 所以,程序和其数据组合起来的大小,限制在DS 所指的64K内,这就是COM文件不得大于64K的原因。8086以内存做为战场,用寄存器做为军事基地,以加速工作。 参考技术B 远古时期,段寄存器确实如楼上所说的,指定某一段数据在哪存放的,长度是多少。
但是现在段寄存器的作用更多的是控制权限,我们可以通过OD,windbg等调式工具看到每个进程的寄存器的值,其中包括段寄存器,CS DS SS FS ES GS 等等。。每一个段寄存器里面的数据可以看作是一个结构体。包括,16位段选择子,32位的Base(基址),32位的Limit(长度),16位的Attribute(属性),总共96位。
不难发现,好几个段寄存器里的Base都是 0 , Limit 都是FFFFFFFF,都知道每个进程有虚拟的独立的4GB空间,0 - FFFFFFFF 可以查找的范围刚好就是4GB,但是有很多地方在用户态(可以理解为我们自己写的程序)是访问不了的,要想访问那些访问不了的地方,就要修改段寄存器的值,来达到能访问的目的。
当然有些地方光修改段寄存器也不可以,还有页的机制来保护这些地方。
如果想深入可以看看CPU保护模式。
这段代码有啥问题? [关闭]
【中文标题】这段代码有啥问题? [关闭]【英文标题】:what`s wrong with this code? [closed]这段代码有什么问题? [关闭] 【发布时间】:2014-06-15 12:51:24 【问题描述】:我写了这个,但它不起作用,找不到错误。 此服务器端代码获取变量 $cpu & $display 并将其用于从数据库中选择。当变量不重要时,将发送“*”。
<?php
if (isset($_REQUEST['action']))
$action = $_REQUEST['action'];
else
echo "Invalid Data";
exit;
if ($action == "read")
readData();
function connectToDatabase()
$connection = mysqli_connect("localhost", "root", "", "project_pro");
if (mysqli_connect_errno())
echo "Failed to connect to MySQL: " . mysqli_connect_error();
return $connection;
function readData()
$connection = connectToDatabase();
$cpu = $_REQUEST['cpu'];
$display = $_REQUEST['display'];
这是存在问题的部分:
$sql = "Select * From phones WHERE";
if ($cpu == "*")
else
$sql+= " phone_cpu='$cpu'";
if ($display == "*")
else
$sql+= " AND phone_display='$display'";
$output = array();
while ($row = mysqli_fetch_array($result))
$record = array();
$record['phone_id'] = $row['phone_id'];
$record['phone_cpu'] = $row['phone_cpu'];
$output[] = $record;
echo json_encode($output);
mysqli_close($connection);
【问题讨论】:
好吧,由于缺乏适当的缩进,很难阅读,对于一个......:p += 是 javascript,而不是 php! :)。 php 中的连接是 .= 【参考方案1】:PHP 中的连接运算符是.
而不是+
。所以把+=
改成.=
。
【讨论】:
+ 他从未执行过查询时试图获取 $row = mysqli_fetch_array($result) 的事实..以上是关于段寄存器有啥作用的主要内容,如果未能解决你的问题,请参考以下文章