Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

Исполняется ли приложение в консоли? (std::cin) - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ CreateProcess с совместимостью Win95 (програмно) http://www.cyberforum.ru/cpp/thread646964.html
Странный, возможно кому-то покажется что даже идиотский вопрос: как програмно установить параметрами запуска процесса совместимость с Win95?:scratch: Собственно как использовать ShellExecute и...
C++ Подскажите тему для дипломной работы В прошлом году делал курсовую работу, в которой выявлялось преимущество параллельного программирования с помощью OpenMP над последовательным программированием, перемножением двух квадратных матриц... http://www.cyberforum.ru/cpp/thread646785.html
Авто-расположения скобок в visual studio C++
Сейчас, при нажатии Enter, это выглядит так: int parser(){ } а нужно: int parser() {
Как создают маленькие приложения? (размером до ~50-70Кб) C++
Доброго времени суток! Этот вопрос (Subject) меня интересует уже достаточно давно. Мне постоянно попадаются разнообразные оконные приложения, например: 1. FreeMemory 2. Разнообразные модули...
C++ Сменный График работы на месяц http://www.cyberforum.ru/cpp/thread638507.html
Всем Здравствуйте! Столкнулся с нестандартной задачей. Необходимо сделать График работы на месяц. Кто сталкивался с данной задачей?! Может есть какието наработки или идеи. Вообщем меня...
C++ Секция resource подскажите. вот у меня есть в файлах ексешных секция .rsrc только там данные размещены не последовательно.. т.е. между данными есть пустые места... подробнее

Показать сообщение отдельно
Super-Windоws
337 / 4 / 1
Регистрация: 29.11.2011
Сообщений: 44
10.09.2012, 17:33
isatty(STDIN_FILENO), интерактивные приложения проверяют так, чтобы ввод был с терминала. Впрочем false не гарантирует того, что приложение запущенно не в консоли, если ввод был перенаправлен. Можно прочитать /proc/%pid%/stat. В ядре выводу этого файла соответствует
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
seq_printf(m, "%d (%s) %c %d %d %d %d %d %u %lu \
%lu %lu %lu %lu %lu %ld %ld %ld %ld %d 0 %llu %lu %ld %lu %lu %lu %lu %lu \
%lu %lu %lu %lu %lu %lu %lu %lu %d %d %u %u %llu %lu %ld\n",
        pid_nr_ns(pid, ns),
        tcomm,
        state,
        ppid,
        pgid,
        sid,
        [B]tty_nr,[/B]
        tty_pgrp,
        task->flags,
        min_flt,
        cmin_flt,
        maj_flt,
        cmaj_flt,
        cputime_to_clock_t(utime),
        cputime_to_clock_t(stime),
        cputime_to_clock_t(cutime),
        cputime_to_clock_t(cstime),
        priority,
        nice,
        num_threads,
        start_time,
        vsize,
        mm ? get_mm_rss(mm) : 0,
        rsslim,
        mm ? (permitted ? mm->start_code : 1) : 0,
        mm ? (permitted ? mm->end_code : 1) : 0,
        (permitted && mm) ? mm->start_stack : 0,
        esp,
        eip,
        /* The signal information here is obsolete.
         * It must be decimal for Linux 2.0 compatibility.
         * Use /proc/#/status for real-time signals.
         */
        task->pending.signal.sig[0] & 0x7fffffffUL,
        task->blocked.sig[0] & 0x7fffffffUL,
        sigign      .sig[0] & 0x7fffffffUL,
        sigcatch    .sig[0] & 0x7fffffffUL,
        wchan,
        0UL,
        0UL,
        task->exit_signal,
        task_cpu(task),
        task->rt_priority,
        task->policy,
        (unsigned long long)delayacct_blkio_ticks(task),
        cputime_to_clock_t(gtime),
        cputime_to_clock_t(cgtime));
Bash
1
3716 (su) S 3715 3716 3715 [B]34820[/B] 3827 4202496 493 0 0 0 0 0 0 0 1 0 1 0 668987 28278784 304 18446744073709551615 4194304 4224060 140733845056096 140733845055464 139888566114810 0 2147196671 0 16384 0 0 0 17 0 0 0 0 0 0 6323664 6325088 37474304 140733845060170 140733845060173 140733845060173 140733845061616 0
Bash
1
3563 (CrRendererMain) S 2598 2266 2266 [B]0[/B] -1 4202560 58179 0 8 0 201 9 0 0 1 5 4 0 561250 912637952 11861 18446744073709551615 140406614044672 140406690472986 140734964772656 140734964767952 140406548774081 0 0 67112962 1073807360 18446744073709551615 0 0 17 2 0 0 0 0 0 140406692570992 140406695300688 140406717243392 140734964779567 140734964779608 140734964779608 140734964781021 0
видно, да, чем отличается консольное от гуёвого? по этому числу кстати можно определить имя терминала(как ttyname только вручную), формула этого числа (minor & 0xff) | (major << 8) | ((minor & ~0xff) << 12), где minor и major числа, которые мы можем лицезреть в ls -l /dev/*. В твоём случае можно проверить просто равно ли это число нулю
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru