c++,python,汇编语言,reverse
@TOC
计算机语言方面
c++
高中学过一段时间,有一点儿基础,在leetcode上做了几道题,基本上都是暴力循环解决,还有写了高精度加减法,复习一下。
vector
不定长度的数组,可以一直加元素,和字符串中的string感觉差不多。
vector.size()可以计算元素个数
string.length()可以计算字符的个数
==注意:sizeof()函数是计算内存数并非计算元素个数==
可以用 .size() 或者用 (sizeof(xxx)/每个元素所占内存)计算元素个数
常用的
int型每个元素占4字节
char型每个元素占1字节
float型每个元素占4字节
double型每个元素占8字节
数据类型范围
int (-2^31–2^31-1)
longlong (-2^63–2^63-1)
short int (-2^15–2^15-1)
高精度计算的技巧
1.倒序存储数据,是运算时符合竖式加减的顺序
2.数组中的每一个元素可以存储不止一位的数据,可以大大减少运算次数
python
#!/usr/bin/env python3 (选择用python还是python3编译)
字符串 s=’’,可以直接s+=
for i in s: 循环
from pwn import
import base64 (导入pwn,base64库)
python2和python3很多东西不兼容
汇编语言
AX,BX,CX,DX(前面不加E16位,加E后32位)
计算机内部的寄存器,用寄存器处理数据远远快于存储器
SP,BP
两种解释,还不太懂
1.sp:栈顶指针
bp:基数指针寄存器
进入函数时保存sp的值,用sp对栈进行操作,结束时赋值给sp,使sp不改变
大小端存储
大概理解:一个地址0x4000可以存储一个字节数据,而像int型数据是4个字节,所以需要四个地址单元存储,而像栈这样的数据结构是从栈底到栈顶依次进入数据,这样的话就会有int型数据排列顺序的问题(栈底排最高位的一个字节,还是排最低位的一个字节),小端存储就是将最低位的字节先排在栈底,依次向上。大端存储相反
db,dw,dd,dq
db占1字节
dw占2字节
dd占4字节
dq占8字节
有时候和小端存储一起会导致找错数据
ctf 二进制
reverse
ida快捷键
F5:转伪代码
Alt+T:查找文本
G:找到某地址
空格:文本,流程图转换
shift+F12:字符串窗口
R:转换为字符
shift+E:导出数据
A:转字符串
D:dd-dw-db转换
H:10进制16进制转换
-------------本文结束感谢您的阅读-------------