Condividi tramite


COleDateTime::SetDate

Imposta la data di questo oggetto COleDateTime.

int SetDate(
   int nYear,
   int nMonth,
   int nDay 
) throw( );

Parametri

  • nYear, nMonth, nDay
    Scegliere i componenti date da copiare in questo oggetto COleDateTime.

Valore restituito

Zero se il valore di questo oggetto COleDateTime fosse impostato correttamente; in caso contrario, 1.Questo valore restituito è basato sul tipo enumerato DateTimeStatus.Per ulteriori informazioni, vedere la funzione membro SetStatus.

Note

La data è impostata sui valori specificati.Il tempo viene impostato di orologio 0, mezzanotte.

Vedere la tabella seguente per i limiti dei valori di parametro:

Parametro

Limiti

nYear

100 – 9999

nMonth

1 – 12

nDay

0 – 31

Se il giorno degli overflow di mese, viene convertita al giorno del mese e il giorno e/o l'anno viene incrementato di conseguenza.Un valore di ora pari a zero indica l'ultimo giorno del mese precedente.Il comportamento sarà uguale a SystemTimeToVariantTime.

Se il valore della data specificati dai parametri non è valido, lo stato di questo oggetto è impostato su COleDateTime::invalid.Utilizzare GetStatus per verificare la validità del valore DATE e non occorre considerare che il valore m_dt restare invariato.

Di seguito sono riportati alcuni esempi di valori di data:

nYear

nMonth

nDay

Valore

2000

2

29

29 febbraio 2000

1776

7

4

4 luglio 1776

1925

4

35

35 Aprile 1925 (data non valida)

10000

1

1

1° gennaio 10000 (Data non valida)

Per impostare entrambe data e ora, vedere COleDateTime::SetDateTime.

Per informazioni sulle funzioni membro che interroga il valore di questo oggetto COleDateTime, vedere le seguenti funzioni membro:

Per ulteriori informazioni sui limiti dei valori COleDateTime, vedere l'articolo data e ora: supporto di automazione.

Esempio

// set only the date, time set to midnight
dt.SetDate(1999, 3, 19);
ASSERT(dt.GetYear() == 1999);
ASSERT(dt.GetDay() == 19);
ASSERT(dt.GetMonth() == 3);
ASSERT(dt.GetHour() == 0);
ASSERT(dt.GetMinute() == 0);
ASSERT(dt.GetSecond() == 0);

// setting the time only resets the date to 1899!
dt.SetTime(22, 15, 0);
ASSERT(dt.GetYear() == 1899);
ASSERT(dt.GetDay() == 30);
ASSERT(dt.GetMonth() == 12);
ASSERT(dt.GetHour() == 22);
ASSERT(dt.GetMinute() == 15);
ASSERT(dt.GetSecond() == 0);   

Requisiti

Header: atlcomtime.h

Vedere anche

Riferimenti

Classe di COleDateTime

Grafico della gerarchia

COleDateTime::COleDateTime

COleDateTime::SetDateTime

COleDateTime::operator =

COleDateTime::GetStatus

COleDateTime::m_dt