- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在用 C++ 编写一个词法分析器,我能够编译该程序并将其链接得很好;然而,在运行它时,我得到了大量的输出转储,我不知道为什么会这样,或者它是否与我编写的程序有关。我什至无法复制整个转储,但这是一个 gif它的发生。这是一个很好的衡量标准的程序。
我已经在 Windows 10 上用 cygwin 编译和运行了。
token.h
#ifndef TOKEN_H
#define TOKEN_H
#include <string>
class ice_lexer;
enum ice_type_enum {
ICE_NONE,
ICE_EOF,
ICE_MODULE,
ICE_IDENT,
ICE_FLT,
ICE_NUM,
ICE_STR,
// SYMBOLS
ICE_RPARA,
ICE_LPARA,
ICE_RBRAC,
ICE_LBRAC,
ICE_RCURL,
ICE_LCURL,
ICE_PERIOD,
ICE_COLON,
ICE_SEMIC,
ICE_COMMA,
// COMPARISON
ICE_EQLTO,
ICE_NOTEQL,
ICE_GRT,
ICE_GRTEQL,
ICE_LES,
ICE_LESEQL,
// ASSIGNMENT
ICE_EQL,
ICE_ADDEQL,
ICE_SUBEQL,
ICE_MULEQL,
ICE_DIVEQL,
ICE_CAREQL,
// URNARY
ICE_URNARYNOT,
ICE_URNARYSUB,
// BINARY
ICE_ADD,
ICE_SUB,
ICE_MUL,
ICE_DIV,
ICE_MOD,
ICE_CAR,
ICE_CAT,
// TERNARY
ICE_TERNARY,
// KEYWORDS
ICE_IMPORT,
ICE_AS,
ICE_WHILE,
ICE_FOR,
ICE_BREAK,
ICE_IF,
ICE_RETURN,
ICE_TRUE,
ICE_FALSE,
// TYPES
ICE_TYPEDEF,
ICE_CLASS,
ICE_ENUM,
ICE_INT,
ICE_FLOAT,
ICE_STRING,
ICE_BOOLEAN,
ICE_VOID,
ICE_STRUCT
};
typedef struct ice_keyword {
std::string word;
ice_type_enum type;
} ice_keyword;
class ice_type {
public:
std::string string;
ice_type_enum type;
ice_type(ice_type_enum t);
};
class ice_token {
public:
ice_type type;
size_t line;
size_t pos;
std::string str;
double flt;
size_t num;
ice_token(const ice_lexer* lexer, ice_type_enum t);
~ice_token() {};
void print();
};
#endif
token.cpp
#include <string>
#include <iostream>
#include "token.h"
#include "lexer.h"
static const std::string ice_type_enum_strings[] = {
// ABSTRACT
"no type",
"end of file",
"module",
"identifier",
"floating",
"number",
"string",
// SYMBOLS
"left para",
"right para",
"left brac",
"right brac",
"left curl",
"right curl",
"period",
"colon",
"semi",
"comma",
// COMPARISON
"eql to",
"not eql",
"grt",
"grt eql",
"les",
"les eql",
// ASSIGNMENT
"eql",
"add eql",
"sub eql",
"mul eql",
"div eql",
"car eql",
// URNARY
"urnarynot",
"urnarysub",
// BINARY
"add",
"sub",
"mul",
"div",
"mod",
"car",
"cat",
// TERNARY
"ternary",
// KEYWORDS
"import",
"as",
"while",
"for",
"break",
"if",
"return",
"true",
"false",
// TYPES
"typedef",
"class",
"enum",
"int",
"float",
"string",
"bool",
"void",
"struct"
};
ice_type::ice_type(ice_type_enum t) {
string = ice_type_enum_strings[t];
type = t;
}
ice_token::ice_token(const ice_lexer* lexer, ice_type_enum t):type(t) {
line = lexer->line;
pos = lexer->pos;
num = 0;
}
void ice_token::print() {
std::cout << "TYPE [ STR: \'" << this->type.string << "\' | ENUM: " << this->type.type << " ]:" << std::endl;
std::cout << "\tLINE NO. " << this->line << " IN THE " << this->pos << "TH ROW" << std::endl;
if (this->type.type == ICE_NUM)
std::cout << "\tNUMBER VALUE: \'" << this->num << "\'" << std::endl;
if (this->type.type == ICE_FLT)
std::cout << "\tFLOAT VALUE: \'" << this->flt << "\'" << std::endl;
if (this->type.type != ICE_NUM && this->type.type != ICE_FLT)
std::cout << "\tSTR VALUE: \'" << this->str << "\'" << std::endl;
}
lexer.h
#ifndef LEXER_H
#define LEXER_H
#include "token.h"
#include <string>
class ice_token;
#define newline() { \
this->line++; \
this->pos = 0; \
}
class ice_lexer {
public:
std::string source;
size_t length;
size_t line;
size_t pos;
size_t ptr;
ice_lexer(std::string file_name);
~ice_lexer() {};
ice_token lexer_next();
private:
const char look(int offset);
const char advance(int offset);
void comment(void);
void nested(void);
ice_token symbol(ice_type_enum type, std::string string, int move);
void ident(void);
};
#endif
lexer.cpp
#include <fstream>
#include <string>
#include <assert.h>
#include "token.h"
#include "lexer.h"
extern const ice_keyword keywords[] = {
{"import", ICE_IMPORT},
{"as", ICE_AS},
{"while", ICE_WHILE},
{"for", ICE_FOR},
{"break", ICE_BREAK},
{"if", ICE_IF},
{"return", ICE_RETURN},
{"true", ICE_TRUE},
{"false", ICE_FALSE},
{"typedef", ICE_TYPEDEF},
{"class", ICE_CLASS},
{"enum", ICE_ENUM},
{"int", ICE_INT},
{"float", ICE_FLOAT},
{"string", ICE_STRING},
{"bool", ICE_BOOLEAN},
{"void", ICE_VOID},
{"struct", ICE_STRUCT}
};
ice_lexer::ice_lexer(std::string file_name) {
std::ifstream input_file(file_name);
std::string content((std::istreambuf_iterator<char>(input_file)),
(std::istreambuf_iterator<char>()));
line = 1;
pos = 0;
ptr = 0;
}
const char ice_lexer::look(int offset = 0) {
if (this->ptr + offset < this->length)
return '\0';
return this->source[this->ptr + offset];
}
const char ice_lexer::advance(int offset) {
assert(this->ptr + offset < this->length);
return look();
}
void ice_lexer::comment(void) {
while (look() != '\n') { advance(1); }
newline();
}
void ice_lexer::nested(void) {
size_t depth = 1;
while (depth > 0) {
if (look(0) == '\\' && look(1) == '\\') {
advance(2);
depth--;
} else if (look(0) == '/' && look(1) == '/') {
advance(2);
depth++;
} else {
advance(1);
}
}
}
ice_token ice_lexer::symbol(ice_type_enum type, std::string string, int move) {
ice_token token(this, type);
token.str = string;
advance(move);
return token;
}
ice_token ice_lexer::lexer_next() {
/*
while (look() != '\0') {
switch (look()) {
case '+':
if (look(1) == '=')
return symbol(ICE_ADDEQL, "+=", 2);
else
return symbol(ICE_ADD, "+", 1);
break;
case '-':
if (look(1) == '=')
return symbol(ICE_ADDEQL, "+=", 2);
else
return symbol(ICE_SUB, "-", 1);
break;
case '*':
if (look(1) == '=')
return symbol(ICE_ADDEQL, "+=", 2);
else
return symbol(ICE_MUL, "*", 1);
break;
case '/':
if (look(1) == '=')
return symbol(ICE_DIVEQL, "/=", 2);
else if(look(1) == '/')
nested();
else
return symbol(ICE_DIV, "/", 1);
break;
case '^':
if (look(1) == '=')
return symbol(ICE_CAREQL, "^=", 2);
else
return symbol(ICE_CAR, "^", 1);
break;
case '~':
comment();
case '(':
return symbol(ICE_LPARA, "(", 1);
break;
case ')':
return symbol(ICE_RPARA, ")", 1);
break;
case '[':
return symbol(ICE_LBRAC, "[", 1);
break;
case ']':
return symbol(ICE_RBRAC, "]", 1);
break;
case '{':
return symbol(ICE_LCURL, "{", 1);
break;
case '}':
return symbol(ICE_RCURL, "}", 1);
break;
default:
break;
}
}
*/
}
最佳答案
我做了一些更改,并且有点让它工作了。您正在做的一些事情有点靠不住。
ice_lexer::ice_lexer(std::string file_name) {
std::ifstream input_file(file_name);
std::string content((std::istreambuf_iterator<char>(input_file)),
(std::istreambuf_iterator<char>()));
line = 1;
pos = 0;
ptr = 0;
}
您正在将文件读入 content
,这是一个局部变量。您可能打算将其读入 source
.您也没有更新 length
,我猜应该是 source.size()
.
ice_lexer::look()
中存在错误:
const char ice_lexer::look(int offset = 0) {
if (this->ptr + offset < this->length)
return '\0';
return this->source[this->ptr + offset];
}
条件应该是>=
, 不是 <
. ice_lexer::advance()
中的另一个类似错误:
const char ice_lexer::advance(int offset) {
assert(this->ptr + offset < this->length);
return look();
}
应该是<=
.
当您在控制台上看到垃圾时,通常意味着您正在打印一个没有 \0
的字符串。最后,它只是在内存中逃跑,直到找到 \0
。某处。如果您在不该去的地方阅读,它也可能会崩溃。这反过来可能意味着您有未初始化的变量。
学习正确使用调试器。通过逐步执行函数和查看变量,这很容易弄清楚。
关于c++ - Cygwin 控制台转储大量神秘输出然后键入 1;2;6;22c,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39049917/
我正在使用 OUTFILE 命令,但由于权限问题和安全风险,我想将 shell 的输出转储到文件中,但出现了一些错误。我试过的 #This is a simple shell to connect t
我刚刚开始学习 Java,我想克服在尝试为这个“问题”创建 Java 程序时出现的障碍。这是我必须创建一个程序来解决的问题: Tandy 喜欢分发糖果,但只有 n 颗糖果。对于她给第 i 个糖果的人,
你好,我想知道我是否可以得到一些帮助来解决我在 C++ 中打印出 vector 内容的问题 我试图以特定顺序在一个或两个函数调用中输出一个类的所有变量。但是我在遍历 vector 时收到一个奇怪的错误
我正在将 intellij (2019.1.1) 用于 java gradle (5.4.1) 项目,并使用 lombok (1.18.6) 来自动生成代码。 Intellij 将生成的源放在 out
编辑:在与 guest271314 交流后,我意识到问题的措辞(在我的问题正文中)可能具有误导性。我保留了旧版本并更好地改写了新版本 背景: 从远程服务器获取 JSON 时,响应 header 包含一
我的问题可能有点令人困惑。我遇到的问题是我正在使用来自 Java 的 StoredProcedureCall 调用过程,例如: StoredProcedureCall call = new Store
在我使用的一些IDL中,我注意到在方法中标记返回值有2个约定-[in, out]和[out, retval]。 当存在多个返回值时,似乎使用了[in, out],例如: HRESULT MyMetho
当我查看 gar -h 的帮助输出时,它告诉我: [...] gar: supported targets: elf64-x86-64 elf32-i386 a.out-i386-linux [...
我想循环遍历一个列表,并以 HTML 格式打印其中的一部分,以代码格式打印其中的一部分。所以更准确地说:我想产生与这相同的输出 1 is a great number 2 is a great
我有下面的tekton管道,并尝试在Google Cloud上运行。集群角色绑定。集群角色。该服务帐户具有以下权限。。例外。不确定需要为服务帐户设置什么权限。
当尝试从 make 过滤非常长的输出以获取特定警告或错误消息时,第一个想法是这样的: $ make | grep -i 'warning: someone set up us the bomb' 然而
我正在创建一个抽象工具类,该类对另一组外部类(不受我控制)进行操作。外部类在某些接口(interface)点概念上相似,但访问它们相似属性的语法不同。它们还具有不同的语法来应用工具操作的结果。我创建了
这个问题已经有答案了: What do numbers starting with 0 mean in python? (9 个回答) 已关闭 7 年前。 在我的代码中使用按位与运算符 (&) 时,我
我写了这段代码来解析输入文件中的行输入格式:电影 ID 可以有多个条目,所以我们应该计算平均值输出:**没有重复(这是问题所在) import re f = open("ratings2.txt",
我需要处理超过 1000 万个光谱数据集。数据结构如下:大约有 1000 个 .fits(.fits 是某种数据存储格式)文件,每个文件包含大约 600-1000 个光谱,其中每个光谱中有大约 450
我编写了一个简单的 C 程序,它读取一个文件并生成一个包含每个单词及其出现频率的表格。 该程序有效,我已经能够在 Linux 上运行的终端中获得显示的输出,但是,我不确定如何获得生成的显示以生成包含词
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
1.普通的输出: print(str)#str是任意一个字符串,数字··· 2.格式化输出: ?
我无法让 logstash 正常工作。 Basic logstash Example作品。但后来我与 Advanced Pipeline Example 作斗争.也许这也可能是 Elasticsear
这是我想要做的: 我想让用户给我的程序一些声音数据(通过麦克风输入),然后保持 250 毫秒,然后通过扬声器输出。 我已经使用 Java Sound API 做到了这一点。问题是它有点慢。从发出声音到
我是一名优秀的程序员,十分优秀!