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

wcześniej użyty znak nowego wiersza, a funkcja "getline()"

Object Storage Arubacloud
0 głosów
257 wizyt
pytanie zadane 20 września 2016 w C i C++ przez Sidzej Użytkownik (850 p.)

Cześć, robiłem właśnie zadanie 7. z załącznika i natrafiłem na problem. Mianowicie, po podaniu liczby aut do skatalogowania, program przeskakiwał mi opcje podania maki i przechodził od razu do roku produkcji. Było to spowodowane tym, że znak nowego wiersza zostawał w strumieniu wejściowym. Rozwiązałem ten problem, dodając linie "cin.get()" na początku pętli i teraz moje pytanie: czy można się jakoś obejść bez tego "cin.get()" lub zastąpić funkcję "getline()" inną, aby to sprawnie działało?

 

Kod programu:


#include "stdafx.h"
#include <iostream>
#include <conio.h>
#include <string>

using namespace std;
struct car
{
	string brand;
	int yop;


};

int main()
{
	int n, i;
	cout << "how many cars do you want to catalogue? ";
	cin >> n;

	car *tab = new car[n];
	
	for (i = 0; i < n; i++)
	{
		cin.get();

		
		cout << endl << "car " << i + 1 << "." << endl;

		cout << "car brand: ";
		getline(cin, tab[i].brand);

		cout << "year of production: ";
		cin >> tab[i].yop;

		
	}


	for (i = 0; i < n; i++)
	{
		cout << endl << "car " << i + 1 << "." << endl;
		cout << tab[i].brand << endl << tab[i].yop << endl;

		


	}

	delete [] tab;

	_getch();
	return 0;
}

 

2 odpowiedzi

+1 głos
odpowiedź 20 września 2016 przez unknown Nałogowiec (39,560 p.)
wybrane 20 września 2016 przez Sidzej
 
Najlepsza
Metoda clear w tym przypadku nie jest potrzebna. Zamiast metody sync użyj ignore. Czemu? Ponieważ metoda sync nie służy do czyszczenia bufora a takie zachowanie występuje tylko na porcie gcc na Windowsa - MinGW. Na VS czy Linuxie kod z sync po prostu nie zadziała.
komentarz 20 września 2016 przez draghan VIP (106,230 p.)

yes Jeszcze dorzuciłbym coś o wyrzuceniu nieprzenośnego getch().

komentarz 20 września 2016 przez DragonCoder Nałogowiec (36,500 p.)
Dokladnie zamiast getch() cin.get()
komentarz 20 września 2016 przez manjaro Nałogowiec (37,390 p.)

Wiem bo sam używam Linuksa i inaczej czyszczę bufor. Ale W kodzie powyżej widać że użyto bibliotek windowsowych dlatego zaproponowałem sync.

Cytuje ze źródła cpp0x.pl

"Jeśli chcemy mieć większą kontrolę nad strumieniem wejściowym to powinniśmy czyścić jego zawartość przed każdym wczytaniem danych. Aby to zrobić musimy wywołać dwie metody strumienia std::cin. Pierwszą z nich jest std::cin.clear(), która czyści flagi błędu. Drugą metodą jest std::cin.sync(), która czyści bufor strumienia. "

 

komentarz 20 września 2016 przez draghan VIP (106,230 p.)

Polecam opierać się na pewniejszych źródłach.

it is implementation-defined whether this function does anything with library-supplied streams. 

[źródło: http://en.cppreference.com/w/cpp/io/basic_istream/sync]

 

komentarz 20 września 2016 przez unknown Nałogowiec (39,560 p.)

Ale W kodzie powyżej widać że użyto bibliotek windowsowych dlatego zaproponowałem sync.

Czyli według Ciebie pisanie kodu który jest nieprzenośny i zależny od implementacji jest dobre?

komentarz 20 września 2016 przez manjaro Nałogowiec (37,390 p.)
Kod autorski powyżej właśnie taki jest - nieprzenośny. Dlatego zaproponowane rozwiązanie przeze mnie jest jak najbardziej OK.

Jakby nie było kodu to bym podał inne. Nie rozumiem tego bicia piany, skoro moje rozwiązanie jest prawidłowe i autorowi rozwiązuje problem.
komentarz 20 września 2016 przez unknown Nałogowiec (39,560 p.)

Nie rozumiem tego bicia piany, skoro moje rozwiązanie jest prawidłowe i autorowi rozwiązuje problem.

Skąd wiesz? Autor używa chyba VS, więc raczej nie.

komentarz 20 września 2016 przez manjaro Nałogowiec (37,390 p.)

 Autor używa chyba VS,

Masz szklaną kulę?

Już widzę jak ktoś kto uczy się programowania inwestuje w płatne VS.

komentarz 20 września 2016 przez unknown Nałogowiec (39,560 p.)

Już widzę jak ktoś kto uczy się programowania inwestuje w płatne VS.

Eee, VS jest darmowe.

Masz szklaną kulę?

Nie, ale używa stdafx.

komentarz 20 września 2016 przez Sidzej Użytkownik (850 p.)

Autor używa chyba VS

Tak, używam VS Community 2015. Z tego co zrozumiałem, nie powinienem używać funkcji getch(), bo nie wszędzie będzie to działało i z tego samego powodu powinienem też użyć cin.ignore(), tak?

komentarz 20 września 2016 przez DragonCoder Nałogowiec (36,500 p.)
Tak, getch jest w conio.h a biblioteki z .h sa dla windowsa, dlatego tez ja w swoich projektach stosuje biblioteki wieloplatformowe i ty tez tak zrob. Zamiast math.h uzyj cmath ctime itd...A zamiast Sleep(); uzyj tego: _sleep() bo dziala na kazdy system a jak uzylem Sleep to cos nie chcialo zadzialac
komentarz 20 września 2016 przez unknown Nałogowiec (39,560 p.)

biblioteki z .h sa dla windowsa

Nie, tak się dołącza biblioteki napisane w C

A zamiast Sleep(); uzyj tego: _sleep() bo dziala na kazdy system a jak uzylem Sleep to cos nie chcialo zadzialac

Nie nie zadziała. Powinien użyć this_thread::sleep_for: http://www.cplusplus.com/reference/thread/this_thread/sleep_for/

komentarz 20 września 2016 przez Sidzej Użytkownik (850 p.)
Dzięki za rade. Tylko mam kolejny problem, bo żeby cin.get() działało tak jak getch(), tzn żeby program kończył swoją pracę dopiero po naciśnięciu klawisza muszę przed tym wstawić  to cin.ignore(). Nie da się tego jakoś obejść?
komentarz 20 września 2016 przez unknown Nałogowiec (39,560 p.)
Tak, nie używaj strumienia wejścia. Jedyny sposób.
komentarz 20 września 2016 przez Sidzej Użytkownik (850 p.)
Rozumiem. Dzięki za pomoc.
–1 głos
odpowiedź 20 września 2016 przez manjaro Nałogowiec (37,390 p.)

Wrzuć to przed getline

cin.clear();
cin.sync();

 

Podobne pytania

0 głosów
1 odpowiedź 179 wizyt
pytanie zadane 26 sierpnia 2019 w C i C++ przez amtrax Dyskutant (9,630 p.)
0 głosów
1 odpowiedź 560 wizyt
0 głosów
4 odpowiedzi 1,390 wizyt
pytanie zadane 5 grudnia 2016 w C i C++ przez Hvosz Początkujący (410 p.)

92,596 zapytań

141,446 odpowiedzi

319,722 komentarzy

61,981 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.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...