vc编译exe的体积最小优化

参考链接:vc编译exe的体积最小优化

人们都说 vc 做出的东西可以小点,现在你打开vc编译一个Hello World出来!点属性看下,咦!我没走眼吧,就一Hello World就160kb真是要人命啊!
呵呵!上面的情况是笔者所遭遇的情况.不过后来了解vc可以通过设置参数来自定义编译方式.为什么文件那么大!主要是编译器加入了很多没必要的代码(这里是对我们而言,不过有些代码还是有利于安全的).好了我们就手动改下编译器的参数来看看能到多大!

我们主要用到的技巧有:

一,使用release版而不用debug版编译

使用debug版编译会生成许多垃圾信息.我们先使用默认的设置进行一下编译.可以看到编译后生成的文件有152k之巨.使用release版编译具体方法是:在"build(编译)--->Configuration(配置)"中将"Win32 debug"移去,然后再次编译可以发现文件已经小了很多,才24k.但离我们的目标还很远呢.

二,设置自己的入口点函数

C或C++程序默认的入口函数是main()或WinMain(),但我们现在不用什么Main,WinMain.因为这些都不是直接的入口点,编译器在产生exe文件的时候,将为我们生成真正的入口点.下面我们来定义自己的入口函数,具体是把main或WinMain改成其它的名字(如MyFun),打开"Project(工程)--->settings(设置)"选项,选中"link"选项卡,在"Category(分类)"下拉列表中选"output",在" Entry-Point symbol(输入项-点符号)"中输入我们刚才定义的入口函数(MyFun),在源程序中也要做相应修改,然后再编译.现在是16k了:)

三,更改编译对齐方式

通常VC在编译的时候,采用的对齐方式是0x1000,即4096bytes,我们现在将他改成0x200,即512bytes.

在刚才打开的"link"选项卡,在下面的"Project options(工程选项)"中添加:/align:512(还可以将512设

置的更小如16,32.....).注意两个参数之间有个空格. 3k了_用32试试 1.84k好~~~用16 1.79k天哪!

再把程序的数据段和代码段放在一起,添加:/merge.data=.text /merge:.rdata=.text 1.76k go on!

另外,如果要是用到MFC函数的程序,可在"Project(工程)--->settings(设置)"里面的"通用(General)"选项卡中在"Microsoft Foundation Classes"中选择使用一个MFC的dll(Use MFC in a Share Dll)也会使文件大小缩小很多.现在我们的超小后门编译好了,试下能用否. ok 没问题哦

大家注意到程序运行时会产生一个cmd窗口,要让他没有就好了.这也好办.

回到VC++中,在"Project(工程)--->settings(设置)"选项,选中"link"选项卡,在下面的"Project options(工程选项)"有/subsystem:console选项,表示程序是控制台程序,双击运行是会有一个cmd窗口,把console改为windows就没有窗口了.:),运行一下 没有窗口哦 但有进程 连接一下试试

ok 没问题 这样我们的超小1.76k telnet小后门就成功了 不被查杀哦 _

// 编译器 cl.exe(Visual C++ 6.0)
// 没有做任何优化情况下,编译大小为:16K
// 编译优化后: 1K (用16进制编辑器把尾部的0x00去掉: 712bytes)
#include <windows.h>
#pragma comment(lib,"kernel32.lib")

// 作用: 指定节对齐为512字节
#pragma comment(linker, "/align:512")

// 作用: 合并节
// 将.data节和.rdata节合并到.text节(代码节)
#pragma comment(linker, "/merge:.data=.text")
#pragma comment(linker, "/merge:.rdata=.text")

// 作用: 指定子[系统](https://www.2cto.com/os/)为windows (和优化无关)
// vc编译器默认是console,会有个黑糊糊的CMD窗口,不好看.用windows就好了
#pragma comment(linker, "/subsystem:windows")

// 作用: 指定入口函数
// 子系统为windows的默认入口点WinMain和console的默认入口点main,都会引入

#pragma comment(linker, "/ENTRY:main")

//int WinMain(HINSTANCE current, HINSTANCE prev, LPSTR cmdline, int
//showcmd)

// 作用: 去掉函数的栈帧代码,纯属吹毛求疵:-)
// 即函数开头的push ebp / mov ebp, esp和结尾的pop ebp / retn
__declspec(naked)
void main()
{
// 调用wmp. 这是按套路出牌的方法.
//typedef VOID (__stdcall *fnRunDllW)(HWND, HINSTANCE, LPCWSTR, DWORD);
//((fnRunDllW)GetProcAddress(LoadLibrary("msdxm.ocx"), "RunDllW"))(0,0,0,0);

// 不按套路出牌,不压入RunDllW的函数参数,直接调用.
//GetProcAddress(LoadLibrary("msdxm.ocx"), "RunDllW")();
MessageBox(0,0,0,0);
// 注意此时的堆栈是不平衡的.
// 但是通过ExitProcess()退出自身,就不用去考虑平衡了.
ExitProcess(0);
}

微软C/C++ 编译器选项

-优化-

/O1
最小化空间

/Op[-]
改善浮点数一致性

/O2
最大化速度

/Os
优选代码空间

/Oa
假设没有别名

/Ot
优选代码速度

/Ob<n>
内联展开(默认 n=0)

/Ow
假设交叉函数别名

/Od
禁用优化(默认值)

/Ox
最大化选项。(/Ogityb2 /Gs)

/Og
启用全局优化

/Oy[-]
启用框架指针省略

/Oi
启用内部函数

-代码生成-

/G3
为 80386 进行优化

/GH
启用 _pexit 函数调用

/G4
为 80486 进行优化

/GR[-]
启用 C++ RTTI

/G5
为 Pentium 进行优化

/GX[-]
启用 C++ EH(与 /EHsc 相同)

/G6
为 PPro、P-II、P-III 进行优化

/EHs
启用 C++ EH(无 SEH 异常)

/GB
为混合模型进行优化(默认)

/EHa
启用 C++ EH(w/ SEH 异常)

/Gd
__cdecl 调用约定

/EHc
外部“C”默认为 nothrow

/Gr
__fastcall 调用约定

/GT
生成纤维安全 TLS 访问

/Gz
__stdcall 调用约定

/Gm[-]
启用最小重新生成

/GA
为 Windows 应用程序进行优化

/GL[-]
启用链接时代码生成

/Gf
启用字符串池

/QIfp[-]
启用 Pentium FDIV 修复

/GF
启用只读字符串池

/QI0f[-]
启用 Pentium 0x0f 修复

/Gy
分隔链接器函数

/QIfist[-]
使用 FIST 而不是 ftol()

/GZ
启用堆栈检查 (/RTCs)

/RTC1
启用快速检查 (/RTCsu)

/Ge
对所有函数强制堆栈检查

/RTCc
转换为较小的类型检查

/Gs[num]
控制堆栈检查调用

/RTCs
堆栈帧运行时检查

/GS
启用安全检查

/RTCu
未初始化的本地用法检查

/Gh
启用 _penter 函数调用

/clr[:noAssembly]
为公共语言运行时库编译noAssembly - 不产生程序集

-输出文件-

/Fa[file]
命名程序集列表文件

/Fo<file>
命名对象文件

/FA[sc]
配置程序集列表

/Fp<file>
命名预编译头文件

/Fd[file]
命名 .PDB 文件

/Fr[file]
命名源浏览器文件

/Fe<file>
命名可执行文件

/FR[file]
命名扩展 .SBR 文件

/Fm[file]
命名映射文件

-预处理器-

/AI<dir>
添加到程序集搜索路径

/Fx
将插入的代码合并到文件

/FU<file>
强制使用程序集/模块

/FI<file>
命名强制包含文件

/C
不抽出注释

/U<name>
移除预定义宏

/D<name>{=|#}<text>
定义宏

/u
移除所有预定义宏

/E
预处理到 stdout

/I<dir>
添加到包含搜索路径

/EP
预处理到 stdout,没有 #line

/X
忽略“标准位置”

/P
预处理到文件

-语言-

/Zi
启用调试信息

/Zl
忽略 .OBJ 中的默认库名

/ZI
启用“编辑并继续”调试信息

/Zg
生成函数原型

/Z7
启用旧式调试信息

/Zs
只进行语法检查

/Zd
仅有行号调试信息

/vd{0|1}
禁用/启用 vtordisp

/Zp[n]
在 n 字节边界上包装结构

/vm<x>
指向成员的指针类型

/Za
禁用扩展(暗指 /Op)

/noBool
禁用“bool”关键字

/Ze
启用扩展(默认)

/Zc:arg1[,arg2]
C++ 语言一致性,这里的参数可以是:forScope - 对范围规则强制使用标准 C++;wchar_t - wchar_t 是本机类型,不是 typedef

  • 杂项 -

@<file>
选项响应文件

/wo<n>
发出一次警告 n

/?, /help
打印此帮助消息

/w<l><n>
为 n 设置警告等级 1-4

/c
只编译,不链接

/W<n>
设置警告等级(默认 n=1)

/H<num>
最大外部名称长度

/Wall
启用所有警告

/J
默认 char 类型是 unsigned

/Wp64
启用 64 位端口定位警告

/nologo
取消显示版权消息

/WX
将警告视为错误

/showIncludes
显示包含文件名

/WL
启用单行诊断

/Tc<source file>
将文件编译为 .c

/Yc[file]
创建 .PCH 文件

/Tp<source file>
将文件编译为 .cpp

/Yd
将调试信息放在每个 .OBJ 中

/TC

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,233评论 6 495
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,357评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,831评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,313评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,417评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,470评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,482评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,265评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,708评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,997评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,176评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,503评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,150评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,391评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,034评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,063评论 2 352

推荐阅读更多精彩内容

  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 4,380评论 0 5
  • ORA-00001: 违反唯一约束条件 (.) 错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。 O...
    我想起个好名字阅读 5,272评论 0 9
  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 3,340评论 0 2
  • 一、温故而知新 1. 内存不够怎么办 内存简单分配策略的问题地址空间不隔离内存使用效率低程序运行的地址不确定 关于...
    SeanCST阅读 7,791评论 0 27
  • feisky云计算、虚拟化与Linux技术笔记posts - 1014, comments - 298, trac...
    不排版阅读 3,837评论 0 5