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

Nie działa funkcja w .hpp

42 Warsaw Coding Academy
0 głosów
508 wizyt
pytanie zadane 18 grudnia 2015 w C i C++ przez Piotr Karaś Początkujący (460 p.)

Witam. Robie że tak powiem gre. Mam funkcje mapa która sprawdza pozycje. Jesli ta funkcja jest w main ona normalnie działa, jezeli jest w innym pliku (.hpp) to program kompiluje sie, jednak nie ma tak jakby zmiennych które są w tej funkcji.

 

#include <iostream>
#include <windows.h>
#include <conio.h>
#include <cstdlib>
#include "Funkcje/eq.hpp"
#include "Funkcje/menu.hpp"
#include "Funkcje/mapa.hpp"




using namespace std;



int x=0,y=0;
string rasa;
string nazwapostaci;



int menu();
int eq();


//------SWIAT------//

int mapa(int y,int x,string lokacja,string decyzja_postaci1,string decyzja_postaci2,string decyzja_postaci3,string decyzja_postaci4);

int main()
{

    HANDLE h0ut;
    h0ut = GetStdHandle(STD_OUTPUT_HANDLE );
    SetConsoleTextAttribute(h0ut, FOREGROUND_RED);
    /*------------------------------<<<MENU>>>*/
    menu();

//----------------------------NAZWA-POSTACI-----------------------------//

    system("cls");
    cout <<"Wpisz swoja nazwe postaci:";
    cin >>nazwapostaci;
    system("cls");

//----------------------------RASY---------------------------------//

    cout <<"Wybierz rase:"<<endl;
    cout <<"[1].Czlowiek      [3].Elf"<<endl;
    cout <<"[2].Ogr           [4].Mutant"<<endl;


    switch(getch())
    {
        case '1':
            rasa="Czlowiek";
        break;

        case '2':
            rasa="Ogr";
        break;

        case '3':
            rasa="Elf";
        break;

        case '4':
            rasa="Mutant";
        break;
    }
    system("cls");

//---------------------------------------------WSTEP-----------------------------------//

    cout <<"Witaj w grze "<<nazwapostaci<<" wybrales rase:"<<rasa<<endl;
    cout <<endl;
    cout <<"Na poczatku znajdujesz sie na pozycji (0,0)"<<endl;
    cout <<endl;
    cout <<"Dla komfortu ustaw konsole na wymiary 12x16 oraz czionke rastrowa :)"<<endl;

//-------------------------------------------ROZGRYWKA-------------------------------//

   //-----PORUSZANIE-SIE-I-LOKACJE--------//
    char ruch;
    do{
         mapa(x,y,lokacja,decyzja_postaci1,decyzja_postaci2,decyzja_postaci3,decyzja_postaci4);
        cout <<"Znajdujesz sie na pozycji ("<<x<<","<<y<<")"<<endl;
        cout <<"Twoja lokacja to: "<<lokacja<<endl;
        cout <<"----------RUCH--------------|----DECYZJE-POSTACI--------------------------------";
    cout <<"        [W]Naprzod          | 1."<<decyzja_postaci1<<" 3."<<decyzja_postaci3<<endl;
    cout <<"[A]Lewo [S]Cofnij [D]Prawo  | 2."<<decyzja_postaci2<<" 4."<<decyzja_postaci4<<endl;
    ruch=getch();


    if(ruch=='W'||ruch=='w')
    {
        y++;
    }
    if(ruch=='S'||ruch=='s')
    {
        y--;
    }
    if(ruch =='A'||ruch=='a')
    {
        x--;
    }
    if(ruch =='D'||ruch=='d')
    {
        x++;
    }
    if (ruch == 'E'||ruch=='e')
    {
        eq(rasa,nazwapostaci);
    }
    if (ruch == 27)
    {
        exit (0);
    }




    system("cls");

    }while(true);


    return 0;

}







A tutaj jest mapa.hpp


string lokacja;
string decyzja_postaci1,decyzja_postaci2,decyzja_postaci3,decyzja_postaci4;

int mapa(int y,int x,string lokacja,string decyzja_postaci1,string decyzja_postaci2,string decyzja_postaci3,string decyzja_postaci4)
{


    bool sprawdzenie=false;

    if( x==2&&y==2)
    {
        sprawdzenie=true;
        lokacja="Zamek";
        decyzja_postaci1="Wejdz do zamku";
    }
    if(sprawdzenie==false)
    {
        lokacja="Brak";
        decyzja_postaci1="Brak";
        decyzja_postaci2="Brak";
        decyzja_postaci3="Brak";
        decyzja_postaci4="Brak";
    }
}

 

2 odpowiedzi

+1 głos
odpowiedź 18 grudnia 2015 przez Radfler VIP (101,030 p.)
wybrane 18 grudnia 2015 przez Piotr Karaś
 
Najlepsza

Moment, moment... Skoro te zmienne są globalne (pomijając, że takie zmienne to zło):

string lokacja;
string decyzja_postaci1,decyzja_postaci2,decyzja_postaci3,decyzja_postaci4;

To po co funkcja mapa przyjmuje je jako argumenty? I to jeszcze przez wartość?

#EDIT A tak dokładniej. W tym miejscu:

if( x==2&&y==2)
    {
        sprawdzenie=true;
        lokacja="Zamek";
        decyzja_postaci1="Wejdz do zamku";
    }
    if(sprawdzenie==false)
    {
        lokacja="Brak";
        decyzja_postaci1="Brak";
        decyzja_postaci2="Brak";
        decyzja_postaci3="Brak";
        decyzja_postaci4="Brak";
    }

Dokonujesz przypisania wartości do zmiennych przyjętych jako argument. Po wyjściu z funkcji czas życia tych zmiennych kończy się, czyli po prostu są usuwane. Możesz dodać przed tymi nazwami ::. Jest to odwołanie do nazw globalnych.

komentarz 18 grudnia 2015 przez Piotr Karaś Początkujący (460 p.)
Czyli jak to naprawić :?
komentarz 18 grudnia 2015 przez Radfler VIP (101,030 p.)

Niech funkcja maps nie przyjmuje żadnych argumentów.

komentarz 18 grudnia 2015 przez Piotr Karaś Początkujący (460 p.)
No to wtedy wszystkie zmienne które są w mapa.hpp pokazują błąd ze nie są zadeklarowane :/
komentarz 18 grudnia 2015 przez Piotr Karaś Początkujący (460 p.)
Dobra już ogarnąłem :) Dzięki za pomoc :)
+1 głos
odpowiedź 18 grudnia 2015 przez KamilBest Użytkownik (640 p.)

Pliki o rozszerzeniu .hpp to pliki nagłówkowe w nich trzyma się tylko definicje funkcji.

Zmienne globalne są używane w niektórych sytuacjach, ale w tym wypadku nie jest to konieczne. Funkcje powinny być jak najkrótsze i powinny zawierać jak najmniej argumentów.

Twoja funkcja:

int mapa(int y,int x,string lokacja,string decyzja_postaci1,string decyzja_postaci2,string decyzja_postaci3,string decyzja_postaci4)

zawiera o wiele za dużo argumentów. 

Musisz nauczyć się rozgraniczać co będzie parametrem, a co będzie zwykłą zmienną w funkcji.

+ unikaj powtarzalności kodu, zamiast decyzja_postaci1 ... 4, stwórz tablicę.

komentarz 18 grudnia 2015 przez Piotr Karaś Początkujący (460 p.)
Ok stworze :) Dzieki za rade.

Podobne pytania

0 głosów
1 odpowiedź 512 wizyt
0 głosów
3 odpowiedzi 451 wizyt
pytanie zadane 22 października 2015 w C i C++ przez aspoka Mądrala (5,290 p.)
0 głosów
3 odpowiedzi 1,416 wizyt
pytanie zadane 3 kwietnia 2018 w C i C++ przez MsMaciek123 Pasjonat (24,760 p.)

93,383 zapytań

142,382 odpowiedzi

322,539 komentarzy

62,744 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

VMware Cloud PRO - przenieś swoją infrastrukturę IT do chmury
...