UE4编码规范
翻译原文为Unreal 的官方!自己看着总结了一下,不一定每条都能对上。不足之处,请多多不吝赐教!
原文地址: unreal CodingStandard
UE4编码规范
在Epic,有简单几条代码编写标准:
l 代码生命的80%时间在于维修
l 没有一个软件在整个过程中仅仅有原作者在维护
l 编码规范能够提供软件可读性,新手可迅速透彻理解代码。新的project师来会建立新的project改动代码。
l 若对社区开发人员放出源代码,希望代码易于理解。
l 须要满足交叉编译。
命名规范
l 首字母大写,不使用下划线
l 第一个字母为变量类型。
模块前缀为T
继承UObject前缀为U
继承AActor前缀为A
继承SWidget前缀为S
继承抽象接口前缀为I
其它大多数前缀为F,也有一些子类用其它字母。
l 类型和变量为名词
l 方法行为名称为动词,描写叙述方法作用,或返回值。
变量和方法,类名须要清晰,避免过度缩写。
全部变量一次仅仅能声明一个,凝视能够正常使用。javaDocs类型须要它们。你能够多行或单行凝视来凝视。
函数须要返回bool型,bool变量的前缀为b.
无返回值函数,须要动词后面加对象。名称避免不明白功能的字眼
基础C++对象类型
bool不要使用BOOL
TCHAR,不用使用CHAR
uint8
int8
uint16
int16
uint32
int32
Uint64
Int64
Float,单精度浮点
Double,双精度浮点数
PTRINT,带有指针的整型
凝视
凝视即沟通,沟通非常关键。将凝视印在脑海。(Kernighan & Pike The Practice of Programming )
UE4使用JavaDoc来自己主动解析代码凝视,编译生成文档。所以要注意凝视格式。
C++11新特性使用
能够非常好支持的眼下主要有auto,for循环和lambda表达。有时候我们仅仅是用宏定义这样特性折叠了。
l Auto
使用auto,在编译期间绑定变量类型。若鼠标悬停在vs变量上,将会告诉你auto变量的实际类型。
l For循环
代码更简洁,易于维护。
l Lambda表达匿名函数
Lambda是可用的,可是眼下我们使用非常慎重。
第三方代码
编码格式
{}须要另起一行。
If-else,不论什么使用都要使用括号。多行可用把else-if放在一行上。
Switch,必有一个default.
命名空间
l 使用自己的命名空间,注意不要重名,尤其不要与第三方库重名
l 不使用using在全局范围,甚至在cpp中也不使用。
l 在命名空间里使用命名空间,或在函数内使用命名空间是没问题。
l 使用命名空间要确认一致性。
l 前向声明类型须要在他们单独的命名空间中进行。
l 若声明了大量的类或类型在一个命名空间下,则在全局范围内使用须要明白的支出命名空间
l Using,最好不要使用别名。
l 枚举类型在命名空间里声明,防止全局都可见。
物理独立
全部编译器支持#pragma once.
要直接使用头文件包括,不要间接的使用。
不要操心头文件的的预编译头设置,UnrealBuild比你做的要好。
常见格式
l 变量在近期的使用地方定义。
l 尽可能切割多的方法。
l 函数声明或调用,函数名称之前不要空格。
l 在.h和cpp文件结尾加上一行空格,由于Gcc编译须要。
l 不要把浮点float隐形转换为int,由于不是所以编译器能够编译的。要使用appTrunc()来转换。
l 不是接口的,要用private类型保护数据。
l 接口类不要写变量。接口类里同意非纯虚函数,或非虚函数或静态函数的。
l 多使用const.
l 切割多个表达,使代码易于理解。使用中间变量使复杂表达简单化。
const bool bIsLegalWindow = Blah->BlahP->WindowExists->Etc && Stuff;
const bool bIsPlayerDead = bPlayerExists && bGameStarted && bPlayerStillHasPawn && IsTuesday();
if (bIsLegalWindow && !bIsPlayerDead)
{
DoSomething();
}
l 虚函数记得使用override
l 指针的*号,靠近对象来放置,便于搜素某类型的指针类对象。
----------------------
若有问题,请随时联系!
UE4编码规范的更多相关文章
- Android的编码规范
一.Android编码规范 1.学会使用string.xml文件 在我看来,当一个文本信息出现的次数大于一次的时候就必须要使用string.xml 比如一个保存按钮 , 不规范写法: <Butt ...
- PHP 高级编程(1/5) - 编码规范及文档编写
PHP 高级程序设计学习笔记20140612 软件开发中的一个重要环节就是文档编写.他可以帮助未来的程序维护人员和使用者理解你在开发时的思路.也便于日后重新查看代码时不至于无从下手.文档还有一个重要的 ...
- 【原】JAVA SE编码规范
/* * 编码规范: * 1.所有的命名遵循"见名知意"的原则 * 2.所有的命名不允许使用汉字或拼音 * 3.Java的工程命名建议使用小写,比如:oa.crm.cms... * ...
- 浅谈Android编码规范及命名规范
前言: 目前工作负责两个医疗APP项目的开发,同时使用LeanCloud进行云端配合开发,完全单挑. 现大框架已经完成,正在进行细节模块上的开发 抽空总结一下Android项目的开发规范:1.编码规范 ...
- PHP编码规范PSR-2
.note-content { font-family: "Helvetica Neue", Arial, "Hiragino Sans GB", STHeit ...
- Objective-C开发编码规范【转载】
概要 Objective-C是一门面向对象的动态编程语言,主要用于编写iOS和Mac应用程序.关于Objective-C的编码规范,苹果和谷歌都已经有很好的总结: Apple Coding Guide ...
- 前端编码规范之CSS
"字是门面书是屋",我们不会去手写代码,但是敲出来的代码要好看.有条理,这还必须得有一点约束~ 团队开发中,每个人的编码风格都不尽相同,有时候可能存在很大的差异,为了便于压缩组件对 ...
- 前端编码规范之JavaScript
上次浅谈了下关于CSS的编码规范,大部分童鞋持赞同意见,仍存在一些童鞋不太理解这些规范的意义. 如果是个人或者小作坊开发,其实这些所谓的编码规范也没啥意思,因为大家写好的代码直接就给扔到网上去了,很少 ...
- Java Script 编码规范【转】
Java Script 编码规范 以下文档大多来自: Google JavaScript 编码规范指南 Idiomatic 风格 参考规范 ECMAScript 5.1 注解版 EcmaScript ...
随机推荐
- USM锐化之openCV实现,附赠调整对比度函数
源地址:http://www.cnblogs.com/easymind223/archive/2012/07/03/2575277.html 常用Photoshop的玩家都知道Unsharp Mask ...
- 对TMemoryStream的一些改进(用到了LockFile)
对TMemoryStream的一些改进 怎么又是关于Stream的,呵呵,应该说只是最近比较关心程序的效率问题,而我对Stream其实并没有什么特别的研究,只是自己发现了一些新的用法,希望能对大家有用 ...
- find . -iname "*.jpg"|xargs -i mv {} .;for i in `ls`; do mv -f $i `echo $i | sed 's/JPG/jpg/'`; done
find . -iname "*.jpg"|xargs -i mv {} .;for i in `ls`; do mv -f $i `echo $i | sed 's/JPG/jp ...
- NSDate的处理:前一天、后一天等关于时区偏移的处理以及在数据库中的使用
看来非常多网上关于日期的处理,今天.昨天.前天.后天.一周等,满心欢喜的拿着去验证结果总是不尽如人意,看别别人的代码看的脑涨.自己就写一个简单的,自己来用,以后用其它的方法,我会在完好,再次记录.以方 ...
- 利用手工编码的方式对srtus2进行输入验证
对action方法进行校验有两种方法一种是: 1手工编码书写 2一种是用xml 输入校验的流程: 1类型转化器对请求参数执行类型转化,并把转换后的值赋给action属性. 2.如果执行类型转化的过程中 ...
- struts2+jquery +json实现异步加载数据,亲测(原创)
//初始加载页面时 $(document).ready(function(){ //为获取单个值的按钮注册鼠标单击事件 $("#getMessage").click(functio ...
- 区间Dp 暴力枚举+动态规划 Hdu1081
F - 最大子矩形 Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & %I64u Submit Status Des ...
- 应届GIS硕士求职经验总结
记录一下作为一个GIS应届毕业生在帝都找工作的历程吧,之后的经历可能丰富多彩,可能萎靡不振,但这一次走过来了就是这一次的.希望以史为鉴,各位客官也能有所收获. 定位 我们这一届的"烟酒生&q ...
- JavaBean在DAO设计模式简介
一.信息系统开发框架 客户层-------显示层-------业务层---------数据层---------数据库 1.客户层:客户层是client,简单的来说就是浏览器. 2.显示层:JSP/Se ...
- File already exists: filesystem '/path/file', transaction svn常见错误解决方法
前言 多人任务基本都会用到SVN,于是提交的时候如果不先更新在提交或者操作顺序不对,会经常出现错误,其中File already exists: filesystem这个就是个常见问题,上网找了半天没 ...