我当需要固定块上有点混乱。 我有例子,给了我以下矛盾的情形:
enum RoomType { Economy, Buisness, Executive, Deluxe };
struct HotelRoom
{
public int Number;
public bool Taken;
public RoomType Category;
public void Print()
{
String status = Taken ? "Occupied" : "available";
Console.WriteLine("Room {0} is of {1} class and is currently {2}", Number, Category, status);
}
}
我做了这将需要一个指向一个函数HotelRoom
private unsafe static void Reserve(HotelRoom* room)
{
if (room->Taken)
Console.WriteLine("Cannot reserve room {0}", room->Number);
else
room->Taken = true;
}
在main方法我有以下几点:
unsafe static void Main(string[] args)
{
HotelRoom[] myfloor = new HotelRoom[4];
for (int i = 0; i < myfloor.Length; i++)
{
myfloor[i].Number = 501 + i;
myfloor[i].Taken = false;
myfloor[i].Category = (RoomType)i;
}
HotelRoom Room = myfloor[1];
Reserve(&Room); //I am able to do this without fixed block.
//Reserve(&myfloor[1]); //Not able to do this so have to use fixed block below.
fixed (HotelRoom* pRoom = &myfloor[1])
{
Reserve(pRoom);
}
myfloor[1].Print();
Room.Print();
}
我的困惑是,我能够做到Reserve(&Room)
,但没有Reserve(&myfloor[1])
我认为他们正在做同样的事情-传递的memeory地址HotelRoom
结构的Reserve
功能。 为什么需要fixed
做到这一点?