Vývojáři dekompilátoru rev.ng otevřeli jeho backend revng-c. Zdrojové kódy jsou k dispozici na GitHubu.
Poněvadž Redis už není svobodný, konsorcium Linux Foundation a Amazon Web Services (AWS), Google Cloud, Oracle, Ericsson a Snap Inc. společně představili svobodný fork Redisu s názvem Valkey.
Sam Bankman-Fried, zakladatel zkrachovalé kryptoměnové burzy FTX, byl dnes odsouzen k 25 letům vězení [Yahoo Finance].
Proxmox oznámil, že usnadňuje migraci z VMware ESXi do Proxmoxu.
Byla vydána nová verze 2.53.18.2 svobodného multiplatformního balíku internetových aplikací SeaMonkey (Wikipedie). Přehled novinek v poznámkách k vydání.
Na blogu programovacího jazyka Swift byl publikován příspěvek Psaní aplikací pro GNOME v programovacím jazyce Swift. Používá se Adwaita pro Swift.
egui je GUI knihovna pro programovací jazyk Rust běžící na webu i nativně. Vydána byla verze 0.27.0.
Byla vydána nová verze 6.1 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Přehled změn v příslušném seznamu. Tor Browser byl povýšen na verzi 13.0.13. Thunderbird na verzi 115.9.0.
Linka STOPonline.cz v roce 2023 přijala 3700 hlášení závadného obsahu na internetu, 22 bylo předáno PČR, 23 bylo předáno ISP a 944 závadových domén zobrazujících dětskou nahotu či pornografii bylo nahráno do mezinárodního systému ICCAM, který je spravován asociací INHOPE.
Byla publikována podrobná analýza v upstreamu již opravené bezpečnostní chyby CVE-2024-1086 v Linuxu v nf_tables.
Řešení dotazu:
#include <stdio.h> #include <stdlib.h> int lencln(char const * sin) { int len = 0; for (int i = 0; sin[i] != '\0'; i++) if((sin[i] >= 'A' && sin[i] <= 'Z') || (sin[i] >= 'a' && sin[i] <= 'z')) len++; return len; } char * clean(char const * sin){ int j = 0; char *str_cln = NULL; str_cln = (char*) malloc(sizeof(char) * (lencln(sin) + 1)); if(str_cln == NULL) return NULL; for (int i = 0; sin[i] != '\0'; i++) if((sin[i] >= 'A' && sin[i] <= 'Z') || (sin[i] >= 'a' && sin[i] <= 'z')) str_cln[j++] = sin[i]; str_cln[j]='\0'; // !!! return str_cln; } int main(){ char sin[101]; scanf(" %100[^\n]s", sin); char * strout = clean(sin); puts(strout); free(strout); strout = NULL; return 0; }A ten Tvoj obrázok je výstup z akého programu?
A ten Tvoj obrázok je výstup z akého programu?
z toho samýho jeho zkompilovanýho :O ;D hele jendův tutorial na asan ;D
.......obrázok..
btw text z konzole si mužeš normálně zkopírovat když ho uplně vobyčejně voznačíš myšičkou a pak máčkneš ctrl+shift+c a nemusíš čarovat s vobrázkama :O ;D ......a mužeš taky líp poskovávat jakejže soubor kde kompiluješ by tě učitelskej nemoch doxnout :O :D ;D ;D
podobně ctrl+shift+v na vložení textu do terminálu :O ;D
<pre>
, tohle je na prd.
Nějak jsem to otipoval a hned při kompilaci vyletí warning:
a.c: In function ‘lencln’: a.c:8:22: warning: suggest parentheses around ‘&&’ within ‘||’ [-Wparentheses] 8 | if(sin[i] >= 'A' && sin[i] <= 'Z' || sin[i] >= 'a' && sin[i] <= 'z'){ | ~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~ a.c: In function ‘clean’: a.c:23:22: warning: suggest parentheses around ‘&&’ within ‘||’ [-Wparentheses] 23 | if(sin[i] >= 'A' && sin[i] <= 'Z' || sin[i] >= 'a' && sin[i] <= 'z') { | ~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~tak bych začal tím. Dále bývá zvykem přiložit vstup, na kterém to spadne (např. jestli když tady testuješ písmenka, tak musí mít vstup čísla nebo tak něco), ale naštěstí mi to spadlo na prvním co jsem zadal. A ta chyba je podle mě v tom, že alokuješ str_cln mallocem (neinicializované), nikde do toho nenapíšeš terminující nulu a pak se to pokusíš printfnout. No a printf čte a čte a čte, až narazí na konec. Takže tam přidej na konec clean
str_cln[j] = 0;
nebo alokuj callocem, ten ti to vynuluje.
Plus dávám za použití satanizéru, který zjevně alokovanou paměť otravuje, protože když to zkompiluju bez něj, tak mi většinou malloc vrátí nuly (byť podle specifikace tam může být cokoli), protože heap je na začátku vynulovaný aby tam nebyla tajná data předchozích procesů, a chyba se tak hned neprojeví.
Tiskni Sdílej: