IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JDBC Java Discussion :

JDBC warning lors de la compilation


Sujet :

JDBC Java

  1. #1
    Membre du Club
    Inscrit en
    Décembre 2005
    Messages
    79
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 79
    Points : 60
    Points
    60
    Par défaut JDBC warning lors de la compilation
    bonjour,
    j'ai voulus compiler ce simple bout de code pour verifier que tout allait bien,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    public class Test {
     
        public static void main(String[] args) {
            // Create application frame.
            try{
           Class.forName("com.mysql.jdbc.Driver");
           }catch(Exception e){e.printStackTrace();}
        }
    }
    et
    --------------------Configuration: test - JDK version 1.5.0_06 <Default> - <Default>--------------------
    C:\Program Files\Xinox Software\JCreatorV3LE\MyProjects\test\mysql-connector-java-3.1.12\src\com\mysql\jdbc\StringUtils.java:100: warning: non-varargs call of varargs method with inexact argument type for last parameter;
    cast to java.lang.Object for a varargs call
    cast to java.lang.Object[] for a non-varargs call and to suppress this warning
    return (String) toPlainStringMethod.invoke(decimal, null);
    ^
    C:\Program Files\Xinox Software\JCreatorV3LE\MyProjects\test\mysql-connector-java-3.1.12\src\com\mysql\jdbc\integration\c3p0\MysqlConnectionTester.java:54: warning: non-varargs call of varargs method with inexact argument type for last parameter;
    cast to java.lang.Class for a varargs call
    cast to java.lang.Class[] for a non-varargs call and to suppress this warning
    .getMethod("ping", null);
    ^
    C:\Program Files\Xinox Software\JCreatorV3LE\MyProjects\test\mysql-connector-java-3.1.12\src\com\mysql\jdbc\integration\jboss\MysqlValidConnectionChecker.java:55: warning: non-varargs call of varargs method with inexact argument type for last parameter;
    cast to java.lang.Class for a varargs call
    cast to java.lang.Class[] for a non-varargs call and to suppress this warning
    pingMethod = mysqlConnection.getMethod("ping", null);
    ^
    C:\Program Files\Xinox Software\JCreatorV3LE\MyProjects\test\mysql-connector-java-3.1.12\src\testsuite\regression\DataSourceRegressionTest.java:342: warning: non-varargs call of varargs method with inexact argument type for last parameter;
    cast to java.lang.Object for a varargs call
    cast to java.lang.Object[] for a non-varargs call and to suppress this warning
    enableStreamingResultsMethodStmt.invoke(physStatement, new Class[0]);
    ^
    C:\Program Files\Xinox Software\JCreatorV3LE\MyProjects\test\mysql-connector-java-3.1.12\src\testsuite\regression\DataSourceRegressionTest.java:362: warning: non-varargs call of varargs method with inexact argument type for last parameter;
    cast to java.lang.Object for a varargs call
    cast to java.lang.Object[] for a non-varargs call and to suppress this warning
    lorsque j'execute le projet, aucune erreur.

    qu'est-ce que j'ai fais qui ne va pas bien ?

  2. #2
    Membre averti
    Homme Profil pro
    Développeur Java
    Inscrit en
    Avril 2004
    Messages
    265
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Avril 2004
    Messages : 265
    Points : 342
    Points
    342
    Par défaut
    ça c'est des erreurs (enfin des warnings) de java 5...

    Depuis java 1.5, on a les méthodes à nombrezs d'arguments variables, en 1.4 les mêmes methodes utilisaient des tableaux d'objets (par exmemple). Du coup en compilant en 1.5, si t'utilises des méthodes maintenant "varargs", le compilateur génére un warning... (Je sais je suis pas clair... )

    Mais à mon avis elles ne viennent pas du code que tu as donné...

  3. #3
    Membre du Club
    Inscrit en
    Décembre 2005
    Messages
    79
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 79
    Points : 60
    Points
    60
    Par défaut
    ok merci.

    ça m'ammene a une autre question :

    si je laisse comme ça, c'est grave ? ( quelles sont les consequences )
    et si oui, que dois-je modifier pour que "ça ne bug plus" ?

  4. #4
    Membre confirmé
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Octobre 2005
    Messages
    244
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Philippines

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2005
    Messages : 244
    Points : 609
    Points
    609
    Par défaut
    Si tu laisse comme ça, ce n'est pas "grave". En fait sa peu etre embettant si c'est une parti de code que tu va utiliser.
    Or tu va passer je suppose par les classe fournise dans le package java.sql

    Verifie si tu ne peu pas trouver des drivers plus recents (pour java 5.0)

    Sinon, tu devrais pouvoir supprimer les warnings avec:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    @suppressWarnings("non-varargs");
    devant ta methode.

    Je suis pas sur en fait de la valeur de la chaine (non-varargs), je pense que quelqu'un pourra mieux te renseigner à ce propos

  5. #5
    Membre averti
    Homme Profil pro
    Développeur Java
    Inscrit en
    Avril 2004
    Messages
    265
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Avril 2004
    Messages : 265
    Points : 342
    Points
    342
    Par défaut
    Perso je les ai laissé trainer quelques semaines... mais bon c'est pas trés compliquer à enlever (il suffit de se plonger un peu dans la javadoc 1.5) et pouf ça va vite.

    Je ne croit pas qu'il y ai des possibilités de bugs dû à ces warnings... Par contre une liste trop grande de warnings peut cacher un warning important (voire une erreur), du coup je pense que c'est mieux de corriger ça vite.

    genre que tu as cette erreur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    non-varargs call of varargs method with inexact argument type for last parameter;
    cast to java.lang.Object for a varargs call
    cast to java.lang.Object[] for a non-varargs call and to suppress this warning
    return (String) toPlainStringMethod.invoke(decimal, null);
    Il me semnle qu'il suffit d'enlever le "null" en paramètres, donc assez simple

  6. #6
    Membre du Club
    Inscrit en
    Décembre 2005
    Messages
    79
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 79
    Points : 60
    Points
    60
    Par défaut
    merci, c'est noté

    ( je vais laisser trainer quelques temps, puis je l'enleverrais des que je me sentirais pres a me plonger dans le code de com.mysql )

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. warnings lors de la compilation
    Par manaiilhem dans le forum Fortran
    Réponses: 9
    Dernier message: 28/03/2013, 09h35
  2. Réponses: 3
    Dernier message: 19/03/2009, 10h56
  3. warning lors de la compilation
    Par salseropom dans le forum C
    Réponses: 6
    Dernier message: 04/12/2006, 10h46
  4. Warnings lors de la compilation
    Par polo54 dans le forum C
    Réponses: 5
    Dernier message: 07/02/2003, 09h12

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo