Вопросы

Было всё в порядке но потом обратил внимание на это в логах,предположительно началось после того как создал транспорт на продажу.

Очень надеюсь на вашу помощь 

[09:45:10] [debug] Run time error 4: "Array index out of bounds"
[09:45:10] [debug]  Attempted to read/write array element at index 65535 in array of size 1000
[09:45:10] [debug] AMX backtrace:
[09:45:10] [debug] #0 006b01c0 in J_AddStaticVehicleEx (model=904, Float:x=56.22650, Float:y=1002.40002, Float:z=11.51420, Float:a=183.88000, color_1=0, color_2=0, spawntime=60000, interior=0, world=0) at C:\Users\123123\Downloads\ffff\ffff\gamemodes\ffff.pwn:56143
[09:45:10] [debug] #1 00431878 in public fo_OnGameModeInit () at C:\Users\123123\Downloads\ffff\ffff\gamemodes\ffff.pwn:10045
[09:45:10] [debug] #2 00009800 in public SSCANF_OnGameModeInit () at C:\Users\123123\Downloads\ffff\ffff\pawno\include\fixobject.inc:266
[09:45:10] [debug] #3 000035f8 in public OnGameModeInit () at C:\Users\123123\Downloads\ffff\ffff\pawno\include\sscanf2.inc:205
[09:45:10] _____________________________________________________________________
[09:45:10]  QQQQWWWWWQQQ X
[09:45:10] (vk.com/m22vtw) © 2018 (FFFF FFFFF)
[09:45:10] _____________________________________________________________________
[09:45:10] Number of vehicle models: 11

#0 006b01c0 in J_AddStaticVehicleEx

J_AddStaticVehicleEx(model,Float:x,Float:y,Float:z,Float:a,color_1,color_2,spawntime = 300,interior = 0,world = 0)
{
	new carid = AddStaticVehicleEx(model, x, y, z, a, color_1, color_2, spawntime);
	VehicleInfo[carid][vAntiRepair]=2;
	VehicleInfo[carid][vLock]=0;
	//VehicleHealth[carid] = 1000;
	VehicleInfo[carid][vModel] = model;
	VehicleInfo[carid][vPos_X] = x;
	VehicleInfo[carid][vPos_Y] = y;
	VehicleInfo[carid][vPos_Z] = z;
	VehicleInfo[carid][vPos_A] = a;
	VehicleInfo[carid][vColor_1] = color_1;
	VehicleInfo[carid][vColor_2] = color_2;
	VehicleInfo[carid][vSpawnTime] = spawntime;
	LinkVehicleToInterior(carid, interior);
	SetVehicleVirtualWorld(carid, world);
	VehicleInfo[carid][vTuning] = GetVehicleTuningState( model );
	switch(model)
	{
	case 430, 446, 452, 453, 454, 472, 473, 484, 493: VehicleState[carid] = VEHICLE_STATE_BOAT;
	case 417, 425, 447, 460, 469, 476, 487, 488, 497, 511, 512, 513, 519, 520, 548, 553,
		563, 577, 592, 593:  VehicleState[carid] = VEHICLE_STATE_PLANE;
	case 581, 522, 461, 521, 523, 463, 468, 471, 586: VehicleState[carid] = VEHICLE_STATE_BIKE;
	case 509, 481, 510: VehicleState[carid] = VEHICLE_STATE_VELIK;
	case 462,448: VehicleState[carid] = VEHICLE_STATE_MOPED;
	case 538, 537: VehicleState[carid] = VEHICLE_STATE_TRAIN;
	default: VehicleState[carid] = VEHICLE_STATE_CAR;
	}
	return carid;
}

#1 00431878 in public fo_OnGameModeInit

	//Загрузка автомобилей
	for(new i = 0;i < OWNABLECARS;i ++)
	{
		OwnableCar[i] = J_AddStaticVehicleEx(CarInfo[i][cModel],CarInfo[i][cPos_X],CarInfo[i][cPos_Y],CarInfo[i][cPos_Z],CarInfo[i][cPos_A],CarInfo[i][cColor_1],CarInfo[i][cColor_2],60000);
		CarText[i] = CreateDynamic3DTextLabel("-",-1,0,0,0.5,5.0,INVALID_PLAYER_ID,OwnableCar[i]);
		ReSetCarPrice(i);
		new number = OwnableCar[i];
		new virt = CarInfo[i][cVirt];
		if(!GetString(CarInfo[i][cOwner],"The State")) SetVehicleVirtualWorld(number, virt);

	}
	

 

Отредактировано пользователем edikzver
Причина: Дополнил

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

8 ответов на этот вопрос

  • 0

Вообщем я не знаю что это было но факт в том что оно само прошло :dance::dance::beer2:

Не знаю с чем это связано,но единственное что я сделал,это отключил crashdetect,запустил сервер,потом по новой подключил crashdetect и флуда нет ,я не знаю как это воспринимать O.o,

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
  • 0

@edikzver, ты пытался создать транспорт с моделью 904. Такой в SA и CR не существует. Поэтому транспорт не был создан и в carid записалось значение INVALID_VEHICLE_ID (= 65535). Далее система искала эту ячейку в массиве, но не нашла, ведь VehicleInfo размером с 1000, что меньше, чем 65535. Получается и выход за пределы массива. Достаточно добавить проверку на то, верна ли модель транспорта:

Спойлер

 


J_AddStaticVehicleEx(model,Float:x,Float:y,Float:z,Float:a,color_1,color_2,spawntime = 300,interior = 0,world = 0)
{
	if(model < 400 || model > 611)
		return INVALID_VEHICLE_ID;
	
	new carid = AddStaticVehicleEx(model, x, y, z, a, color_1, color_2, spawntime);
	VehicleInfo[carid][vAntiRepair]=2;
	VehicleInfo[carid][vLock]=0;
	//VehicleHealth[carid] = 1000;
	VehicleInfo[carid][vModel] = model;
	VehicleInfo[carid][vPos_X] = x;
	VehicleInfo[carid][vPos_Y] = y;
	VehicleInfo[carid][vPos_Z] = z;
	VehicleInfo[carid][vPos_A] = a;
	VehicleInfo[carid][vColor_1] = color_1;
	VehicleInfo[carid][vColor_2] = color_2;
	VehicleInfo[carid][vSpawnTime] = spawntime;
	LinkVehicleToInterior(carid, interior);
	SetVehicleVirtualWorld(carid, world);
	VehicleInfo[carid][vTuning] = GetVehicleTuningState( model );
	switch(model)
	{
		case 430, 446, 452, 453, 454, 472, 473, 484, 493: VehicleState[carid] = VEHICLE_STATE_BOAT;
		case 417, 425, 447, 460, 469, 476, 487, 488, 497, 511, 512, 513, 519, 520, 548, 553,
			563, 577, 592, 593:  VehicleState[carid] = VEHICLE_STATE_PLANE;
		case 581, 522, 461, 521, 523, 463, 468, 471, 586: VehicleState[carid] = VEHICLE_STATE_BIKE;
		case 509, 481, 510: VehicleState[carid] = VEHICLE_STATE_VELIK;
		case 462,448: VehicleState[carid] = VEHICLE_STATE_MOPED;
		case 538, 537: VehicleState[carid] = VEHICLE_STATE_TRAIN;
		default: VehicleState[carid] = VEHICLE_STATE_CAR;
	}
	return carid;
}

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
  • 0

@TalexУ вы не успел проверить :)  теперь это хотя я ничего не создавал даже бд от транспорта и теперь это ..

[13:12:27] [debug] Run time error 4: "Array index out of bounds"
[13:12:27] [debug]  Attempted to read/write array element at negative index -1
[13:12:27] [debug] AMX backtrace:
[13:12:27] [debug] #0 004e5610 in IsAOwnableCar (carid=781) at C:\Users\123123\Downloads\fffff\fffff\gamemodes\fffff.pwn:15812
[13:12:27] [debug] #1 004dffdc in public OnVehicleSpawn (vehicleid=781) at C:\Users\123123\Downloadys\fffff\fffff\fffff\fffff.pwn:15355
[13:12:27] [debug] #2 native SetVehicleToRespawn () from samp-server-cr.exe
[13:12:27] [debug] #3 004b43d8 in public fo_OnGameModeInit () at C:\Users\123123\Downloads\fffff\fffff\gamemodes\fffff.pwn:11979
[13:12:27] [debug] #4 00009800 in public SSCANF_OnGameModeInit () at C:\Users\123123\Downloads\fffff\fffff\pawno\include\fffff.inc:266
[13:12:27] [debug] #5 000035f8 in public OnGameModeInit () at C:\Users\123123\Downloads\fffff\fffffpawno\include\sscanf2.inc:205

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
  • 0

@edikzver, покажи, где вызывается эта функция при старте сервера.

Отредактировано пользователем Talex

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
  • 0

@Talex Какая именно?9_9

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
  • 0

@edikzverJ_AddStaticVehicleEx. 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
  • 0

@Talex 

	for(new i = 0;i < OWNABLECARS;i ++)
	{
		OwnableCar[i] = J_AddStaticVehicleEx(CarInfo[i][cModel],CarInfo[i][cPos_X],CarInfo[i][cPos_Y],CarInfo[i][cPos_Z],CarInfo[i][cPos_A],CarInfo[i][cColor_1],CarInfo[i][cColor_2],60000);
		CarText[i] = CreateDynamic3DTextLabel("-",-1,0,0,0.5,5.0,INVALID_PLAYER_ID,OwnableCar[i]);
		ReSetCarPrice(i);
		new number = OwnableCar[i];
		new virt = CarInfo[i][cVirt];
		if(!GetString(CarInfo[i][cOwner],"The State")) SetVehicleVirtualWorld(number, virt);

	}

Вот ещё с его участием нашел  (странное значение olor_1],CarInfo[vehid][cColor_1],100000);)

for(new vehid;vehid < OWNABLECARS;vehid++)
	{
		if(!GetString(CarInfo[vehid][cOwner],"The State"))
		{
		    if(GetDistance(CarInfo[vehid][cPos_X],CarInfo[vehid][cPos_Y],CarInfo[vehid][cPos_Z],2368.9749,2436.7090,5018.39) > 200)
		    {
				if(CarInfo[vehid][cShtraf]==0) CarInfo[vehid][cShtrafer] += GLS[1];
				else CarInfo[vehid][cShtraf] += GLS[1]*2;
			}
			if(CarInfo[vehid][cShtraf]>120000 || CarInfo[vehid][cShtrafer]>60000)
			{
				CarInfo[vehid][cPos_X] = CarInfo[vehid][cSell_X];
				CarInfo[vehid][cPos_Y] = CarInfo[vehid][cSell_Y];
				CarInfo[vehid][cPos_Z] = CarInfo[vehid][cSell_Z];
				CarInfo[vehid][cPos_A] = CarInfo[vehid][cSell_A];
				CarInfo[vehid][cColor_1] = 1;
				CarInfo[vehid][cColor_2] = 1;
                CarInfo[vehid][cVirt] = 0;
				new bool:qu = true,str[254];
				foreach(p)
				{
					if(!strcmp(CarInfo[vehid][cOwner],PN(p),true))
					{
						if(IsPlayerLogged[p])
						{
							SendClientMessage(p,COLOR_BLUE,"За неоплату счетов у вас отобрали личный автомобиль!");
							GiveMoney(p,CarInfo[vehid][cCost]);
							qu = false;
							break;
						}
					}
				}
				if(qu)
				{
					format(str, sizeof(str), "UPDATE `usrboston` SET `Money`=`Money`+'%d' WHERE `NickName` = '%s'; ",CarInfo[vehid][cCost], CarInfo[vehid][cOwner]);
					mysql_tquery(mysql, str);
				}
				//aml(51, -1, CarInfo[vehid][cOwner], "отобрали машину за неуплату налогов", CarInfo[vehid][cCost]);
				SetString(CarInfo[vehid][cOwner], "The State");
				SetString(CarInfo[vehid][cKeyer], "The State");
				CarInfo[vehid][cShtrafer] = 0;

				CarInfo[vehid][cNumberColor] = 0;
				SetString(CarInfo[vehid][cNumber],"SA");
				SetString(CarInfo[vehid][cOnNumber],"The State");
				SetString(CarInfo[vehid][cOnRegister],"The State");
				SetString(CarInfo[vehid][cRegister],"The State");
				ReSetCarPrice(vehid);
				CarInfo[vehid][cLock] = 0;
				CarInfo[vehid][cShtraf] = 0;
				CarInfo[vehid][cKeyIN] = 0;
				CarInfo[vehid][cAlarmON] = 0;
				CarInfo[vehid][cMilage] = 0;
				CarInfo[vehid][cVirt] = 0;
			//	CarInfo[vehid][cInt] = 0;
				DestroyVehicleEx(OwnableCar[vehid]);
				J_AddStaticVehicleEx(CarInfo[vehid][cModel],CarInfo[vehid][cPos_X],CarInfo[vehid][cPos_Y],CarInfo[vehid][cPos_Z],CarInfo[vehid][cPos_A],CarInfo[vehid][cColor_1],CarInfo[vehid][cColor_1],100000);
				//SetVehicleNumberPlate(vehid,"SA");
				VehicleInfo[OwnableCar[vehid]][vAntiRepair]=2;
				VehicleHealth[OwnableCar[vehid]] = 1000;
				DelTunCar(OwnableCar[vehid]);
				SetVehicleToRespawn(OwnableCar[vehid]);
				SetVehicleVirtualWorld(OwnableCar[vehid],CarInfo[vehid][cVirt]);
			//	LinkVehicleToInterior(OwnableCar[vehid],CarInfo[vehid][cVirt]);
				SaveOwnableCar(vehid);
				format(string,sizeof(string),"< Штраф Стоянка > Машина %d была продана в гос.",vehid);
				SendAdminsMessage(COLOR_RED,string,1);
			}
		}
		SaveOwnableCar(vehid);
	}
	return true;

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
  • 0

Ничего там не прошло. Crashdetect Вам показал, что есть ситуация, когда происходит выход за пределы массива. Рано или поздно эта ситуация повториться. Не хватает проверки на валидность... В принципе, это не столь страшно и его вообще можно отключить.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
Гость
Эта тема закрыта для публикации ответов.

  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Похожий контент

    • Mister Odin
      От Mister Odin
       
      new
       g_teleport_list[39][E_TELEPORT_LIST] = {  {"Спавн пгт.Батырево", 1802.3612, 2508.4824, 15.8887},  {"Спавн г.Арзамас", -113.5887, 977.7222, 12.0346},     {"Спавн г.Южный", 2744.2770, -2446.7246, 21.8988},     {"Центральный банк", 1852.020385,2040.791381,15.892713},  {"Рублёвка", -837.7783, 888.6161, 12.7232},  {"Казино", 1332.4252, 2358.7014, 17.6641},  {"Битва за контейнеры", 614.5167, 1722.3566, 12.0709},  {"Автосалон низкого класса", 2493.9616, -722.9544, 12.3315},  {"Автосалон среднего класса", 1407.7449, 455.4801, 13.1630},  {"Автосалон высокого класса", -14.0637, 2614.5664, 10.9892},   {"Мотосалон Harley Davidson", 785.720153, 750.465087, 12.000024},  {"Автошкола", 1909.174438,2227.679687,15.708162},  {"Военкомат", 1916.778564,2302.411376,15.574637},  {"Правительство области", -139.140975,593.789611,12.145712},  {"Отдел полиции №1 (ГИБДД)", 1906.805786,-2234.382812,11.257631},  {"Отдел полиции №2 (УМВД)", 2581.309326,-2416.139892,21.960090},  {"Отдел ФСБ", 1823.904663,2095.636718,15.848405},  {"Городская больница г.Арзамас", -285.797210,581.851562,12.120290},   {"СМИ", -317.708038,821.221679,13.051450},  {"Воинская часть", 1703.197265,1678.025878,15.279437},  {"Арзамасская ОПГ", 438.705322,1046.505126,12.002637},  {"Батыревская ОПГ", 1941.203857,2161.006591,15.705187},  {"Лыткаринская ОПГ", -2346.002441,75.257041,21.002962},  {"Шахта", 2381.5727, 1726.4451, -2.1506},  {"Завод", -1062.6697, 2204.1894, 38.0964},  {"Инкосация", 1864.1374, 2011.7136, 15.8546},  {"Транспортная Компания", 2362.1115, 1972.5627, 15.5530},  {"База механиков", 1840.918090,-118.025146,15.695312},  {"Курьерская служба доставки", 2764.509765,-2396.882568,21.890625},  {"Аренда автобуса(Южный)", 2771.041992,-2454.780761,21.845964},  {"Аренда автобуса(Арзамас)", -127.487670,943.652648,12.142824},   {"Аренда автобуса(Батырево)", 1798.986328,2529.591552,15.664262},  {"Гоночная трасса", -1568.7784, 1611.8305, 36.3971},  {"Дом на горе", -789.5397, -456.7479, 741.1422},  {"СТО и тюнинг-ателье", 1856.1375, -122.3266, 15.6888},  {"Аренда транспорта пгт.Батырево", 1763.641723,2255.673339,15.865348},  {"Аренда транспорта г.Арзамас", -36.923530,1360.673583,12.002090},  {"Аренда транспорта г.Южный", 1966.599975,-2603.943603,10.820312},  {"Тайный интерьер в Лыткарино", -2424.5818, 2846.3291, 40.7908} };