Win8DE je desktopové prostředí pro Wayland, inspirované nechvalně proslulým uživatelským rozhraním Metro z Windows 8. Nabízí dlaždicové rozhraní s velkými tlačítky a jednoduchou navigací, optimalizované pro dotyková zařízení. Cílem projektu je přetvořit design operačního systému Windows 8 do funkčního a minimalistického rozhraní vhodného pro každodenní použití na Linuxu.
Laboratoře CZ.NIC vydaly Datovku 4.28.0 a Mobilní Datovku 2.6.0. Hlavní novinkou je ukládání rozpracovaných datových zpráv do konceptů. Datovka je svobodné multiplatformní aplikace pro přístup k datovým schránkám a k trvalému uchovávání datových zpráv v lokální databázi.
Unix Pipe Game je vzdělávací karetní hra zaměřená na děti a rodiče, která děti učí používat unixové příkazy prostřednictvím interaktivních úkolů. Klíčovým prvkem hry je využití symbolu | pro pipeline neboli 'rouru', který umožňuje propojit výstupy a vstupy jednotlivých unixových příkazů, v tomto případě vytištěných na kartičkách. Předpokládá se, že rodič má alespoň nějaké povědomí o unixových příkazech a jejich provazování pomocí |.
… více »PCIem je linuxový framework, který vytváří virtuální zařízení PCIe pomocí technik, které umožňují hostitelskému operačnímu systému rozpoznat tyto syntetické 'neexistující' karty jako fyzické zařízení přítomné na sběrnici. Framework PCIem je primárně zamýšlen jako pomůcka pro vývoj a testování ovladačů bez nutnosti použít skutečný hardware. Dle tvrzení projektu si fungování PCIem můžeme představit jako MITM (Man-in-the-Middle), který se nachází mezi ovladači a kernelem.
Byla nalezena vážná bezpečnostní chyba v telnetd z balíčku GNU InetUtils. Týká se verzí GNU InetUtils od 1.9.3 z 12. května 2015 až po aktuální 2.7 z 14. prosince 2025. Útočník může obejít autentizaci a získat root přístup, jelikož telnetd nekontroluje předaný obsah proměnné prostředí USER a pokud obsahuje "-f root"…
Stanislav Aleksandrov předložil patch rozšiřující KWin (KDE Plasma) na 3D virtuální desktopové prostředí (videoukázka v mp4).
Digg (Wikipedie), "místo, kde můžete sdílet a objevovat to nejlepší z internetu – a nejen to", je zpět. Ve veřejné betě.
Po .deb balíčcích Mozilla nově poskytuje také .rpm balíčky Firefoxu Nightly.
Vývojové prostředí IntelliJ IDEA slaví 25. narozeniny (YouTube).
Vedení společnosti NVIDIA údajně povolilo použití milionů knih ze známého 'warez' archivu Anna's Archive k výcviku umělé inteligence, ačkoliv vědělo, že archiv tyto knihy nezískal legální cestou. Žaloba, ve které se objevují i citace interních dokumentů společnosti NVIDIA, tvrdí, že NVIDIA přímo kontaktovala Anna's Archive a požadovala vysokorychlostní přístup k datům knihovny.
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}
ppole = &pole;
for (a=0;a<10;a++) {
printf("%d:\t%d\n", a, *(ppole + a));
}
Překvapuje mě, že tahle část dělá to, co se od ní očekává. Jeden by si myslel, že se do 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: