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 12-10-2009, 21:51   #1
Andreabianchi1984
Junior Member
 
Iscritto dal: Sep 2005
Messaggi: 21
[VB] Applicazione che si blocca ogni seconda volta che viene lanciata

ABC

Ultima modifica di Andreabianchi1984 : 23-01-2010 alle 01:40.
Andreabianchi1984 è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2009, 00:12   #2
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Il tuo codice è soggetto ad errori, principalmente perchè stai usando Excel da VB6, non da VBA, perciò è rischioso ed ambiguo chiamare proprietà e metodi del modello ad oggetti di Excel in modo diretto, senza riferimenti completi.
Al momento non mi è chiaro perchè VB6 ti passi per buona la prima e non la seconda, in ogni caso è meglio così :

Codice:
xlApp.ActiveCell.Offset(0, 0).Select
xlApp.ActiveCell.Offset(0, 0).Value = Text1(0).Text
xlApp.Range("A2").Select
a = xlApp.Range("B2").Value
e così via per tutti gli altri... A questo punto non dovrebbe più dare errori.
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 14-10-2009, 01:10   #3
Andreabianchi1984
Junior Member
 
Iscritto dal: Sep 2005
Messaggi: 21
ABC

Ultima modifica di Andreabianchi1984 : 23-01-2010 alle 01:40.
Andreabianchi1984 è offline   Rispondi citando il messaggio o parte di esso
Old 14-10-2009, 07:52   #4
lorenzo001
Senior Member
 
Iscritto dal: Jul 2008
Città: Roma
Messaggi: 542
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
Al momento non mi è chiaro perchè VB6 ti passi per buona la prima e non la seconda
Perche' VB6, in modo del tutto opinabile, crea automaticamente una istanza nascosta se si accorge che non c'e' il riferimento ad un'istanza esplicita.
lorenzo001 è offline   Rispondi citando il messaggio o parte di esso
Old 14-10-2009, 09:27   #5
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da lorenzo001 Guarda i messaggi
Perche' VB6, in modo del tutto opinabile, crea automaticamente una istanza nascosta se si accorge che non c'e' il riferimento ad un'istanza esplicita.
E perchè questa istanza nascosta viene creata solo sulla prima esecuzione della routine, e non sulla seconda e le successive ?
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 14-10-2009, 09:51   #6
lorenzo001
Senior Member
 
Iscritto dal: Jul 2008
Città: Roma
Messaggi: 542
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
E perchè questa istanza nascosta viene creata solo sulla prima esecuzione della routine, e non sulla seconda e le successive ?
Non viene creata sulla prima esecuzione.

Ad ogni esecuzione, se sono usate delle istruzioni che fanno riferimento alla libreria di Excel senza passare da una esplicita istanza, ne viene creata automaticamente una nascosta.
lorenzo001 è offline   Rispondi citando il messaggio o parte di esso
Old 14-10-2009, 15:39   #7
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da lorenzo001 Guarda i messaggi
Non viene creata sulla prima esecuzione.

Ad ogni esecuzione, se sono usate delle istruzioni che fanno riferimento alla libreria di Excel senza passare da una esplicita istanza, ne viene creata automaticamente una nascosta.
E' una teoria che non mi convince. Non spiega perchè alla prima esecuzione tutto funzioni, mentre nelle successive, no.
Se così fosse dovrebbe funzionare ad ogni esecuzione, ossia ad ogni Click su quel pulsante, su una nuova istanza "fantasma" creata da VB6 allo scopo...

Secondo me l'errore è dovuto al fatto di mischiare insieme 2 soluzioni possibili. Ci si può aiutare tenendo aperto il Task Manager durante le esecuzioni, e tenendo traccia del PID dei processi Excel tramite la GetWindowThreadProcessId :

Codice:
Private Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hwnd As Long, ByVal lpdwProcessId As Long) As Long
> CASO 1 - Riferimenti totalmente espliciti :

Codice:
    Dim AppExcel As Excel.Application
    Dim WB As Excel.Workbook
    
    Set AppExcel = New Excel.Application
    AppExcel.Visible = True
    
    Dim PID As Long
    PID = GetWindowThreadProcessId(AppExcel.hwnd, 0)
    MsgBox PID
    
    Set WB = AppExcel.Workbooks.Open(percorso & "TEST.xls")
    
    AppExcel.ActiveCell.Offset(1, 1).FormulaR1C1 = "OFFSET"
    WB.Worksheets("Foglio2").Select
    WB.Worksheets("Foglio2").Range("A1").FormulaR1C1 = "PROVA"
    
    WB.Close SaveChanges:=True
    
    AppExcel.Quit
    Set WB = Nothing
    Set AppExcel = Nothing
questa tecnica è la migliore in assoluto, non produce alcuna ambiguità, nessun errore. A Task Manager, il processo Excel è slegato dall'Application VB6, viene aperto, usato e chiuso correttamente. Il PID cambia ad ogni esecuzione.

> CASO 2 - Riferimenti totalmente impliciti :

Codice:
    Workbooks.Open percorso & "TEST.xls"
    
    Dim PID As Long
    PID = GetWindowThreadProcessId(ActiveCell.Application.hwnd, 0)
    MsgBox PID
    
    ActiveCell.Offset(2, 2).FormulaR1C1 = "OFFSET"
    Worksheets("Foglio2").Select
    Worksheets("Foglio2").Range("A1").FormulaR1C1 = "PROVA"
    
    ActiveWorkbook.Close SaveChanges:=True
questa tecnica ha senso solo per risparmiare codice su task molto semplici, ed è funzionante. Alla prima esecuzione VB6 crea l'istanza di Excel, e la "collega" all'Application. Dalla seconda esecuzione in poi, VB6 NON crea altre istanze, ma si basa sempre sulla stessa, ecco il perchè dello strano errore di Andreabianchi1984. Tutte le esecuzioni funzionano e non ci sono errori. A Task Manager è visibile l'istanza fantasma di Excel, che infatti viene chiusa automaticamente alla chiusura dell'Application VB6. Il PID ad ogni esecuzione è lo stesso.

> CASO 3 - L'Ibrido :

Codice:
    Dim AppExcel As Excel.Application
    Dim WB As Excel.Workbook
    
    Set AppExcel = New Excel.Application
    AppExcel.Visible = True
    
    Set WB = AppExcel.Workbooks.Open(percorso & "TEST.xls")
    
    ActiveCell.Offset(1, 1).FormulaR1C1 = "OFFSET"
    Worksheets("Foglio2").Select
    Worksheets("Foglio2").Range("A1").FormulaR1C1 = "PROVA"
    
    Dim PID As Long
    PID = GetWindowThreadProcessId(ActiveCell.Application.hwnd, 0)
    MsgBox PID
    PID = GetWindowThreadProcessId(AppExcel.hwnd, 0)
    MsgBox PID
    
    WB.Close SaveChanges:=True
    AppExcel.Quit
    Set WB = Nothing
    Set AppExcel = Nothing
la peggiore soluzione che si possa adottare. Nella prima esecuzione viene creata AppExcel, ma alla prima istruzione "implicita" VB6 si trova a dover "indovinare", e lo fa creando UNA VOLTA SOLA la sua solita istanza fantasma, e la collega ( con quello che sembrerebbe una sorta di "ByRef implicito" ) ad AppExcel. Alla chiusura del WorkBook su AppExcel viene implicitamente chiuso anche quello sull'istanza fantasma, con il risultato che, alla prima istruzione di lettura o scirttura, l'istanza fantasma è sempre quella, ma senza alcun WorkBook all'interno, da qui l'errore VB6 di istanza non impostata. Basta commentare la linea "WB.Close SaveChanges:=True
" affinchè non vada più in errore. Dallo studio del PID risulta che alla PRIMA esecuzione il PID di AppExcel coincide con l'istanza fantasma, mentre dalla seconda in poi l'istanza fantasma conserva sempre il suo PID, mentre AppExcel cambia.
MarcoGG è 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 ...
Roscosmos ha posticipato (ancora) il lan...
Isar Aerospace si prepara al secondo lan...
Tory Bruno è entrato in Blue Orig...
Fujifilm lancia la cartuccia per archivi...
Dreame H15 Mix: la soluzione 7-in-1 per ...
AirPods Pro 3 in forte sconto su Amazon:...
36 offerte Amazon, molte appena partite:...
2 caricatori multipli eccezionali: da 28...
OLED e 360 Hz a un prezzo senza preceden...
Roborock Q10 S5+ a un prezzo molto conve...
Upgrade PC a prezzo ridotto: le migliori...
Sono i 6 smartphone migliori su Amazon: ...
Google Pixel 9a a 361€, mai così ...
Super sconti sugli spazzolini Oral-B, an...
Aspira a 6000Pa, lava bene, costa 139€: ...
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: 22:38.


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