Ministerstvo pro místní rozvoj (MMR) jako první orgán státní správy v Česku spustilo takzvaný „bug bounty“ program pro odhalování bezpečnostních rizik a zranitelných míst ve svých informačních systémech. Za nalezení kritické zranitelnosti nabízí veřejnosti odměnu 1000 eur, v případě vysoké závažnosti je to 500 eur. Program se inspiruje přístupy běžnými v komerčním sektoru nebo ve veřejné sféře v zahraničí.
Vláda dne 16. července 2025 schválila návrh nového jednotného vizuálního stylu státní správy. Vytvořilo jej na základě veřejné soutěže studio Najbrt. Náklady na přípravu návrhu a metodiky činily tři miliony korun. Modernizovaný dvouocasý lev vychází z malého státního znaku. Vizuální styl doprovází originální písmo Czechia Sans.
Vyhledávač DuckDuckGo je podle webu DownDetector od 2:15 SELČ nedostupný. Opět fungovat začal na několik minut zhruba v 15:15. Další služby nesouvisející přímo s vyhledáváním, jako mapy a AI asistent jsou dostupné. Pro některé dotazy během výpadku stále funguje zobrazování například textu z Wikipedie.
Více než 600 aplikací postavených na PHP frameworku Laravel je zranitelných vůči vzdálenému spuštění libovolného kódu. Útočníci mohou zneužít veřejně uniklé konfigurační klíče APP_KEY (např. z GitHubu). Z více než 260 000 APP_KEY získaných z GitHubu bylo ověřeno, že přes 600 aplikací je zranitelných. Zhruba 63 % úniků pochází z .env souborů, které často obsahují i další citlivé údaje (např. přístupové údaje k databázím nebo cloudovým službám).
Open source modální textový editor Helix, inspirovaný editory Vim, Neovim či Kakoune, byl vydán ve verzi 25.07. Přehled novinek se záznamy terminálových sezení v asciinema v oznámení na webu. Detailně v CHANGELOGu na GitHubu.
Americký výrobce čipů Nvidia získal od vlády prezidenta Donalda Trumpa souhlas s prodejem svých pokročilých počítačových čipů používaných k vývoji umělé inteligence (AI) H20 do Číny. Prodej těchto čipů speciálně upravených pro čínský trh by tak mohl být brzy obnoven, uvedla firma na svém blogu. Americká vláda zakázala prodej v dubnu, v době eskalace obchodního sporu mezi oběma zeměmi. Tehdy to zdůvodnila obavami, že by čipy mohla využívat čínská armáda.
3D software Blender byl vydán ve verzi 4.5 s prodlouženou podporou. Podrobnosti v poznámkách k vydání. Videopředstavení na YouTube.
Open source webový aplikační framework Django slaví 20. narozeniny.
V Brestu dnes začala konference vývojářů a uživatelů linuxové distribuce Debian DebConf25. Na programu je řada zajímavých přednášek. Sledovat je lze online.
Před 30 lety, tj. 14. července 1995, se začala používat přípona .mp3 pro soubory s hudbou komprimovanou pomocí MPEG-2 Audio Layer 3.
Dobrý den, konečně jsem si udělal čas a začal se učit céčko, mám problém, pokoušel jsem se o prográmek, ktrerý naplní pole hodnotami indexů, vytiske, pak vynuluje a znova vytiskne, bohužel, nevím, kde je problém, ale nenuluje ho správně:
#include <stdio.h> int main() { int pole[10], i,a; for (i=0;i<10;i++) { pole[i]=i; } int *ppole; ppole = &pole; for (a=0;a<10;a++) { printf("%d:\t%d\n", a, *(ppole + a)); } while(ppole <= &pole[9]) { *(ppole++)=0; } for (a=0;a<10;a++) { printf("%d:\t%d\n", a, *(ppole++)); } return 0; }
výstup je pak zhruba následující:
david@PC1 /home/david/texty/programovani/cecko $ ./36-ukazatel_s_polem 0: 0 1: 1 2: 2 3: 3 4: 4 5: 5 6: 6 7: 7 8: 8 9: 9 0: 10 1: 1 2: -1074194984 3: -1074194944 4: 0 5: 1105578095 6: 1091910816 7: 134513744 8: 0 9: 1105578095
jako by to nějak přetěkalo, nebo co, použiji-li for cyklus, jede to, takhle ne, chybu tam prostě nevidím, netušíte někdo? Předem díky moc...
PS: takhle to mám, abych si procvičil ukazatele s poly
ppole
jste nenastavil znovu na začátek pole.
-lefence
V tomto případě sice nepomůže (protože se jedná o zásobník), ale jinak je to naprosto nutná věc.
#include stdio.h
int main() {
int pole[10], i,a;
for (i=0;i<10;i++) {
pole[i]=i;
}
int *ppole;
ppole = &pole;
for (a=0;a<10;a++) {
printf("%d:\t%d\n", a, *(ppole + a));
}
while(ppole <= &pole[9]) {
*(ppole++)=0; // tu sa posuva adresa o prvok dalej
}
// teda ukazovatel na konci cyklu while ukazuje na koniec pola
ppole = &pole;
for (a=0;a<10;a++) {
printf("%d:\t%d\n", a, *(ppole++));
}
return 0;
}
#include <string.h> void foo() { int pole[DELKA_POLE]; ... memset(pole, 0, sizeof(pole)); ... }
void foo() { int pole[DELKA_POLE] = {0}; ... }
int pole[10] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0};což by u velkých polí byla docela otrava
#include <stdio.h> #include <stdlib.h> #include <string.h> #define N (10) int tisknipole(int *pole){ int i; for (i = 0; i < N; i++){ printf("%10d. %10d\n", i, pole[i]); } return 0; } int main(int argc, char** argv){ int pole[N] = {1}; tisknipole(pole); return 0; }což nainicializovalo pouze nultý prvek. Zřejmě to chápu nějak špatně.
struct S { int i; double d; char c[100]; }; void foo() { struct S s1 = {0}; struct S s2 = {1}; struct S s3 = {1, 1.0}; struct S s4[100] = {0}; }
int pole[10] = {1, 2, 3}
Překvapuje mě, že tahle část dělá to, co se od ní očekává. Jeden by si myslel, že se doppole = &pole; for (a=0;a<10;a++) { printf("%d:\t%d\n", a, *(ppole + a)); }
ppole
uloží ukazatel na ukazatel na pole, zvlášt když gcc nadává, že
sileny_pointry.c:11: warning: assignment from incompatible pointer type
int pole[10];
...
int *ppole;
ppole = &pole;
Vyznačený riadok je zle. Má byť
ppole=pole;
pole
je výraz typu int*
, ale &pole
je int**
.
&pole
je typu int(*)[10]
.
int pole[10];není totéž co
int *pole; pole = (int *) malloc(10 * sizeof(*pole));
pole
ukazuje na prvni prvek pole a &pole
ukazuje na zacatek pole. prvni prvek pole je ovsem jeho zacatkem, takze pole == &pole
plati.
.-------. .------. | &pole | ---> | pole | ----------. `-------' `------' | v .---.---.---.- - | | | | `---'---'---'- -pole == &pole platí jen a pouze tehdy, pokud pole ukazuje samo na sebe, což by vypadalo takto:
.-------. .------. | &pole | ---> | pole | -----. `-------' `------' | ^ | | | `-------------------------'
&pole je adresa pointeru na prvni prvek poleNe, žádný takový pointer v diskutované situaci neexistuje.
pole
) je non-l-value.
Každopádně bych zápis &pole raději ani nepovoloval, protože je matoucí.
int neni_zle() { int pole[10]; return &pole == &pole[0]; }
test.cpp:6: error: comparison between distinct pointer types ‘int (*)[10]’ and ‘int*’ lacks a castPorovnat můžete
pole
a &pole[0]
, výsledkem bude true.
int neni_zle() { int pole[10]; return reinterpret_cast< void *>(&pole) == reinterpret_cast< void *>(&pole[0]); }
#include <stdio.h> #include <stdlib.h> #include <string.h> #define N (100) int tisknipole(int *pole){ int i; for (i = 0; i < N; i++){ printf("%10d. %10d\n", i, pole[i]); } return 0; } int main(int argc, char** argv){ int *pole; int i; pole = (int *) malloc(N * sizeof(*pole)); if (!pole){ printf("Out of memory\n"); return -1; } for (i = 0; i < N; i++) pole[i] = i; tisknipole(pole); memset(pole, 0, N*sizeof(*pole)); tisknipole(pole); free(pole); return 0; }
int pole[10000000];Dostanete segmentation fault a dost špatně se to debugguje. Navíc pole o pevné velikosti většinou plýtvá pamětí (protože se tam nacpe raději víc než míň), při požadavku na změnu velikost pole se musí překompilovávat, do toho pointeru se nedá zapsat třeba NULL (což se občas může hodit).
Tiskni
Sdílej: