Нет сообщений об ошибках или cout на консоли Cygwin - PullRequest
3 голосов
/ 19 января 2012

Я установил Cygwin на свой компьютер с Windows7 и запускаю некоторый код на С ++.Когда я запускаю этот код:

#include <iostream>
#include <string>
#include <fstream>
#include <time.h>
#include <math.h>
#include "Pop.h"
using namespace std;


int main() {
  ifstream in;
  ofstream out;
  cout << "something";
  out.open("res7.txt", ios::out|ios::app);
  if (out.is_open())
    out << "1\n";
  else
    cout << "unable to open res7 file";
  out.close();
  int seed = time(NULL);
  out.open("res7.txt", ios::out|ios::app);
  if (out.is_open())
    out << "2\n";
  else
    cout << "unable to open res7 file";
  out.close();
  out.open("res7.txt", ios::out|ios::app);
  if (out.is_open())
    out << "seed " << seed << '\n';
  else
    cout << "unable to open res7 file";
  out.close();
  out.open("res7.txt", ios::out|ios::app);
  if (out.is_open())
    out << "3\n";
  else
    cout << "unable to open res7 file";
  out.close();
  srand (seed);
  out.open("res7.txt", ios::out|ios::app);
  if (out.is_open())
    out << "4\n";
  else
    cout << "unable to open res7 file";
  out.close();
  double parameters[4];
  int location;
  in.open("input7.txt", ios::in);
  out.open("res7.txt", ios::out|ios::app);
  if (out.is_open())
    out << "5\n";
  else
    cout << "unable to open res7 file";
  out.close();
  return 0;
}

Я вижу вывод на консоли (что-то).Но когда я запускаю свой полный код:

#include <iostream>
#include <string>
#include <fstream>
#include <time.h>
#include <math.h>
#include "Pop.h"
using namespace std;


int main() {
  ifstream in;
  ofstream out;
  cout << "something";
  out.open("res7.txt", ios::out|ios::app);
  if (out.is_open())
    out << "1\n";
  else
    cout << "unable to open res7 file";
  out.close();
  int seed = time(NULL);
  out.open("res7.txt", ios::out|ios::app);
  if (out.is_open())
    out << "2\n";
  else
    cout << "unable to open res7 file";
  out.close();
  out.open("res7.txt", ios::out|ios::app);
  if (out.is_open())
    out << "seed " << seed << '\n';
  else
    cout << "unable to open res7 file";
  out.close();
  out.open("res7.txt", ios::out|ios::app);
  if (out.is_open())
    out << "3\n";
  else
    cout << "unable to open res7 file";
  out.close();
  srand (seed);
  out.open("res7.txt", ios::out|ios::app);
  if (out.is_open())
    out << "4\n";
  else
    cout << "unable to open res7 file";
  out.close();
  double parameters[4];
  int location;
  in.open("input7.txt", ios::in);
  out.open("res7.txt", ios::out|ios::app);
  if (out.is_open())
    out << "5\n";
  else
    cout << "unable to open res7 file";
  out.close();
     if (in.is_open()) {
    out.open("res7.txt", ios::out|ios::app);
    if (out.is_open())
      out << "6\n";
    else
      cout << "unable to open res7 file";
    out.close();
    char line[256];
    while (!in.getline(line, 256).eof()) {
      out.open("res7.txt", ios::out|ios::app);
      if (out.is_open())
    out << "7\n";
      else
    cout << "unable to open res7 file";
      out.close();
      char *input = strtok(line, " ");
      int i=0;
      while (input!=NULL) {
    out.open("res7.txt", ios::out|ios::app);
    if (out.is_open())
      out << "8\n";
    else
      cout << "unable to open res7 file";
    out.close();
    parameters[i] = atof(input);
    input = strtok(NULL, " ");
    i++;
      }
      int rnum = rand();
      location = rnum%10000;
      out.open("res7.txt", ios::out|ios::app);
      if (out.is_open())
    out << "9\n";
      else
    cout << "unable to open res7 file";
      out.close();
      Pop p(parameters[0], parameters[1], 0.2, 0.1, parameters[2], location);
      out.open("res7.txt", ios::out|ios::app);
      if (out.is_open())
    out << "10\n";
      else
    cout << "unable to open res7 file";
      out.close();
      double L = exp(-parameters[3]);
      double FF_mean = p.FF_steady(parameters[3], L, 0.0);
      out.open("res7.txt", ios::out|ios::app);
      if (out.is_open())
    out << "11\n";
      else
    cout << "unable to open res7 file";
      out.close();
      out.open("res7.txt", ios::out|ios::app);
      if (out.is_open()) {
    out << "number of chromosomes is " << p.all_population[0]->ga->chromosome << "  alpha is " << parameters[2] << "  cost is " << parameters[1];
    out << "  a is " << parameters[0] << "  u is " << parameters[3] << "  location is " << location << "  FF steady is " << FF_mean << '\n';
      }
      else
    cout << "unable to open res7 file FF";
      out.close();
      out.open("res7.txt", ios::out|ios::app);
      if (out.is_open())
    out << "12\n";
      else
    cout << "unable to open res7 file";
      out.close();
      if (FF_mean>0.1) {
    out.open("res7.txt", ios::out|ios::app);
    if (out.is_open())
      out << "13\n";
    else
      cout << "unable to open res7 file";
    out.close();
    p.insert_O(0.05);
    out.open("res7.txt", ios::out|ios::app);
    if (out.is_open())
      out << "14\n";
    else
      cout << "unable to open res7 file";
    out.close();
    double total_mean = p.steady(parameters[3], L, 0.0);
    double perc = p.perc_O();
    out.open("res7.txt", ios::out|ios::app);
    if (out.is_open())
      out << "total steady is " << total_mean << "   perc O is " << perc << '\n';
    else
      cout << "unable to open res7 file";
    out.close();
      }
    }
  }
  else
    cout << "Unable to open input7 file\n";
    in.close();
  return 0;
}

, я не вижу никаких выводов на консоли.Когда я запускаю код на другом компьютере, я вижу, что у меня есть исключение с плавающей запятой.Я думаю, я мог бы найти, где это находится, но я не понимаю, почему я не вижу вывод или ошибка на консоли в Cygwin.Кто-нибудь может мне помочь?

Ответы [ 2 ]

0 голосов
/ 18 сентября 2012

Во-первых, исключение может прервать программу, даже не предоставив информацию.Cygwin - это попытка объединить Windows и Unix, и вещи не всегда работают идеально.

Во-вторых, std::cout - это буферный поток.Таким образом, каждый operator<< добавляет в буфер до тех пор, пока либо буфер не заполнится и он не будет автоматически выведен, вы явно очистите буфер с помощью cout.flush(), либо неявно очистите буфер, такой как std::endl, это вызовет.

Итак, вам нужно использовать отладчик или другую систему, чтобы найти ошибку и исправить ее.Вам также необходимо провести тестирование на нескольких платформах, поскольку на разных устройствах все происходит по-разному, включая разные ошибки и даже видимость работы.

0 голосов
/ 19 января 2012

Вы уверены, что код компилируется?С третьей до последней строки у вас есть

in.close();*/

Однако, нет открывающего тега / *.Я хотел бы убедиться, что ваш код на самом деле компилируется, и у вас есть новый сгенерированный .exe.Возможно, вам не удается скомпилировать и запустить старый .exe-файл, у которого нет никаких cout-файлов.

Кроме того, вы уверены, что не генерируются исключения?Я не могу полностью протестировать код, потому что мне не хватает исходного кода для «Pop.h», поэтому я не могу полностью увидеть, какие ошибки я получаю при компиляции.Не могли бы вы попытаться сделать начальный cout в верхней части вашей программы и, возможно, предоставить соучастие в Pop.h, чтобы мы могли проверить его больше.

...