20170704学习笔记

一、Linux上地址映射:

1、逻辑地址:由程序产生的和段相关的偏移地址部分

线性地址:是逻辑地址到物理地址变换的中间层,程序代码会产生逻辑地址,段中的偏移地址加上相应段的基地址就生成了一个线性地址。在Intel 80836的线性地址空间从0x00 00 00 00----0xff ff ff ff,为2^32次方,就是4G大小。

物理地址:指出目前CPU外部地址总线上的寻址物理内存的地址信号,是地址变换的最终结果地址。

2.实模式和保护模式的区别:

实模式将整个物理内存看成分段区域,程序的代码和数据位于不同区域,系统程序和用户程序没有区别对待,而且每一个指针都是指向实在的物理地址。不能使用多线程,不能实现权限分级

保护模式包括权限分级,内存分页,多任务等功能

3.从逻辑地址到线性地址的转化:

DS段选择符:

GDTR指向GDT表,指明是标的哪一项

在Linux系统中所有的段起始地址都是0x 00 00 00 00

所以Linux中逻辑模式和线性模式的地址相同。

将线性地址转化为物理地址:

将32位地址分为三部分:

前10位:0-1023个值,表示在页目录表里找到指向的哪个页表

中间10位:0-1023个值,指定在页表里的哪一项,在真实的地址里用的是哪一个页框;

后12位:表示在页里的偏移

在Linux里面cd /proc/pid/pagemap允许用户态的进程查看每个虚拟页映射到的物理页,一共8个字节64个位,0-55位转化为十进制用来表示物理页号,第63位0表示不在内存中,1表示在内存中,可以用cat status查看,要找到当前进程的pid,有一个self链接文件,直接链接到当前进程的pid,即就是/proc/self/pagemap;
在Linux中实现的代码如下:

#include<stdio.h>

#include<stdlib.h>

#include<unistd.h>

#include<stdint.h>

#include<assert.h>

#include<fcntl.h>

#include<sys/stat.h>

#include<sys/types.h>

int mem_addr(unsigned long vaddr,unsigned long *phy)

{

int pagesize = getpagesize();

unsigned long v_index = vaddr/pagesize;

unsigned long v_offset = v_insex * sizeof(uin64_t);

unsigned long page_offset = vaddr%pagesize;

uin64_t item = 0;

int fd = open("/proc/self/pagemap",O_RDONLY);

if(fd == -1)

{

printf("open pagemap error\n");

return ;

}

if(lseek(fd,v_offset,SEEK_SET)==-1)

{

printf("sleek error\n");

return ;

}

if(read(fd,&item,sizeof(uint64_t)) != sizeof(uint64_t))

{

Printf(“read item error\n”);

return;

}

if((((uin64_t)1<<63)&item)==0)

{

printf("flg faild\n");

return ;

}

uin64_t phy_index = (((uin64_t)1<<55)-1)&item;

*phy = phy_index * pagesize + page_offset;

}

int main()

{

int a = 0;

int addr = 0;

mem_addr(&a,&addr);

}

测试:数据段值改变,代码段值不变

局部变量:a = 0,addr = 0; 线性地址不变,物理地址改变

全局变量:int g = 0;线性地址不变,物理地址改变

函数:mem_addr(fun,addr);线性地址不变,物理地址不变;

堆区:fork()以后如果对子进程的内存不进行改变,物理地址不变,如果进行改变,物理地址也会改变。

二、斐波那契数列:

举例:1  1  2  3  5  8  13  21  34  55  89

所以F(11) = 89;

1.循环:

int fab(int n)

{

if(n == 1 || n == 2)

{

return 1;

}

int num1 = 1;

int num2 = 1;

int tmp = 0;

while (n-2)

{

tmp = num1;

num1  = num2;

num2 = num2 + tmp;

n--;

}

return num2;

}

2.递归:

int fab2(int n)

{

if (n ==1 || n == 2)

{

return 1;

}

else

return fab2(n-1)+fab2(n-2);

}

3.改进的循环

int fab3(int num1,int num2,int n)

{

if (n ==1 || n == 2)

{

return 2;

}

else

return fab3(num2,num1+num2,n-1);

}

时间: 2024-12-23 23:16:38

20170704学习笔记的相关文章

vector 学习笔记

vector 使用练习: /**************************************** * File Name: vector.cpp * Author: sky0917 * Created Time: 2014年04月27日 11:07:33 ****************************************/ #include <iostream> #include <vector> using namespace std; int main

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则 用了几天时间看了一下开源框架Caliburn.Micro 这是他源码的地址http://caliburnmicro.codeplex.com/ 文档也写的很详细,自己在看它的文档和代码时写了一些demo和笔记,还有它实现的原理记录一下 学习Caliburn.Micro要有MEF和MVVM的基础 先说一下他的命名规则和引导类 以后我会把Caliburn.Micro的 Actions IResult,IHandle ICondu

jQuery学习笔记(一):入门

jQuery学习笔记(一):入门 一.JQuery是什么 JQuery是什么?始终是萦绕在我心中的一个问题: 借鉴网上同学们的总结,可以从以下几个方面观察. 不使用JQuery时获取DOM文本的操作如下: 1 document.getElementById('info').value = 'Hello World!'; 使用JQuery时获取DOM文本操作如下: 1 $('#info').val('Hello World!'); 嗯,可以看出,使用JQuery的优势之一是可以使代码更加简练,使开

[原创]java WEB学习笔记93:Hibernate学习之路---Hibernate 缓存介绍,缓存级别,使用二级缓存的情况,二级缓存的架构集合缓存,二级缓存的并发策略,实现步骤,集合缓存,查询缓存,时间戳缓存

本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 -----------------------------------------------------------------------------------------------------------------

Activiti 学习笔记记录(三)

上一篇:Activiti 学习笔记记录(二) 导读:上一篇学习了bpmn 画图的常用图形标记.那如何用它们组成一个可用文件呢? 我们知道 bpmn 其实是一个xml 文件

HTML&CSS基础学习笔记8-预格式文本

<pre>标签的主要作用是预格式化文本.被包围在 pre 标签中的文本通常会保留空格和换行符.而文本也会呈现为等宽字体. <pre>标签的一个常见应用就是用来表示计算机的源代码.当然你也可以在你需要在网页中预显示格式时使用它. 会使你的文本换行的标签(例如<h>.<p>)绝不能包含在 <pre> 所定义的块里.尽管有些浏览器会把段落结束标签解释为简单地换行,但是这种行为在所有浏览器上并不都是一样的. 更多学习内容,就在码芽网http://www.

java/android 设计模式学习笔记(14)---外观模式

这篇博客来介绍外观模式(Facade Pattern),外观模式也称为门面模式,它在开发过程中运用频率非常高,尤其是第三方 SDK 基本很大概率都会使用外观模式.通过一个外观类使得整个子系统只有一个统一的高层的接口,这样能够降低用户的使用成本,也对用户屏蔽了很多实现细节.当然,在我们的开发过程中,外观模式也是我们封装 API 的常用手段,例如网络模块.ImageLoader 模块等.其实我们在开发过程中可能已经使用过很多次外观模式,只是没有从理论层面去了解它. 转载请注明出处:http://bl

[原创]java WEB学习笔记48:其他的Servlet 监听器:域对象中属性的变更的事件监听器 (3 个),感知 Session 绑定的事件监听器(2个)

本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 ---------------------------------

java/android 设计模式学习笔记(10)---建造者模式

这篇博客我们来介绍一下建造者模式(Builder Pattern),建造者模式又被称为生成器模式,是创造性模式之一,与工厂方法模式和抽象工厂模式不同,后两者的目的是为了实现多态性,而 Builder 模式的目的则是为了将对象的构建与展示分离.Builder 模式是一步一步创建一个复杂对象的创建型模式,它允许用户在不知道内部构建细节的情况下,可以更精细地控制对象的构造流程.一个复杂的对象有大量的组成部分,比如汽车它有车轮.方向盘.发动机.以及各种各样的小零件,要将这些部件装配成一辆汽车,这个装配过