Vous êtes actuellement hors ligne, en attente de reconnexion à Internet.

Vous pouvez recevoir une "erreur C2593: ' opérateur << ' est ambigu" message d'erreur lorsque vous essayez de passer une variable de __int64 à l'opérateur ostream <<

IMPORTANT : Cet article est issu du système de traduction automatique mis au point par Microsoft (http://support.microsoft.com/gp/mtdetails). Un certain nombre d’articles obtenus par traduction automatique sont en effet mis à votre disposition en complément des articles traduits en langue française par des traducteurs professionnels. Cela vous permet d’avoir accès, dans votre propre langue, à l’ensemble des articles de la base de connaissances rédigés originellement en langue anglaise. Les articles traduits automatiquement ne sont pas toujours parfaits et peuvent comporter des erreurs de vocabulaire, de syntaxe ou de grammaire (probablement semblables aux erreurs que ferait une personne étrangère s’exprimant dans votre langue !). Néanmoins, mis à part ces imperfections, ces articles devraient suffire à vous orienter et à vous aider à résoudre votre problème. Microsoft s’efforce aussi continuellement de faire évoluer son système de traduction automatique.

La version anglaise de cet article est la suivante: 168440
Symptômes
Si vous essayez de passer une variable de __int64 à l'opérateur ostream <<, le message d'erreur suivant s'affiche :
erreur C2593: ' opérateur << ' est ambigu
Cause
Il n'y a pas d'opérateur << pour type __int64 défini pour la classe ostream.
Résolution
Définir votre propre version de l'opérateur <<. La section de code exemple suivant illustre une solution simple pour << opérateur qui convertit la variable __int64 vers un char * tapez et le transmet à l'ostream << opérateur.
Statut
Microsoft a confirmé l'existence de ce bogue dans les produits Microsoft répertoriés dans la section "S'applique à".

Il a été corrigé dans Microsoft Visual C++ .NET.
Plus d'informations
Le programme exemple suivant montre le problème et de la solution de contournement :
//Sample.cpp// Compiler Options : /GX//#define WORKAROUND   //Uncomment this line to workaround#include<iostream>using namespace std;#ifdef WORKAROUNDstd::ostream& operator<<(std::ostream& os, __int64 i ){    char buf[20];    sprintf(buf,"%I64d", i );    os << buf;    return os;}#endifint main(){__int64  i64;cout << i64 ;return 0;}				

Avertissement : cet article a été traduit automatiquement

Propriétés

ID d'article : 168440 - Dernière mise à jour : 05/26/2005 21:44:31 - Révision : 3.0

The Standard C++ Library

  • kbmt kbbug kbcrt kberrmsg kbfix kbnoupdate KB168440 KbMtfr
Commentaires
ent.createElement('meta');m.name='ms.dqp0';m.content='true';document.getElementsByTagName('head')[0].appendChild(m);" onload="var m=document.createElement('meta');m.name='ms.dqp0';m.content='false';document.getElementsByTagName('head')[0].appendChild(m);" src="http://c1.microsoft.com/c.gif?"> =4050&did=1&t=">/html>>