unsigned char problem

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

unsigned char x,y;
int main()
{
    printf("WYPISZ 2 LICZBY""\n""\n");
    printf("Pierwsza liczba: ");
    scanf("%d",&x);
    printf("Druga liczba: ");
    scanf("%d",&y);
    printf("%d %d",x,y);
    return 0;
}

Chce aby te liczby całkowite pojawiły mi się w konsoli zamiast tego x zawsze jest 0 nie wiem o co chodzi próbowałem z różnymi ciągami formatującymi ale dalej to samo help

0

Dla wczytywania znaków ( unsigned char ) powinno się używać %c zamiast %d

scanf("%c",&x);

Jeżeli nie jest to czyste C, to rozważ użycie cin >> x.

4
  1. dokumentacja twoim przyjacielem
  2. używaj opcji kompilatora -Wall (włącza ostrzeżenia) albo -Werror (traktuj ostrzeżenia jak błędy). https://wandbox.org/permlink/JlevbHpExqCePxZj
  3. Masz "undefined behavior" bo przypisujesz za pomocą scanf int do zmiennej char (stąd ostrzeżenia)
  4. rada powyżej jest bezsensu, bo nie chcesz wczytywać znaku tylko liczbę
  5. Użyj int zamiast char
  6. jeśli koniecznie ma być char to dokumentacja mówi, że format string ma być:
scanf("%hhu",&x);
1
MarekR22 napisał(a):
  1. dokumentacja twoim przyjacielem
  2. używaj opcji kompilatora -Wall (włącza ostrzeżenia) albo -Werror (traktuj ostrzeżenia jak błędy). https://wandbox.org/permlink/JlevbHpExqCePxZj
  3. Masz "undefined behavior" bo przypisujesz za pomocą scanf int do zmiennej char (stąd ostrzeżenia)
  4. rada powyżej jest bezsensu, bo nie chcesz wczytywać znaku tylko liczbę
  5. Użyj int zamiast char
  6. jeśli koniecznie ma być char to dokumentacja mówi, że format string ma być:
scanf("%hhu",&x);

Dlaczego na tej stronce którą podlinkowałeś program działa poprawnie a u mnie coś się krzani

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

int main()
{
    unsigned char x,y,a,b,c;

    printf("WYPISZ 2 LICZBY""\n");
    printf("Pierwsza liczba: ");
    scanf("%hhu",&x);
    printf("Druga liczba: ");
    scanf("%hhu",&y);
    printf("Podane liczby: %hhu %hhu\n",x,y);

    a=x|y;
    b=x&y;
    c=x^y;

    printf("Wynik OR: %hhu %x\n",a,a);
    printf("Wynik AND: %hhu %x\n",b,b);
    printf("Wynik XOR: %hhu %x\n",c,c);

    return 0;
}

pokazuje 0 zamiast pierwszej liczby

1

Masz zmienną typu char (1 bajt rozmiaru) i podajesz wskaźnik do niej w scanf. Jednak w formacie dla scanf podałeś %d, więc interpretuje ten wskaźnik do zmiennej typu int (4/8 bajtów). Najprowdopodobnie korzystasz z architektury x86, co onzacza, że pierwszy bajt odpowiada najwyższej części liczby, a ostatni najmniejszej. Zatem twoja liczba znajduje się dopiero parę bajtów dalej, natomiast bajt, który odczytujesz jest wyzerowany, bo wpisałeś niedostatecznie dużą liczbę. Jakbyś wpisał w większą, coś by ci się innego wyświetliło.
Aby uniknąć takich sytuacji, jak słusznie zauważono wyżej, włącz i zwracaj uwagę na ostrzeżenia. Dobrą praktyką jest -Werror nie przepuszczać ostrzeżeń nigdy. Nawet jeśli dostajesz ostrzeżenie w kodzie, który działa jak powinien, zmodyfikowanie kodu, żeby ostrzeżenia nie było, to przeważnie kwestia dodania nawiasu lub rzutowania. Zaś jak się zacznie olewać ostrzeżenia to już się olewa je zawsze. Nie warto.

0

Weź normalnie wczytaj do unsigned int po czym przypisz do unsigned char

unsigned char scanuchar()
  {
   unsigned value=0;
   if(scanf("%u",&value)!=1) { /*scanf nie wczytał liczby może wpisano litery  - może coś z tym fantem chcesz zrobić?*/ }
   if(value>>8) { /*wpisano więcej niż 255 - może coś z tym fantem chcesz zrobić?*/ }
   return value;
  }

1 użytkowników online, w tym zalogowanych: 0, gości: 1