簡體   English   中英

將無符號long long轉換為C中的double

[英]Convert unsigned long long to double in C

我意識到這個問題可能取決於處理器,但希望有人可以指出我正確的方向。 對於我的生活,我無法弄清楚如何將表示納秒的無符號long long int轉換為表示C中的秒的double(我使用32位big-endian PowerPC 405進行此特定測試,以及GNU C99編譯器)。

我試過了:

unsigned long long int nanoseconds = 1234567890LLU;
double nanoseconds_d = nanoseconds*1e-9;

也:

nanoseconds_d = ((double) nanoseconds)*1e-9;

對於這兩種情況,我只得到0.我在這里做錯了什么?

編輯添加完整的例子

#include <stdio.h>
#include <stdlib.h>

int
main( int argc, char *argv[] )
{
    unsigned long long int nanoseconds = 1234567890LLU;
    double nanoseconds_d = nanoseconds * 1e-9;
    printf("%g\n", nanoseconds_d);

    return 0;
}

MAKEFILE

SRCS    = simple.c    
INCLUDE := -I$(PWD)            
CFLAGS  := -O0 -g3 -Wall -fmessage-length=0 -mhard-float -fsigned-char -D_REENTRANT
LIBS    := -lc

OBJS = $(SRCS:.c=.o)
PROG = $(SRCS:.c=).out

all: $(PROG)

$(PROG): $(OBJS)
    @echo "Linking object files with output."
    $(CC) -o $(PROG) $(OBJS) $(LIBS)
    @echo "Linking complete."

$(OBJS): $(SRCS)
    @echo "Starting compilation."
    $(CC) $(CFLAGS) $(INCLUDE) -c $<
    @echo "Compilation complete."   

clean::
    @$(RM) *.o *.out

使用%g打印時可在此處使用

#include <stdlib.h>
#include <stdio.h>

int main(){
    unsigned long long int nanoseconds = 1234567890LLU;
    double nanoseconds_d = nanoseconds*1e-9;
    printf("%g\n", nanoseconds_d);

    nanoseconds_d = ((double) nanoseconds)*1e-9;
    printf("%g\n", nanoseconds_d);
}

輸出

1.23457
1.23457

事實證明,我使用的交叉gcc的版本有一個與軟浮點和硬浮點有關的錯誤。 因此,從無符號長到長的演員陣容不能正常工作,造成問題。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM