• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Czemu ten kod zawiesza program?

0 głosów
611 wizyt
pytanie zadane 27 czerwca 2022 w C i C++ przez MichaelM Gaduła (3,000 p.)

Witam, napisałem program. Program działa do czasu, gdy nie zdejmę komentarza z części

	     		int dlugosci = GetWindowTextLength(NazwaPliku);
				LPSTR nazwa = (LPSTR)GlobalAlloc(GPTR, dlugosci + 1);
				GetWindowText(NazwaPliku, nazwa, dlugosci + 1);
				
	     		ifstream plik;
				plik.open(nazwa);
				string calosc, linia;
				while(!plik.eof())
				{
					getline(plik, linia);
					calosc += linia+'\n';
				}
				string tekst = calosc;
				int n = tekst.length();
				char * lista = new char[n+1];
				strcpy(lista, tekst.c_str());
				znak = lista[i];
				while(znak!="x") 
				{
					widths = widths + lista[i];
					i = i+1;
				}
				i = i+1;
				while(znak!="z") 
				{
					heights = heights + lista[i];
					i = i+1;
				}
				i = i + 1;
				width = atoi(widths.c_str());
				height = atoi(heights.c_str());

Część z problemowym kodem:

		case WM_COMMAND:
		{
			if(( HWND ) lParam == Wczytywanie )
	     	{
	     		int dlugosci = GetWindowTextLength(NazwaPliku);
				LPSTR nazwa = (LPSTR)GlobalAlloc(GPTR, dlugosci + 1);
				GetWindowText(NazwaPliku, nazwa, dlugosci + 1);
				
	     		ifstream plik;
				plik.open(nazwa);
				string calosc, linia;
				while(!plik.eof())
				{
					getline(plik, linia);
					calosc += linia+'\n';
				}
				string tekst = calosc;
				int n = tekst.length();
				char * lista = new char[n+1];
				strcpy(lista, tekst.c_str());
				znak = lista[i];
				while(znak!="x") 
				{
					widths = widths + lista[i];
					i = i+1;
				}
				i = i+1;
				while(znak!="z") 
				{
					heights = heights + lista[i];
					i = i+1;
				}
				i = i + 1;
				width = atoi(widths.c_str());
				height = atoi(heights.c_str());
				kliknieto = 1;
			    UpdateWindow(hwnd);

 

1 odpowiedź

+1 głos
odpowiedź 27 czerwca 2022 przez adrian17 Mentor (354,880 p.)
edycja 27 czerwca 2022 przez adrian17
                znak = lista[i];
                while(znak!="x") 

Bo masz tu nieskończoną pętlę.

Co to w ogóle ma robić? Strasznie dziwnie ten kod wygląda i trudno powiedzieć jaki jest jego cel.

(btw nigdzie też nie widać gdzie w ogóle deklarujesz i ustawiasz jakąś wartość dla `i`  i innych zmiennych, czemu `i` nie jest tutaj lokalne?)

Ostatnio też Ci mówiliśmy że nie musisz robić tego dziwnego kopiowania stringa z strcpy https://forum.pasja-informatyki.pl/568400/konwersja-string-na-liste , więc nie wiem czemu wciąż uparcie próbujesz to robić.

komentarz 27 czerwca 2022 przez krystianfr Nowicjusz (240 p.)

Nawet 2 nieskończone pętle:

while(znak!="x") 
{
    widths = widths + lista[i];
    i = i+1;
}
i = i+1;
while(znak!="z") 
{
    heights = heights + lista[i];
    i = i+1;
}

Ale bez opisu i całości kody trudno stwierdzić jak to naprawić .

komentarz 27 czerwca 2022 przez adrian17 Mentor (354,880 p.)
(... w sumie to mam wątpliwości czy to się w ogóle kompiluje? Bo `znak!="x"` to jest porównanie chara do literału stringowego, co się nie skompiluje przecież.)
komentarz 27 czerwca 2022 przez krystianfr Nowicjusz (240 p.)
Z tego co widzę w kodzie który dołączył kolegą nie ma definicji zmiennej znak więc możliwe że jest to poprawne jeśli kod mu się skompilował bez błędów.
komentarz 28 czerwca 2022 przez MichaelM Gaduła (3,000 p.)
zmienna znak jest globalna, dołąćzyłem tylko część case z kodu

Podobne pytania

0 głosów
0 odpowiedzi 203 wizyt
+1 głos
2 odpowiedzi 814 wizyt
+2 głosów
3 odpowiedzi 5,522 wizyt

93,695 zapytań

142,612 odpowiedzi

323,223 komentarzy

63,223 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

Twierdza Linux. Bezpieczeństwo dla dociekliwych

Aby uzyskać rabat -10%, użyjcie kodu pasja-linux, wpisując go w specjalne pole w koszyku.

...