常用作编译命令行指定的单个go源码包。会生成一个以文件.o为后缀的目标文件,其文件名与包内第一个源文件的文件名相同。 目标文件可以与其他对象组合成一个包档案或直接传递给链接器(go tool link)。如果使用-pack调用,编译器会直接写入一个档案(archive),绕过中间目标文件。

生成的文件包含有关由包导出的符号的类型信息,以及包使用的从其他包导入的符号使用的类型。因此,在编译包P的客户端C读取P的依赖关系文件时,不需要编译P的输出。

命令行

go tool compile [flags] file...

指定的文件必须是Go源文件和同一个包下的其他部分。所有目标操作系统和体系结构都使用相同的编译器。 GOOS和GOARCH环境变量设置了所需的属性。

-D path
设置本地导入的相对路径。
-I dir1 -I dir2
在dir1,dir2等文件夹搜索导入的包,
会先查询 $GOROOT/pkg/$GOOS_$GOARCH.
-L
在错误消息中显示完整的文件路径。
-N
禁用优化。
-S
将汇编列表打印到标准输出(仅限代码)。
-S -S
将汇编列表打印到标准输出(代码和数据)。
-V
打印编译器版本并退出。
-asmhdr file
将汇编头写入文件。
-blockprofile file
编写用于编译到文件的块配置文件。
-complete
假设软件包没有非Go组件。
-cpuprofile file
编写用于编译文件的CPU配置文件。
-dynlink
允许引用共享库中的Go符号(实验性功能)。
-e
移除报告错误数量限制(默认限制为10)。
-h
在检测到第一个错误时暂停堆栈跟踪。
-importmap old=new
在编译过程中将导入“旧”解释为导入“新”。
该选项可以重复添加。
-installsuffix suffix
在 $GOROOT/pkg/$GOOS_$GOARCH_suffix 查找包
而非 $GOROOT/pkg/$GOOS_$GOARCH.
-l
禁用内联。
-largemodel
生成假定大内存模型的代码。
-linkobj file
将链接器特定的对象写入文件和编译器特定的对象
对象到通常的输出文件(由-o指定)。
没有这个标志,-o输出是两者的组合
链接器和编译器输入。
-memprofile file
写入内存配置文件。
-memprofilerate rate
设置 runtime.MemProfileRate 调整编译速度。
-msan
将调用插入到C/C++内存清理程序。
-mutexprofile file
编写用于编译文件的互斥量配置文件。
-nolocalimports
禁止本地(相对)导入。
-o file
将目标写入文件(默认file.o或与-pack,file.a)。
-p path
为正在编译的代码设置期望的包导入路径,
并诊断会导致循环依赖的导入。
-pack
编写一个包(归档)文件而不是一个目标文件
-race
编译启用竞争检测器。
-trimpath prefix
从记录的源文件路径中删除前缀。
-u
禁止导入未标记为安全的软件包;意味着 -nolocalimports.

还有一些调试标志;运行该命令时没有使用消息的参数。

编译指令

编译器在行的开头以//注释的形式接受编译器指令。为了将它们与非指令注释区分开来,指令在斜线和指令名称之间不需要空格。但由于它们是注释,不知道指令约定或特定指令的工具可以像跳过其他注释一样跳过指令。

//line path/to/file:linenumber

//line指令指定后面的源代码行应该被记录为来自给定的文件路径和行号。连续的行使用递增的行号记录,直到下一个指令。该指令通常出现在机器生成的代码中,因此编译器和调试器将在生成器的原始输入中显示行。

//line指令是一个历史的特例;所有其他指令的格式为//go:name,表示该指令是由Go工具链定义的。

//go:noescape

//go:noescape指令指定文件中的下一个声明,它必须是一个没有body的func(意思是它有一个不用Go编写的实现),不允许任何作为参数传递的指针转义到堆或从函数返回的值。在调用函数的Go代码的编译器转义分析期间,可以使用这些信息。

//go:nosplit

//go:nosplit指令指定文件中声明的下一个函数不能包含堆栈溢出检查。在调用goroutine被抢占的时候,调用低级运行时源的情况最为常见。

//go:linkname localname importpath.name

//go:linkname指令指示编译器使用“importpath.name”作为源代码中声明为“localname”的变量或函数的目标文件符号名称。因为这个指令可以颠覆类型系统和包模块化,所以只有在导入 unsafe 包的文件中才能使用。

Go命令行—compile的更多相关文章

  1. Maven命令行使用:mvn clean compile(编译)

    先把命令行切换到Maven项目的根目录,比如:/d/xxxwork/java/maven-test,然后执行命令: mvn clean compile 执行结果如下: [INFO] Scanning ...

  2. .NET Core系列 : 1、.NET Core 环境搭建和命令行CLI入门

    2016年6月27日.NET Core & ASP.NET Core 1.0在Redhat峰会上正式发布,社区里涌现了很多文章,我也计划写个系列文章,原因是.NET Core的入门门槛相当高, ...

  3. Maven命令行使用:mvn clean package(打包)

    先把命令行切换到Maven项目的根目录,比如:/d/xxxwork/java/maven-test,然后执行命令:  mvn clean package 执行结果如下: [INFO] Scanning ...

  4. Maven命令行使用:mvn clean install(安装)

    先把命令行切换到Maven项目的根目录,比如:/d/xxxwork/java/maven-test,然后执行命令: $ mvn clean install 执行结果如下: [INFO] Scannin ...

  5. gcc 常用命令行及解释

    gcc - GNU project C and C++ compiler   gcc [option] file...            preprocessing         compila ...

  6. Maven学习(四)Maven 命令行选项

    说明: 1.使用-选项时,和后面的参数之间可以不要空格.而使用--选项时,和后面的参数之    间必须有空格.如下面的例子: $ mvn help:describe -Dcmd=compiler:co ...

  7. iOS系统提供开发环境下命令行编译工具:xcodebuild

    iOS系统提供开发环境下命令行编译工具:xcodebuild[3] xcodebuild 在介绍xcodebuild之前,需要先弄清楚一些在XCode环境下的一些概念[4]: Workspace:简单 ...

  8. Gradle命令行黑魔法

    毫无疑问,现在Gradle已经成为java世界最火的构建工具,风头已经盖过了冗余的ant,落后的maven.Gradle是以Groovy语言编写的一套构建脚本的DSL,由于Groovy语法的优雅,所以 ...

  9. Sass学习之路:Sass、Compass安装与命令行

    导言 CSS不是一门真正意义上的编程语言,很多编程语言理所当然的特性(比如变量),都不被支持.同时再开发模块化的web项目的时候,也要避免相互干扰.为了弥补CSS的这些不足,就产生了CSS预处理器,S ...

随机推荐

  1. Dubbo从入门到实战:实战篇

    一.加入 zookeeper 作为注册中心 在前面的案例中,我们没有使用任何的注册中心,而是用一种直连的方式进行的.但是,实际上很多时候,我们都是使用 dubbo + zookeeper 的方式,使用 ...

  2. python3在mac下配置

    目的 https://github.com/VonSdite/Plane_Wars 可以本地跑起来. 下载并安装python3 https://www.python.org/downloads/mac ...

  3. 手写SpringMVC实现过程

    1. Spring Boot,Spring MVC的底层实现都是Servlet的调用. 2. Servlet的生命周期里面首先是类的初始化,然后是类的方法的调用,再次是类的销毁. 3. 创建一个spr ...

  4. VS2017安装使用Easyx时出现的问题及解决方法

    EasyX 是针对 Visual C++ 的绘图库,在初学 C 语言实现图形和游戏编程.图形学.分形学等需要绘图实践的领域有一定应用. EasyX 库在 Visual C++ 中模拟了 Turbo C ...

  5. Python3---爬虫---抓取百度贴吧

    前言 该文章主要描述如何抓取百度贴吧内容.当然是简单爬虫实现功能,没有实现输入参数过滤等辅助功能,仅供小白学习. 修改时间:20191219 天象独行 import os,urllib.request ...

  6. python web框架Flask——csrf攻击

    CSRF是什么? (Cross Site Request Forgery, 跨站域请求伪造)是一种网络的攻击方式,它在 2007 年曾被列为互联网 20 大安全隐患之一,也被称为“One Click ...

  7. WebLogic任意文件上传漏洞复现与分析 -【CVE-2018-2894 】

    CVE-2018-2894 漏洞影响版本:10.3.6.0, 12.1.3.0, 12.2.1.2, 12.2.1.3 下载地址:http://download.oracle.com/otn/nt/m ...

  8. linux守护进程start-stop-daemon启动服务

    start-stop-daemon #! /bin/sh PATH=/sbin:/bin . /lib/lsb/init-functions do_start () { log_action_msg ...

  9. Mysql 索引精讲

    Mysql 索引精讲 开门见山,直接上图,下面的思维导图即是现在要讲的内容,可以先有个印象- 常见索引类型(实现层面) 索引种类(应用层面) 聚簇索引与非聚簇索引 覆盖索引 最佳索引使用策略 1.常见 ...

  10. docker安装执行问题

    ubuntu14.04上安装docker问题: sudo apt-get update curl -fsSL https://get.docker.com -o get-docker.sh sh ge ...