关于Unity的C#基础学习(四)
一、数组
存放同种类型的一组数据,同类+多个
1.定义
int [] int_set;
int_set=new int[10]; //在堆上分配出10个int,int_set是数组的引用变量,指向10个int大小的内存空间。new 类型[容量]
2.访问
数组引用变量名称[索引],int_set[0]=0,int_set[1]=1,int_set[1]=2,访问数组的元素。
数组大小是有限的,所以数组访问千万不能越界,10个元素大小的数组,索引就是0到9,100个元素大小的数组,索引就是0到99。
数组容量一旦确定,就无法再扩展。
索引可以是常量也可以是变量。int_set[index]=5;
3.遍历
访问数组里面的每一个元素
for(int i=0;i<10;i++)
{
int_set[i]=i+1;
Debug.Log(int_set[i]);
}
二、String
1.string.Fromat格式化创建一个字符串
string str=string.Fromat("{0} {1} {2}",“xiaoming”,10,"male");
Debug.Log(str);
群发短信//XXX,祝福你新年快乐
for(int i=0;i<10;i++)
{
string fmr_str="{0}:{1} happy new year";
Debug.Log(string.Format(fmt_str,i,i));
}
2.字符串相等判断
str="Liming";
if(str.Equals("Liming")){
Debug.Log("Equals");
}
3.转换大小写
str.ToUpper();//全部转大写
str.ToLower();//全部转小写
三、static的用法
1.static类的静态方法---不需要实例(与类的实例没有任何关系)就可以调用,格式:类名.函数方法名字,全局唯一。
int age;
public void normal()
{
this.age=0;
}
public static void test()
{
//由于没有对象实例,不能访问对象的数据成员
Debug.Log("Person test");
}
//调用
Person p;
p=new Person();
p.normal();//需要类的实例调用
Person.test();//不需要类的实例直接用类名调用
//用途
用于一些只有逻辑,没有对象的计算,比如我们平时用的Math.sum(),Math.sort(),Math.sin(),Math.cos()等等处理纯粹的逻辑。
2.static类的静态变量(类.变量名称)---不需要实例(与类的实例没有任何关系)就可以调用。格式:类名.变量名字,全局唯一
public static float PI=3.14F;//存放在数据段上,所有的类都共用同一个内存。在编译的时候静态的内存已经释放出来了,永远不会放弃,全局唯一。
//使用
Person.PI=3.14f;
注意:普通的成员函数,成员变量,可以通过this,来访问实例的数据成员。static修饰的静态变量,静态函数是没有this的,并且不能访问实例的数据,因为它的调用压根就和实例无关。
//内存中的存放位置
在数据段中,全局变量,不可被修改
四、const的用法
const修饰的类的成员变量,在编译的时候确定的常量,一旦把一个变量定义为const,你就再也无法修改,全局唯一。格式:类名.变量名
public (static) const int t=3;
Person.t=4;//语句是错误的,不能修改的
Debug.Log(Person.t);//只能去访问,读取
//用途
在写代码逻辑的过程中,需要用一个有意义的名字来代表一个数IDLE , ATTACK , DEAD , WALK 1,2,3,4
//内存中的存放位置
在数据段中,全局变量,不可被修改
五、readonly的用法
实例化时确定的变量,const修饰的类的成员变量,还有一次修改的机会,这个机会在对象的构造函数里面可以使用,后面就再也不能修改。像性别变量sex,一出生就注定的变量,或者是父母变量,一出生就注定的变量。
每一个实例都有一个readonly变量,和前面的static和const不一样。格式:对象引用变量名.变量名
public readonly int t=4;
public Person()
{
this.t=5;
}
六、泛型编程
1.首先指明一个泛型类,这东西其实是一种模板。
class Point<T>{
T xpos;
T ypos;
}
2.实例化泛型类,指明这个泛型到底是哪种类型Point<int>
Point<int> point=new Point<int>();
Point<float> p_float=new Point<float>();
Point<double> p_double=new Point<double>();
3.编译器会使用模板为我们创建相应的类,这个过程是隐示的。
如
class Point<int>{
int xpos;
int ypos;
}
注意:如果数据成员要做成泛型的,类也要做成泛型的。
七、名字空间的使用
在项目开发的过程中,难免会用同样的类名字,所以就要使用名字空间,名字空间带着开发者很强的烙印。
例子:A公司开发了软件的一部分代码,里面有一个类的名字是pay,B公司开发了软件的另外一部分代码,里面也有一个类的名字是pay,
当最后两家开发公司的代码整合后,如果C用户来使用这一软件,发现,调用pay类的时候会出现冲突,不知道要用谁的pay,这就需要使用名字空间来区分两家公司定义的类。
所以,如果是做底层的开发人员,在把自己写的东西SDK,库,给别人的时候要记得加名字空间。
using UnityEngine;就是Unity的名字空间,带着很强的公司烙印。
就像在福建有个人叫李伟,在广东也有一个人叫李伟,在浙江也有一个人叫李伟,我们之所以可以区分他们,是因为他们的地区不同,用省份进行了分区
1.自定义名字空间:
namespace my_namespace{
class Person(){
int xpos;
int ypos;
}
}
2.在外面就算也有一个名为Person的类也没关系,因为两者的名字空间不同。
my_namespace.Person person=new my_namespace.Person();
注意:为了不在每个类前面都写一个名字空间,可以使用using my_namespace;
也就是在开头写:
using my_namespace;//意思就是加入一个搜索范围来查找类或方法,
namespace my_namespace{
class Person(){
int xpos;
int ypos;
}
}
搜索类的定义的过程:
首先会查找当前名字空间也可以理解为当前.cs文件中有没有定义这个类,没有再从第一个using的名字空间范围里开始找起,直到找到处于当前名字空间且与所查找的类的名字相同的类或方法。