啥也不会还想学PWN

本文介绍了计算机数据存储的两种模式——大端序和小端序,其中大端序高位在前,小端序低位在前,并通过例子进行详细解释。此外,还讲解了文件描述符在Linux系统中的应用,如标准输入(0)、标准输出(1)和标准错误(2)。了解这些基础知识对于进行系统级编程至关重要。
摘要由CSDN通过智能技术生成

今天继续学习两个方面的知识:计算机的大端序和小端序、文件描述符。

计算机的大端序和小端序:简单来讲就是计算机储存数据的两种不同模式。大端序储存:数据的高位储存在计算机地址的低位,数据的低位储存在计算机地址的高位;而小端序则正好相反。

例如:数据0x0123456789abcdef,大端序储存。

0位低位地址,7为高位地址。

输入是就应该是:\x01\x23\x45\x67\x89\xab\xcd\xef

同样,小端序的情况:

输入的时候就应该是:\xef\xcd\xab\x89\x67\x45\x23\x01

这两种方式,大端序更符合人的阅读习惯,而相对计算机的储存逻辑和计算,小端序更加适合。

Linux是小端序,所以在以字符串形式输入时,(如:0xdeadbeef)就应该输入成:\xef\xbe\xad\xde.当然,有pwntools的帮助下可以直接P32完成自动转换。

文件描述符:常见于read、write、open等函数中。

0=标准输入(stdin),1=标准输出(stdout),2=标准错误(stden)。

例如:read(0,buf,size) 表示的是从stdin中读取size个数据到buf中;

write(1,buf,size)表示的是从buf中输出size个数据到stdout中。

这里方便记忆,可以认为数字与紧随其后的寄存器为一个整体,数字表示的是其后寄存器接下来要做的操作。(忽略格式:0,buf  意思就是buf的操作是0(输入);1,buf  的意思是buf

将要的操作是1(输出))。

好了,今天到这里。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值