Unity面试题教案资料Word文件下载.docx
《Unity面试题教案资料Word文件下载.docx》由会员分享,可在线阅读,更多相关《Unity面试题教案资料Word文件下载.docx(19页珍藏版)》请在冰豆网上搜索。
AreaLight
九:
简述一下对象池,你觉得在FPS里哪些东西适合使用对象池
对象池就存放需要被反复调用资源的一个空间,当一个对象回大量生成的时候如果每次都销毁创建会很费时间,通过对象池把暂时不用的对象放到一个池中(也就是一个集合),当下次要重新生成这个对象的时候先去池中查找一下是否有可用的对象,如果有的话就直接拿出来使用,不需要再创建,如果池中没有可用的对象,才需要重新创建,利用空间换时间来达到游戏的高速运行效果,在FPS游戏中要常被大量复制的对象包括子弹,敌人,粒子等
十:
CharacterController和Rigidbody的区别
Rigidbody具有完全真实物理的特性,Unity中物理系统最基本的一个组件,包含了常用的物理特性,而CharacterController可以说是受限的的Rigidbody,具有一定的物理效果但不是完全真实的,是Unity为了使开发者能方便的开发第一人称视角的游戏而封装的一个组件
十一:
简述prefab的用处
在游戏运行时实例化,prefab相当于一个模板,对你已经有的素材、脚本、参数做一个默认的配置,以便于以后的修改,同时prefab打包的内容简化了导出的操作,便于团队的交流。
十二:
请简述sealed关键字用在类声明时与函数声明时的作用
sealed修饰的类为密封类,类声明时可防止其他类继承此类,在方法中声明则可防止派生类重写此方法。
十三:
请简述private,public,protected,internal的区别
public:
对任何类和成员都公开,无限制访问
private:
仅对该类公开
protected:
对该类和其派生类公开
internal:
只能在包含该类的程序集中访问该类
十四:
使用Unity3d实现2d游戏,有几种方式?
1.
使用本身的GUI,在Unity4.6以后出现的UGUI
2.把摄像机的Projection(投影)值调为Orthographic(正交投影),不考虑z轴;
3.使用2d插件,如:
2DToolKit,和NGUI
十五:
在物体发生碰撞的整个过程中,有几个阶段,分别列出对应的函数
三个阶段,1.OnCollisionEnter
2.OnCollisionStay
3.OnCollisionExit
十六:
Unity3d的物理引擎中,有几种施加力的方式,分别描述出来
rigidbody.AddForce/AddForceAtPosition,都在rigidbody系列函数中。
大家可以自己去查看一下rigidbody的API
十七:
什么叫做链条关节?
Hinge
Joint,可以模拟两个物体间用一根链条连接在一起的情况,能保持两个物体在一个固定距离内部相互移动而不产生作用力,但是达到固定距离后就会产生拉力。
十八:
物体自身旋转使用的函数?
Transform.Rotate()
;
物体围绕某点旋转使用的函数?
Transform.RotateAround()
十九:
Unity3d提供了一个用于保存和读取数据的类(PlayerPrefs),请列出保存和读取整形数据的函数
PlayerPrefs.SetInt()
PlayerPrefs.GetInt()
二十:
Unity3d脚本从唤醒到销毁有着一套比较完整的生命周期,请列出系统自带的几个重要的方法。
Awake——>
OnEnable–>
Start——>
Update——>
FixedUpdate——>
LateUpdate——>
OnGUI——>
OnDisable——>
OnDestroy
二十一:
物理更新一般放在哪个系统函数里?
FixedUpdate,每固定帧绘制时执行一次,和Update不同的是FixedUpdate是渲染帧执行,如果你的渲染效率低下的时候FixedUpdate调用次数就会跟着下降。
FixedUpdate比较适用于物理引擎的计算,因为是跟每帧渲染有关。
Update就比较适合做控制。
二十二:
在场景中放置多个Camera并同时处于活动状态会发生什么?
游戏界面可以看到很多摄像机的混合。
二十三:
如何销毁一个UnityEngine.Object及其子类?
使用Destroy()方法;
二十四:
请描述为什么Unity3d中会发生在组件上出现数据丢失的情况
一般是组件上绑定的物体对象被删除了
二十五:
LOD是什么,优缺点是什么?
LOD(Level
of
detail)多层次细节,是最常用的游戏优化技术。
它按照模型的位置和重要程度决定物体渲染的资源分配,降低非重要物体的面数和细节度,从而获得高效率的渲染运算。
缺点是增加了内存。
二十六:
MipMap是什么,作用?
MipMapping:
在三维计算机图形的贴图渲染中有常用的技术,为加快渲染进度和减少图像锯齿,贴图被处理成由一系列被预先计算和优化过的图片组成的文件,这样的贴图被称为MipMap。
二十七:
请描述Interface与抽象类之间的不同
抽象类表示该类中可能已经有一些方法的具体定义,但接口就是公公只能定义各个方法的界面,不能具体的实现代码在成员方法中。
类是子类用来继承的,当父类已经有实际功能的方法时该方法在子类中可以不必实现,直接引用父类的方法,子类也可以重写该父类的方法。
实现接口的时候必须要实现接口中所有的方法,不能遗漏任何一个。
二十八:
.Net与Mono的关系?
mono是.net的一个开源跨平台工具,就类似java虚拟机,java本身不是跨平台语言,但运行在虚拟机上就能够实现了跨平台。
.net只能在windows下运行,mono可以实现跨平台跑,可以运行于linux,Unix,MacOS等。
二十九:
简述Unity3D支持的作为脚本的语言的名称
Unity的脚本语言基于Mono的.Net平台上运行,可以使用.NET库,这也为XML、数据库、正则表达式等问题提供了很好的解决方案。
Unity里的脚本都会经过编译,他们的运行速度也很快。
这三种语言实际上的功能和运行速度是一样的,区别主要体现在语言特性上。
JavaScript、C#、Boo
三十:
U3D中用于记录节点空间几何信息的组件名称,及其父类名称
Transform父类是Component
三十一:
向量的点乘、叉乘以及归一化的意义?
1.点乘描述了两个向量的相似程度,结果越大两向量越相似,还可表示投影
2.叉乘得到的向量垂直于原来的两个向量
3.标准化向量:
用在只关系方向,不关心大小的时候
三十二:
为何大家都在移动设备上寻求U3D原生GUI的替代方案
不美观,OnGUI很耗费时间,效率不高,使用不方便
三十三:
请简述如何在不同分辨率下保持UI的一致性
NGUI很好的解决了这一点,屏幕分辨率的自适应性,原理就是计算出屏幕的宽高比跟原来的预设的屏幕分辨率求出一个对比值,然后修改摄像机的size。
UGUI通过锚点和中心点和分辨率也解决这个问题
三十四:
什么是LightMap?
LightMap:
就是指在三维软件里实现打好光,然后渲染把场景各表面的光照输出到贴图上,最后又通过引擎贴到场景上,这样就使物体有了光照的感觉。
三十五:
Unity和cocos2d的区别
1.Unity3D支持C#、javascript等,cocos2d-x支持c++、Html5、Lua等。
2.cocos2d开源并且免费
3.Unity3D支持iOS、Android、Flash、Windows、Mac、Wii等平台的游戏开发,cocos2d-x支持iOS、Android、WP等。
三十六:
C#和C++的区别?
简单的说:
C#
与C++
比较的话,最重要的特性就是C#
是一种完全面向对象的语言,而C++
不是,另外C#
是基于IL
中间语言和.NET
Framework
CLR
的,在可移植性,可维护性和强壮性都比C++
有很大的改进。
的设计目标是用来开发快速稳定可扩展的应用程序,当然也可以通过Interop
和Pinvoke
完成一些底层操作。
更详细的区别大家可以参考这里
三十七:
结构体和类有何区别?
结构体是一种值类型,而类是引用类型。
(值类型、引用类型是根据数据存储的角度来分的)就是值类型用于存储数据的值,引用类型用于存储对实际数据的引用。
那么结构体就是当成值来使用的,类则通过引用来对实际数据操作
三十八:
ref参数和out参数是什么?
有什么区别?
ref和out参数的效果一样,都是通过关键字找到定义在主函数里面的变量的内存地址,并通过方法体内的语法改变它的大小。
不同点就是输出参数必须对参数进行初始化。
ref必须初始化,out参数必须在函数里赋值。
ref参数是引用,out参数为输出参数。
三十九:
C#的委托是什么?
有何用处?
委托类似于一种安全的指针引用,在使用它时是当做类来看待而不是一个方法,相当于对一组方法的列表的引用。
用处:
使用委托使程序员可以将方法引用封装在委托对象内。
然后可以将该委托对象传递给可调用所引用方法的代码,而不必在编译时知道将调用哪个方法。
与C或C++中的函数指针不同,委托是面向对象,而且是类型安全的。
四十:
C#中的排序方式有哪些?
选择排序,冒泡排序,快速排序,插入排序,希尔排序,归并排序
四十一:
射线检测碰撞物的原理是?
射线是3D世界中一个点向一个方向发射的一条无终点的线,在发射轨迹中与其他物体发生碰撞时,它将停止发射
。
四十二:
Unity中,照相机的ClippingPlanes的作用是什么?
调整Near、Fare两个值时,应该注意什么?
剪裁平面
从相机到开始渲染和停止渲染之间的距离。
四十三:
如何让已经存在的GameObject在LoadLevel后不被卸载掉?
voidAwake()
{
DontDestroyOnLoad(transform.gameObject);
}
四十四:
请简述GC(垃圾回收)产生的原因,并描述如何避免?
GC回收堆上的内存
避免:
1.减少new产生对象的次数
2.使用公用的对象(静态成员)
3.将String换为StringBuilder
四十五:
反射的实现原理?
审查元数据并收集关于它的类型信息的能力。
实现原理:
在运行时根据程序集及其中的类型得到元数据。
下面是实现步骤:
1.导入usingSystem.Reflection;
2.Assembly.Load(“程序集”)加载程序集,返回类型是一个Assembly
3.得到程序集中所有类的名称
foreach(Typetypeinassembly.GetTypes())
stringt=type.Name;
4.Typetype=assembly.GetType(“程序集.类名”);
获取当前类的类型
5.Activator.CreateInstance(type);
创建此类型实例
6.MethodInfomInfo=type.GetMethod(“方法名”);
获取当前方法
7.m.Info.Invoke(null,方法参数);
四十六:
简述四元数的作用,四元数对欧拉角的优点?
四元数用于表示旋转
相对欧拉角的优点:
1.能进行增量旋转
2.避免万向锁
3.给定方位的表达方式有两种,互为负(欧拉角有无数种表达方式)
四十七:
移动相机动作在哪个函数里,为什么在这个函数里?
LateUpdate,是在所有的update结束后才调用,比较适合用于命令脚本的执行。
官网上例子是摄像机的跟随,都是所有的update操作完才进行摄像机的跟进,不然就有可能出现摄像机已经推进了,但是视角里还未有角色的空帧出现。
四十八:
GPU的工作原理
简而言之,GPU的图形(处理)流水线完成如下的工作:
(并不一定是按照如下顺序)
顶点处理:
这阶段GPU读取描述3D图形外观的顶点数据并根据顶点数据确定3D图形的形状及位置关系,建立起3D图形的骨架。
在支持DX8和DX9规格的GPU中,这些工作由硬件实现的Vertex
Shader(定点着色器)完成。
光栅化计算:
显示器实际显示的图像是由像素组成的,我们需要将上面生成的图形上的点和线通过一定的算法转换到相应的像素点。
把一个矢量图形转换为一系列像素点的过程就称为光栅化。
例如,一条数学表示的斜线段,最终被转化成阶梯状的连续像素点。
纹理帖图:
顶点单元生成的多边形只构成了3D物体的轮廓,而纹理映射(texture
mapping)工作完成对多变形表面的帖图,通俗的说,就是将多边形的表面贴上相应的图片,从而生成“真实”的图形。
TMU(Texture
mapping
unit)即是用来完成此项工作。
像素处理:
这阶段(在对每个像素进行光栅化处理期间)GPU完成对像素的计算和处理,从而确定每个像素的最终属性。
在支持DX8和DX9规格的GPU中,这些工作由硬件实现的Pixel
Shader(像素着色器)完成。
最终输出:
由ROP(光栅化引擎)最终完成像素的输出,1帧渲染完毕后,被送到显存帧缓冲区。
总结:
GPU的工作通俗的来说就是完成3D图形的生成,将图形映射到相应的像素点上,对每个像素进行计算确定最终颜色并完成输出。
四十九:
什么是渲染管道?
是指在显示器上为了显示出图像而经过的一系列必要操作。
渲染管道中的很多步骤,都要将几何物体从一个坐标系中变换到另一个坐标系中去。
主要步骤有:
本地坐标->
视图坐标->
背面裁剪->
光照->
裁剪->
投影->
视图变换->
光栅化
五十:
如何优化内存?
有很多种方式,例如
1.压缩自带类库;
2.将暂时不用的以后还需要使用的物体隐藏起来而不是直接Destroy掉;
3.释放AssetBundle占用的资源;
4.降低模型的片面数,降低模型的骨骼数量,降低贴图的大小;
5.使用光照贴图,使用多层次细节(LOD),使用着色器(Shader),使用预设(Prefab)。
6.代码中少产生临时变量
五十一:
动态加载资源的方式?
他们之间的区别
1.Resources.Load();
2.AssetBundle
区别参考
五十二:
请描述游戏动画有哪几种,以及其原理?
主要有关节动画、骨骼动画、单一网格模型动画(关键帧动画)。
关节动画:
把角色分成若干独立部分,一个部分对应一个网格模型,部分的动画连接成一个整体的动画,角色比较灵活,Quake2中使用这种动画;
骨骼动画,广泛应用的动画方式,集成了以上两个方式的优点,骨骼按角色特点组成一定的层次结构,有关节相连,可做相对运动,皮肤作为单一网格蒙在骨骼之外,决定角色的外观;
单一网格模型动画由一个完整的网格模型构成,在动画序列的关键帧里记录各个顶点的原位置及其改变量,然后插值运算实现动画效果,角色动画较真实。
五十三:
alpha
blend工作原理
Alpha
Blend
实现透明效果,不过只能针对某块区域进行alpha操作,透明度可设。
五十四:
写出光照计算中的diffuse的计算公式
diffuse
=
Kd
x
colorLight
max(N*L,0);
漫反射系数、colorLight
光的颜色、N
单位法线向量、L
由点指向光源的单位向量、其中N与L点乘,如果结果小于等于0,则漫反射为0。
五十五:
两种阴影判断的方法、工作原理。
本影和半影:
参考本影和半影
本影:
景物表面上那些没有被光源直接照射的区域(全黑的轮廓分明的区域)。
半影:
景物表面上那些被某些特定光源直接照射但并非被所有特定光源直接照射的区域(半明半暗区域)
工作原理:
从光源处向物体的所有可见面投射光线,将这些面投影到场景中得到投影面,再将这些投影面与场景中的其他平面求交得出阴影多边形,保存这些阴影多边形信息,然后再按视点位置对场景进行相应处理得到所要求的视图(利用空间换时间,每次只需依据视点位置进行一次阴影计算即可,省去了一次消隐过程)
五十七:
下列代码在运行中会产生几个临时对象?
stringa=newstring("
abc"
);
a=(a.ToUpper()+"
123"
).Substring(0,2);
在C#中第一行是会报错的(Java中倒是可行)。
应该这样初始化:
stringb=newstring(newchar[]{'
a'
'
b'
c'
});
答案为:
5个临时对象
五十八:
下列代码在运行中会发生什么问题?
如何避免?
List<
int>
ls=newList<
(newint[]{1,2,3,4,5});
foreach(intiteminls)
Console.WriteLine(item*item);
ls.Remove(item);
}
产生运行时错误,在ls.Remove(item)这行,因为foreach是只读的。
不能一边遍历一边修改。
五十九:
Unity3D是否支持写成多线程程序?
如果支持的话需要注意什么?
仅能从主线程中访问Unity3D的组件,对象和Unity3D系统调用
支持:
如果同时你要处理很多事情或者与Unity的对象互动小可以用thread,否则使用coroutine。
注意:
C#中有lock这个关键字,以确保只有一个线程可以在特定时间内访问特定的对象
六十:
Unity3D的协程和C#线程之间的区别是什么?
多线程程序同时运行多个线程,而在任一指定时刻只有一个协程在运行,并且这个正在运行的协同程序只在必要时才被挂起。
除主线程之外的线程无法访问Unity3D的对象、组件、方法。
Unity3d没有多线程的概念,不过unity也给我们提供了StartCoroutine(协同程序)和LoadLevelAsync(异步加载关卡)后台加载场景的方法。
StartCoroutine为什么叫协同程序呢,所谓协同,就是当你在StartCoroutine的函数体里处理一段代码时,利用yield语句等待执行结果,这期间不影响主程序的继续执行,可以协同工作。
六十一:
矩阵相乘的意义及注意点
用于表示线性变换:
旋转、缩放、投影、平移、仿射
注意矩阵的蠕变:
误差的积累
六十三:
当一个细小的高速物体撞向另一个较大的物体时,会出现什么情况?
穿透(碰撞检测失败)
六十四:
请简述OnBecameVisible及OnBecameInvisible的发生时机,以及这一对回调函数的意义?
当物体是否可见切换之时。
可以用于只需要在物体可见时才进行的计算。
六十六:
简述StringBuilder和String的区别?
String是字符串常量。
StringBuffer是字符串变量,线程安全。
StringBuilder是字符串变量,线程不安全。
String类型是个不可变的对象,当每次对String进行改变时都需要生成一个新的String对象,然后将指针指向一个新的对象,如果在一个循环里面,不断的改变一个对象,就要不断的生成新的对象,所以效率很低,建议在不断更改String对象的地方不要使用String类型。
StringBuilder对象在做字符串连接操作时是在原来的字符串上进行修改,改善了性能。
这一点我们平时使用中也许都知道,连接操作频繁的时候,使用StringBuilder对象。
六十七:
Unity3DShader分哪几种,有什么区别?
表面着色器的抽象层次比较高,它可以轻松地以简洁方式实现复杂着色。
表面着色器可同时在前向渲染及延迟渲染模式下正常工作。
顶点片段着色器可以非常灵活地实现需要的效果,但是需要编写更多的代码,并且很难与Unity的渲染管线完美集成。
固定功能管线着色器可以作为前两种着色器的备用选择,当硬件无法运行那些酷炫Shader的时,还可以通过固定功能管线着色器来绘制出一些基本的内容。
六十九:
C#中四种访问修饰符是哪些?
各有什么区别?
1.属性修饰符2.存取修饰符3.类修饰符4.成员修饰符。
属性修饰符:
Serializable:
按值将对象封送到远程服务器。
STATread:
是单线程套间的意思,是一种线程模型。
MATAThread:
是多线程套间的意思,也是一种线程模型。
存取修饰符:
存取不受限制。
只有包含该成员的类可以存取。
只有当前工程可以存取。
只有包含该成员的类以及派生类可以存取。
类修饰符:
abstract:
抽象类。
指示一个类只能作为其它类的基类。
sealed:
密封类。
指示一个类不能被继承。
理所当然,密封类不能同时又是抽象类,因为抽象总是希望被继承的。
成员修饰符:
指示该方法或属性没有实现。
密封方法。
可以防止在派生类中对该方法的override(重载)。
不是类的每个成员方法都可以作为密封方法密封方法,必须对基类的虚方法进行重载,提供具体的实现方法。
所以,在方法的声明中,sealed修饰符总是和override修饰符同时使用。
delegate:
委托。
用来定义一个函数指针。
C#中的事件驱动是基于delegate+event的。
const:
指定该成员的值只读不允许修改。
event:
声明一个事件。
ext