Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 15-02-2011, 23:47   #1
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
[C++] Utilizzo di classe

Premetto che so programmare in Java. Java mi permette di istanziare classi scritte da me in un altra classe. Per spiegare vi faccio un breve esempio:
Prima classe/primo file:
Codice:
public class ClasseA{
//variabili
//costruttore
//metodi
}
Seconda classe/secondo file:
Codice:
public class Main{
public static void main(String[] args){
ClasseA = new ClasseA();
}
Come faccio fare una cosa simile in C++? Io ho scritto il seguente codice di esempio, ma poi non riesco a creare un "main" e utilizzarlo:

Codice:
#include <iostream>
#include <stdlib.h>
#include <time.h>
using namespace std;

class Book {
	string title;
	string author;
	int price;
public:
	Book(string, string, int);
	void printBook();
	void printBookPrice();
	string getTitle();
	string getAuthor();
	int getPrice();
	void setPrice(int);
};


Book::Book(string newTitle, string newAuthor, int newPrice) {
	title = newTitle;
	author = newAuthor;
	price = newPrice;
}

void Book::printBook() {
	cout << "The title of the book is: " << title << ".\n";
	cout << "The Author of the book is: " << author << ".\n";
}

void Book::printBookPrice() {
	cout << "Title: " << title << ". Author: " << author << ". Price: "
			<< price << "\n";
}

string Book::getTitle() {
	return title;
}

string Book::getAuthor() {
	return author;
}

int Book::getPrice() {
	return price;
}

void Book::setPrice(int newPrice) {
	price = newPrice;
}
Cioè, come faccio a creare varie classi per poi usarle tutte in un unico main, come si fa nella programmazione OO?
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2011, 00:19   #2
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Per prima cosa sposta la dichiarazione della classe Book in un file header Book.h (usa #pragma once all'inizio del file per evitare problemi con inclusioni multiple che altrimenti vengono sicuramente fuori) e l'implementazione la metti in Book.cpp che include Book.h oltre agli #include che hai già messo.
using namespace std lo metti in Book.cpp, mentre in Book.h espliciti il namespace, nel tuo caso basta usare std::string.
Per usare a questo punto la classe Book non dovrai fare altro che includere Book.h ovunque tu voglia usarla.

Book.h:
Codice:
#pragma once

#include <string>

class Book {
	std::string title;
	std::string author;
	int price;
public:
        //meglio usare:
        //Book(const std::string &, const std::string &, int);
	Book(std::string, std::string, int);
	void printBook();
	void printBookPrice();
        //meglio usare:
        //const std::string & getTitle() const;
	std::string getTitle();
	std::string getAuthor();
	int getPrice();
	void setPrice(int);
};
Book.cpp:
Codice:
#include <iostream>
#include <stdlib.h>
#include <time.h>

#include <Book.h>

using namespace std;

Book::Book(string newTitle, string newAuthor, int newPrice) {
	title = newTitle;
	author = newAuthor;
	price = newPrice;
}

void Book::printBook() {
	cout << "The title of the book is: " << title << ".\n";
	cout << "The Author of the book is: " << author << ".\n";
}

void Book::printBookPrice() {
	cout << "Title: " << title << ". Author: " << author << ". Price: "
			<< price << "\n";
}

//meglio usare:
//const string & Book::getTitle() const
string Book::getTitle() {
	return title;
}

string Book::getAuthor() {
	return author;
}

int Book::getPrice() {
	return price;
}

void Book::setPrice(int newPrice) {
	price = newPrice;
}
Un pò di consigli: usa i riferimenti (const) per passare le stringhe specialmente sul costruttore e sui metodi get.
Inoltre per i metodi get è bene specificare l'attributo const per indicare che tali metodi non modificano la classe e che possono essere utilizzati da riferimenti const.

Poi ci sarebbero un pò di dettagli mancanti, come l'utilizzo del costruttore di copia ecc...
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2011, 09:14   #3
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Grazie della risposta celere.
il "# pragma" non ò'avevo mai visto ne letto. Il "const" lo avevo gia notato in giro nei codici, ma non ho capito esattamente a cosa serve.
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2011, 14:27   #4
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
Grazie della risposta celere.
il "# pragma" non ò'avevo mai visto ne letto. Il "const" lo avevo gia notato in giro nei codici, ma non ho capito esattamente a cosa serve.
Serve ad indicare come già scritto che il metodo non modifica la classe e pertanto può essere utilizzato da riferimenti const.
Ad esempio se usassi la tua classe Book un codice del genere:
Codice:
const Book & book = GetBook();
string title = book.getTitle();
porterebbe ad un errore in fase di compilazione.
In C++ si parla di "const correctness"
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2011, 15:13   #5
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Correggimi se sbaglio. In java basta che scrivo una classe, e posso riusarla dove voglio. In C++ devo sempre scrivere un file h e uno cpp?
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2011, 15:38   #6
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
Correggimi se sbaglio. In java basta che scrivo una classe, e posso riusarla dove voglio. In C++ devo sempre scrivere un file h e uno cpp?
Si, esatto
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2011, 15:40   #7
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Si, esatto
OK, perfetto. Proverò a programmare un pò....comunque devo prima andare a studiarmi sta cosa del "const" che non ho capito l'utilizzo.
Grazie.
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2011, 16:59   #8
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Un pò di consigli: usa i riferimenti (const) per passare le stringhe specialmente sul costruttore e sui metodi get.
Inoltre per i metodi get è bene specificare l'attributo const per indicare che tali metodi non modificano la classe e che possono essere utilizzati da riferimenti const.

Poi ci sarebbero un pò di dettagli mancanti, come l'utilizzo del costruttore di copia ecc...
Non avevo letto queste righe...ma non capisco esattamente cosa intendi. Sono andato a vedere il "const" e ora mi è chiaro il suo significato; però non capisco perchè devo metterlo su costruttori e metodi. In che senso "tali metodi potrebbero modificare la classe"?
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2011, 18:07   #9
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
Non avevo letto queste righe...ma non capisco esattamente cosa intendi. Sono andato a vedere il "const" e ora mi è chiaro il suo significato; però non capisco perchè devo metterlo su costruttori e metodi. In che senso "tali metodi potrebbero modificare la classe"?
Andiamo per ordine:
Per il passaggio di oggetti in C++ è buona norma usare i riferimenti per motivi di performance (per i puntatori si apre un discorso a parte, ma lasciamolo perdere per il momento). Nel tuo caso quando chiami il costruttore crei una copia delle stringhe, mentre se usi il riferimento no. Con il riferimento nasce un problema però: te puoi modificare l'oggetto passato potenzialmente creando problemi al chiamante, pertanto si usa il modificatore const. In questo modo il chiamante sa che la tua classe non modificherà l'oggetto e contemporaneamente la tua classe non modificherà l'oggetto nemmeno per sbaglio. In ultimo i vantaggi prestazionali.

Sempre per il solito motivo che è bene passare gli oggetti per riferimento e per il fatto che è bene che siano pure const per i motivi sopra elencati, se non hai specificato dei metodi come const non puoi utilizzare l'oggetto.
Metti ad esempio che tu voglia modellare una libreria e tu abbia un metodo AddBook (l'implementazione è tarata sull'esempio):
Codice:
map<string, Book> books;

void Library::AddBook(const Book & book)
{
    map[book.getTitle()] = book;
}
Nel tuo caso avresti un errore
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2011, 18:48   #10
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
OK, tutto sommato ho capito.
Diciamo che il punto è se uso il passaggio by reference o meno. Ma usando il costruttore come ho fatto io, in pratica creando copie di stringhe, a parte le prestazioni ho altri svantaggi?
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2011, 16:43   #11
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
....noto solo ora che facendo copia incolla del codice scritto da te, Book.cpp e Book.h, mi da errore su #include <Book.h> dicendo No such file or directory.

EDIT

facendo #include "Book.h" funziona.
__________________
Vendo...nulla.
Cerco...la felicità
.

Ultima modifica di Emaborsa : 17-02-2011 alle 16:48.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2011, 17:04   #12
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
OK, tutto sommato ho capito.
Diciamo che il punto è se uso il passaggio by reference o meno. Ma usando il costruttore come ho fatto io, in pratica creando copie di stringhe, a parte le prestazioni ho altri svantaggi?
in realtà è anche una questione semantica.. se un metodo non modifica l'oggetto (come può essere un getter) allora dovrebbe essere dichiarato const
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2011, 17:42   #13
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da tuccio` Guarda i messaggi
in realtà è anche una questione semantica.. se un metodo non modifica l'oggetto (come può essere un getter) allora dovrebbe essere dichiarato const
ok, capito. Visto che mi scrivi anche tu, chiedo pure a te:

Lui mi ha scritto:

Codice:
//meglio usare:
//const string & Book::getTitle() const
string Book::getTitle() {
	return title;
}
sarebbe e dire:

Codice:
const string & Book::getTitle() const {
	return title;
}
Capisco che i const stanno per "dire" al compilatore che la stringa di ritorno e il metodo stesso non può essere modificato (o sbaglio), ma perchè? Che rischio c'è?
Inoltre perchè la referenza & prima di Book?
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
La Russia potrebbe sviluppare un'arma pe...
Manda la RAM Corsair in assistenza, rice...
ASUS ROG G1000 con 'AniMe Holo': saranno...
Un test di longevità ha messo alla prova...
Incat inizia i test dell'incredibile tra...
LG Sound Suite: al CES il sistema audio ...
Avengers Doomsday, il primo trailer &egr...
La crisi delle memorie non farà sconti a...
Il trailer più atteso dell'anno &...
I gamer vogliono i monitor OLED: sopratt...
Samsung alza l’asticella dei televisori ...
Energie rinnovabili 2025: quasi 42% del ...
Le auto elettriche volano in tutta Europ...
Nuovo look per la finestra Esegui su Win...
Rad Power Bikes è in bancarotta: ...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 20:41.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v