Torna indietro   Hardware Upgrade Forum > Software > Programmazione

NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
Nelle ultime settimane abbiamo provato tre delle proposte top di gamma di NZXT nelle categorie case, dissipatori e ventole. Rispettivamente, parliamo dell'H9 Flow RGB+, Kraken Elite 420 e F140X. Si tratta, chiaramente, di prodotti di fascia alta che si rivolgono agli utenti DIY che desiderano il massimo per la propria build. Tuttavia, mentre i primi due dispositivi mantengono questa direzione, le ventole purtroppo hanno mostrato qualche tallone d'Achille di troppo
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN è il primo monitor gaming con pannello QD-OLED Gen 5 a layout RGB Stripe Pixel e 360 Hz su 34 pollici: lo abbiamo misurato con sonde colorimetriche e NVIDIA LDAT. Ecco tutti i dati
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-04-2005, 09:53   #1
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
[C] È possibile?

È possibile dichiarare una variabile in un file C e renderla accessibile in sola lettura ai file che non sono quello in cui è stata dichiarata?
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 25-04-2005, 17:40   #2
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Proprio no, eh?
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 25-04-2005, 19:59   #3
Ed_Bunker
Senior Member
 
L'Avatar di Ed_Bunker
 
Iscritto dal: Jan 2004
Città: Montignoso(MS)
Messaggi: 9498
La dichiari come 'final' e, poi, negli altri file fai riferimento ad essa dichiarandola come extern.
Credo che dovrebbe "funzionare"...
__________________
"Il Meglio che si possa ottenere è evitare il peggio." I.C.
Ed_Bunker è offline   Rispondi citando il messaggio o parte di esso
Old 25-04-2005, 23:00   #4
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
Iscritto dal: Oct 2001
Messaggi: 11471
Quote:
Originariamente inviato da Ed_Bunker
La dichiari come 'final' e, poi, negli altri file fai riferimento ad essa dichiarandola come extern.
Credo che dovrebbe "funzionare"...
final non esiste coe modificatore in C.

Potresti sempre dichiararla static all'intern o di una funzione e poi usare quella funzione per leggerla. qualcosa di tipo:

Codice:
int getValore () {
    static int valore = 9;
    return valore;
}
E' un po stupido come esempio ma sepro si capisca cosa intendo

ciao
VICIUS è offline   Rispondi citando il messaggio o parte di esso
Old 26-04-2005, 08:40   #5
Gica78R
Senior Member
 
L'Avatar di Gica78R
 
Iscritto dal: Mar 2005
Messaggi: 1653
Con le funzioni per la memoria condivisa non va bene? O devi scrivere in ANSI C?
Guardati le funzioni shmget, shmat, shmctl e shmdt. Il problema e' che se la vuoi accedere da un processo 'non imparentato' con quello in cui dichiari la porzione di mem condivisa, per agganciarla allo spazio di indirizzi di tale processo devi usare la stessa chiave (il parametro key di shmget) usata nel processo che ha creato la variabile condivisa...

Ciao
Gica78R è offline   Rispondi citando il messaggio o parte di esso
Old 26-04-2005, 09:19   #6
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Hmm... veramente forse potrei risolvere (parzialmente) col metodo di VICIUS, anche se non mi sembra la soluzione migliore. Spiego: ho un file C che contiene delle variabili usate praticamente da tutte le sue funzioni, e che devono essere modificabili da queste. Cercavo, però, un metodo per renderle in sola lettura per i file che le importano. Magari c'è qualche directive che posso impostare nell'header? Mah.
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 26-04-2005, 11:16   #7
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Per comprendere io meglio la tua domanda, intendi qualcosa tipo il Private che si utilizza in C++ ?
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 26-04-2005, 11:48   #8
Blackat
Senior Member
 
L'Avatar di Blackat
 
Iscritto dal: Oct 2004
Città: Acireale
Messaggi: 447
Non è che ha molto senso quello che stai facendo.

Quote:
ho un file C che contiene delle variabili usate praticamente da tutte le sue funzioni, e che devono essere modificabili da queste.
Invece di "proteggere" le variabili utilizzate da queste funzioni, perchè non utilizzi un
pattern come quello dei file in C.
I file in C utilizzano la struttura FILE, per memorizzare delle variabili utilizzate dalle
funzioni che permettono di accedere ad un file.
Poi utilizzano delle funzioni di inizializzazione e distruzione come fopen e fclose per creare
e distruggere lo "spazio" di variabili utilizzato dalle funzioni che utilizzeranno FILE.
Per accedere al file tramite la struttura FILE invece utilizzano la collezione di funzioni
fwrite, fread, feof, fseek, ecc.....

Lo so che non è la soluzione ideale per "proteggere" le variabili globali, ma rende
l'operazione di modifica più complessa.

Saluti.
__________________
Ho concluso acquisti e/o vendite con : SHIVA>>LuR<<, TheGaiden, ArvMau
Blackat è offline   Rispondi citando il messaggio o parte di esso
Old 26-04-2005, 12:47   #9
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
scusa, ma normalmente come fai ad utilizzare in un file sorgente C una variabile dichiarata in un altro file sorgente? la dichiari in un header come extern?
imho non esiste modo di fare quello che dici; a parte il fatto che se vuoi evitare modifiche alla variabile, semplicemente... non modificarla! ma cmq se proprio cerchi il massimo dell'eleganza, l'unica soluzione in C imho è usare un getter come dice VICIOUS, però non è necessario che la variabile sia statica e locale, puoi semplicemente fare così:
Codice:
int nVar;
.
.
.
int GetValue() {
    return nVar;
}
o al limite così:
Codice:
static int nVar;
.
.
.
int GetValue () { ecc.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 26-04-2005, 13:32   #10
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Be', la soluzione in effetti può essere proprio quella di VICIUS e 71104, anche se è poco elegante e un po' scomoda. Infatti dopo diverse lotte sono riuscito a far funzionare di nuovo il mio sistemino operativo (una schifezza, era meglio se lo lasciavo morire ), e ora mi trovo di fronte una variabile globale (posizione su schermo dell'output per la console) che vorrei venisse letta anche esternamente, ma che non sia esternamente modificabile. In fondo usare un "getter" sarebbe la soluzione più semplice e veloce, ma anche quella che rallenterebbe di più l'esecuzione (chiamare la funzione ogni volta soltanto per leggere un valore...).

Ho capito, insomma: non è possibile, almeno non normalmente. Grazie comunque a tutti!
Bye
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 26-04-2005, 15:11   #11
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da DanieleC88
(chiamare la funzione ogni volta soltanto per leggere un valore...).
Se la dichiari come inline non hai problema di performance...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 26-04-2005, 22:32   #12
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Quote:
Originariamente inviato da cionci
Se la dichiari come inline non hai problema di performance...
Tu dici? Ma sbaglio, o dichiarandola inline questa viene "ricopiata" in ogni parte in cui viene chiamata? Temo che questo possa portare a grandezze del kernel maggiori, quando a me serve solo un piccolo kernel che vada in pochi settori di un floppy (47, per ora).
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 26-04-2005, 22:52   #13
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Al contrario...se, come in questo caso, la funzione è minima ci dovrebbe essere una semplice mov al posto di una call...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2005, 12:47   #14
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Quote:
Originariamente inviato da cionci
Al contrario...se, come in questo caso, la funzione è minima ci dovrebbe essere una semplice mov al posto di una call...
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
CAS Space ha lanciato per la prima volta...
Qualcomm boccia Samsung: i futuri chip S...
Il razzo spaziale cinese Tianlong-3 di S...
Samsung cambia i piani: aumenta la produ...
TSMC non si ferma più: fatturato ...
Xiaomi porta in Italia il nuovo Redmi A7...
Mercato smartphone: Q1 2026 positivo (+1...
YouTube punta sull'AI: gli utenti potran...
Il prossimo chip a 2 nm di Samsung punte...
Due smartphone REDMAGIC sono stati rimos...
La beta della One UI 8.5 è ora di...
Addio al Pannello di Controllo di Window...
Il chip N1 di NVIDIA per i laptop del fu...
YouTube Premium costerà di pi&ugr...
I nuovi Samsung Galaxy A57 5G e A37 5G a...
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: 04:04.


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