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

question-closed Visual studio program składający się z trzech plików

Object Storage Arubacloud
0 głosów
412 wizyt
pytanie zadane 29 września 2016 w C i C++ przez Kasztan Dyskutant (8,080 p.)
zamknięte 30 września 2016 przez Kasztan

Otóż mam taki program składający się z trzech plików

Nagłówek:

#ifndef Bamboo_h
#define Bamboo_h

namespace SALES
{
	const int QUARTERS = 4;
	struct Sales
	{
		double sales[QUARTERS];
		double average;
		double max;
		double min;

	};

	void setSales(Sales &s, const double ar[], int n);
	void setSales(Sales &s);
	void showSales(const Sales &s);
}

#endif // !Bamboo

Pierwszy plik

#include "stdafx.h"
#include "Header4.h"
#include <iostream>



int main()
{
	using namespace std;
	using namespace SALES;

	Sales s;
	const double tablica[4] = { 1.2,3.2,5.5,0.1 };
	setSales(s, tablica[], 4);
	showSales(s);
	setSales(s);
	showSales(s);
	

    return 0;
}

drugi plik

#include "stdafx.h"
#include "Header4.h"
#include <iostream>


void setSales(Sales &s, const double ar[], int n)
{	
	using namespace SALES;
	using namespace std;
	double srednia = 0;
	for (int i = 0; i < n; i++)
	{
		s.sales[i] = ar[i];
		srednia += ar[i];
	}
	s.average = (srednia/n);
	double najwieksza = ar[0];
	for (int i = 0; i < n; i++)
	{
		if (najwieksza < ar[i])
		{
			najwieksza = ar[i];
		}
	}
	s.max = najwieksza;
	double najmniejsza = ar[0];
	for (int i = 0; i < n; i++)
	{
		if (najmniejsza > ar[i])
		{
			najmniejsza = ar[i];
		}
	}
	s.min = najmniejsza;
	//zerowanie danych w tablicy;
	for (int i = 0; i < n; i++)
	{
		if (ar[i] != najwieksza || ar[i] != najmniejsza)
		{
			ar[i] = 0;
		}
	}
}

void setSales(Sales &s)
{	
	using namespace SALES;
	using namespace std;
	double srednia = 0;
	for (int i = 0; i < 4; i++)
	{
		cout << "Wpiesz wartosc numer: " << i << endl;
		cin >> s.sales[i];
		srednia += s.sales[i];

	}
	s.average = (srednia / 4);
	double najwieksza = s.sales[0];
	for (int i = 0; i < 4; i++)
	{
		if (najwieksza < s.sales[i])
		{
			najwieksza = s.sales[i];
		}
	}
	s.max = najwieksza;
	double najmniejsza = s.sales[0];
	for (int i = 0; i < 4; i++)
	{
		if (najmniejsza > s.sales[i])
		{
			najmniejsza = s.sales[i];
		}
	}
	s.min = najmniejsza;
	//zerowanie danych w tablicy;
	for (int i = 0; i < 4; i++)
	{
		if (s.sales[i] != najwieksza || s.sales[i] != najmniejsza)
		{
			s.sales[i] = 0;
		}
	}

}

void showSales(const Sales &s)
{	
	using namespace SALES;
	using namespace std;
	cout << s.average << endl;
	cout << s.max << endl;
	cout << s.min << end;

}

I teraz moje pytanie czy nagłówek jest dobrze napisany chodzi mi czy do tworzenia przestrzeni nazw używa się infdef i define

Następnie mam wrażenie, że ten drugi plik wgl nie jest odnajdowany przez pierwszy(definicje funkcji nie widnieją w funkcji main)

W pliku wygląda to tak

oraz tak od strony IDE

komentarz zamknięcia: Uzyskałem odpowiedź

2 odpowiedzi

0 głosów
odpowiedź 30 września 2016 przez Kasztan Dyskutant (8,080 p.)
wybrane 30 września 2016 przez Kasztan
 
Najlepsza
Odniosłem się do wszystkich powyższych rad, które były trafne jednak nadal mam problem żeby uruchomić ten program.

Severity    Code    Description    Project    File    Line    Suppression State
Error    LNK2019    unresolved external symbol "void __cdecl SALES::showSales(struct SALES::Sales const &)" (?showSales@SALES@@YAXABUSales@1@@Z) referenced in function 4

Severity    Code    Description    Project    File    Line    Suppression State
Error    LNK1120    3 unresolved externals    4
1
komentarz 30 września 2016 przez criss Mędrzec (172,590 p.)
Przed wszystkim co zostało zadeklarowane w namespace musisz dodawać operator zasięgu. Tutaj chodzi o typ SALES::Sales (w definicji masz samo Sales). Powtarzam - najprościej będzie jak wszystko w pliku cpp gdzie definiujesz te funkcje zamkniesz w klamrach namespace SALES { }
komentarz 30 września 2016 przez Kasztan Dyskutant (8,080 p.)
No ale dalej to nie pomaga
0 głosów
odpowiedź 29 września 2016 przez criss Mędrzec (172,590 p.)

1. Tak, dobrze.

2.  

(definicje funkcji nie widnieją w funkcji main)

Nie mam pojęcia o co ci chodzi. Jak to "masz wrażenie"? Tzn. co się dzieje? 

komentarz 29 września 2016 przez Kasztan Dyskutant (8,080 p.)
tak jak pisałem zrobiłem
komentarz 29 września 2016 przez Pascal Bywalec (2,720 p.)
pokaż kod po tych zmianach tylko błagam nie jako screen...
komentarz 29 września 2016 przez Kasztan Dyskutant (8,080 p.)
#ifndef Bamboo_h
#define Bamboo_h

namespace SALES
{
	const int QUARTERS = 4;
	struct Sales
	{
		double sales[QUARTERS];
		double average;
		double max;
		double min;

	};

	void setSales(Sales &s, const double ar[], int n);
	void setSales(Sales &s);
	void showSales(const Sales &s);
}

#endif // !Bamboo

#include "stdafx.h"
#include "Header4.h"
#include <iostream>



int main()
{
	using namespace std;
	using namespace SALES;

	Sales s;
	const double tablica[4] = { 1.2,3.2,5.5,0.1 };
	setSales(s, tablica[], 4);
	showSales(s);
	setSales(s);
	showSales(s);
	

    return 0;
}

#include "stdafx.h"
#include "Header4.h"
#include <iostream>


void Sales::setSales(Sales &s, const double ar[], int n)
{	
	
	using namespace SALES;
	using namespace std;
	double srednia = 0;
	for (int i = 0; i < n; i++)
	{
		s.sales[i] = ar[i];
		srednia += ar[i];
	}
	s.average = (srednia/n);
	double najwieksza = ar[0];
	for (int i = 0; i < n; i++)
	{
		if (najwieksza < ar[i])
		{
			najwieksza = ar[i];
		}
	}
	s.max = najwieksza;
	double najmniejsza = ar[0];
	for (int i = 0; i < n; i++)
	{
		if (najmniejsza > ar[i])
		{
			najmniejsza = ar[i];
		}
	}
	s.min = najmniejsza;
	//zerowanie danych w tablicy;
	for (int i = 0; i < n; i++)
	{
		if (ar[i] != najwieksza || ar[i] != najmniejsza)
		{
			ar[i] = 0;
		}
	}
}

void Sales::setSales(Sales &s)
{	
	using namespace SALES;
	using namespace std;
	double srednia = 0;
	for (int i = 0; i < 4; i++)
	{
		cout << "Wpiesz wartosc numer: " << i << endl;
		cin >> s.sales[i];
		srednia += s.sales[i];

	}
	s.average = (srednia / 4);
	double najwieksza = s.sales[0];
	for (int i = 0; i < 4; i++)
	{
		if (najwieksza < s.sales[i])
		{
			najwieksza = s.sales[i];
		}
	}
	s.max = najwieksza;
	double najmniejsza = s.sales[0];
	for (int i = 0; i < 4; i++)
	{
		if (najmniejsza > s.sales[i])
		{
			najmniejsza = s.sales[i];
		}
	}
	s.min = najmniejsza;
	//zerowanie danych w tablicy;
	for (int i = 0; i < 4; i++)
	{
		if (s.sales[i] != najwieksza || s.sales[i] != najmniejsza)
		{
			s.sales[i] = 0;
		}
	}

}

void Sales::showSales(const Sales &s)
{	
	using namespace SALES;
	using namespace std;
	cout << s.average << endl;
	cout << s.max << endl;
	cout << s.min << end;

}

 

komentarz 29 września 2016 przez Pascal Bywalec (2,720 p.)
edycja 29 września 2016 przez Pascal
c++ rozpoznaje wielkość znaków masz tu podane Sales:: a powinno być SALES:: gdyż nazwałeś przestrzeń nazw SALES a nie Sales, lub też zmień nazwę tej przestrzeni nazw SALES na Sales i będzie git :P No i wyszło mi masło maślane :D
komentarz 29 września 2016 przez criss Mędrzec (172,590 p.)
"Zrobiłem."

Serio...

Podobne pytania

0 głosów
2 odpowiedzi 182 wizyt
0 głosów
2 odpowiedzi 228 wizyt
0 głosów
1 odpowiedź 305 wizyt

92,632 zapytań

141,500 odpowiedzi

319,879 komentarzy

62,012 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!

...