c - int16_t - prid64




Como imprimir um tipo int64_t em C (4)

O padrão C99 tem tipos inteiros com tamanho de bytes como int64_t. Estou usando o seguinte código:

#include <stdio.h>
#include <stdint.h>
int64_t my_int = 999999999999999999;
printf("This is my_int: %I64d\n", my_int);

e recebo este aviso do compilador:

warning: format ‘%I64d expects type int’, but argument 2 has type int64_t

Eu tentei com:

printf("This is my_int: %lld\n", my_int); // long long decimal

Mas recebo o mesmo aviso. Eu estou usando este compilador:

~/dev/c$ cc -v
Using built-in specs.
Target: i686-apple-darwin10
Configured with: /var/tmp/gcc/gcc-5664~89/src/configure --disable-checking --enable-werror --prefix=/usr --mandir=/share/man --enable-languages=c,objc,c++,obj-c++ --program-transform-name=/^[cg][^.-]*$/s/$/-4.2/ --with-slibdir=/usr/lib --build=i686-apple-darwin10 --program-prefix=i686-apple-darwin10- --host=x86_64-apple-darwin10 --target=i686-apple-darwin10 --with-gxx-include-dir=/include/c++/4.2.1
Thread model: posix
gcc version 4.2.1 (Apple Inc. build 5664)

Qual formato devo usar para imprimir a variável my_int sem ter um aviso?


//VC6.0 (386 e melhor)

    __int64 my_qw_var = 0x1234567890abcdef;

    __int32 v_dw_h;
    __int32 v_dw_l;

    __asm
        {
            mov eax,[dword ptr my_qw_var + 4]   //dwh
            mov [dword ptr v_dw_h],eax

            mov eax,[dword ptr my_qw_var]   //dwl
            mov [dword ptr v_dw_l],eax

        }
        //Oops 0.8 format
    printf("val = 0x%0.8x%0.8x\n", (__int32)v_dw_h, (__int32)v_dw_l);

Saudações.


Com o C99, o modificador %j length também pode ser usado com a família printf de funções para imprimir valores do tipo int64_t e uint64_t :

#include <stdio.h>
#include <stdint.h>

int main(int argc, char *argv[])
{
    int64_t  a = 1LL << 63;
    uint64_t b = 1ULL << 63;

    printf("a=%jd (0x%jx)\n", a, a);
    printf("b=%ju (0x%jx)\n", b, b);

    return 0;
}

Compilar este código com gcc -Wall -pedantic -std=c99 não produz nenhum aviso e o programa imprime a saída esperada:

a=-9223372036854775808 (0x8000000000000000)
b=9223372036854775808 (0x8000000000000000)

Isso está de acordo com printf(3) no meu sistema Linux (a página man especificamente diz que j é usado para indicar uma conversão para um intmax_t ou uintmax_t ; no meu stdint.h, tanto int64_t quanto intmax_t são typedef'd exatamente iguais maneira, e da mesma forma para uint64_t ). Não tenho certeza se isso é perfeitamente portátil para outros sistemas.


O caminho C99 é

#include <inttypes.h>
int64_t my_int = 999999999999999999;
printf("%" PRId64 "\n", my_int);

Ou você pode lançar!

printf("%ld", (long)my_int);
printf("%lld", (long long)my_int); /* C89 didn't define `long long` */
printf("%f", (double)my_int);

Se você está preso a uma implementação do C89 (principalmente o Visual Studio), talvez você possa usar um código aberto <inttypes.h> (e <stdint.h> ): http://code.google.com/p/msinttypes/


Para o tipo int64_t :

#include <inttypes.h>
int64_t t;
printf("%" PRId64 "\n", t);

para o tipo uint64_t :

#include <inttypes.h>
uint64_t t;
printf("%" PRIu64 "\n", t);

Você também pode usar o PRIx64 para imprimir em hexadecimal.

O cppreference.com tem uma lista completa de macros disponíveis para todos os tipos, incluindo intptr_t ( PRIxPTR ). Existem macros separadas para o scanf, como o SCNd64 .

Uma definição típica de PRIu16 seria "hu" , portanto, a concatenação constante de cadeia de caracteres implícita ocorre em tempo de compilação.

Para que seu código seja totalmente portátil, você deve usar o PRId32 e assim por diante para imprimir int32_t e "%d" ou similar para impressão int .





stdint