- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试用 C 语言创建一个词法分析器。程序读取另一个程序作为输入,将其转化为token,源码在这里-
#include <stdio.h>
#include <conio.h>
#include <string.h>
int main() {
FILE *fp;
char read[50];
char seprators [] = "\n";
char *p;
fp=fopen("C:\\Sum.c", "r");
clrscr();
while ( fgets(read, sizeof(read)-1, fp) !=NULL ) {
//Get the first token
p=strtok(read, seprators);
//Get and print other tokens
while (p!=NULL) {
printf("%s\n", p);
p=strtok(NULL, seprators);
}
}
return 0;
}
而Sum.c的内容是-
#include <stdio.h>
int main() {
int x;
int y;
int sum;
printf("Enter two numbers\n");
scanf("%d%d", &x, &y);
sum=x+y;
printf("The sum of these numbers is %d", sum);
return 0;
}
我没有得到正确的输出,只看到一个空白屏幕而不是输出。
谁能告诉我哪里出错了??提前非常感谢..
最佳答案
自从这个问题之后你问了几个问题,所以我想你已经继续了。关于您的问题和您开始的解决方案可以帮助其他人开始解决类似问题,有几件事需要注意。 You'll also find that people can often be slow at answering things that are obvious homework .我们经常等到作业截止日期过去了。 :-)
首先,我注意到您使用了一些特定于 Borland C 编译器的非标准功能,并且不会使解决方案具有可移植性或通用性。你可以在没有他们的情况下很好地解决问题,这通常是一个不错的选择。例如,您使用了 #include <conio.h>
只是为了clear the screen with a clrscr();
这可能是不必要的,并且与词法分析器问题无关。
我测试了该程序,并且按照编写的那样运行!它转录文件的所有行 Sum.c
至 stdout
.如果您只看到一个空白屏幕,那是因为找不到该文件。要么你没有把它写到你的 C:\
目录或具有不同的名称。正如@WhozCraig 已经提到的 you need to check that the file was found and opened properly .
我看到您正在使用 C 函数 strtok
将输入分成标记。有一些nice examples of using this in the documentation you could include in your code ,它比您的简单案例做得更多。正如@Grijesh Chauhan 所提到的,有比 \n
更多的分隔符需要考虑。 , 或行尾。例如,空格和制表符。
然而,在程序中,事物并不总是由空格和行分隔。举个例子:
result=(number*scale)+total;
如果我们只使用空格作为分隔符,那么它不会识别所使用的单词,只会提取整个表达式,这显然不是分词。我们可以将这些东西添加到分隔符列表中:
char seprators [] = "\n=(*)+;";
然后您的代码也会挑选出这些词。该策略仍然存在缺陷,因为在编程语言中,那些符号也是需要识别的标记。编程语言标记化的问题是标记之间没有明确的分隔符。
这背后有很多理论,但基本上我们必须写下构成我们想要识别的标记基础的模式,而不是查看它们之间的差距,因为正如已经表明的那样,没有'没有!这些模式通常写为 regular expressions .计算机科学理论告诉我们,我们可以使用finite state automata来匹配这些正则表达式。 Writing a lexer involves a particular style of coding ,具有这种风格:
while ( NOT <<EOF>> ) {
switch ( next_symbol() ) {
case state_symbol[1]:
....
break;
case state_symbol[2]:
....
break;
default:
error(diagnostic);
}
}
所以,现在,也许学术作业的值(value)变得更加清晰。
关于在 C 中创建词法分析器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18396165/
我最近开始使用 Scala 编程。我正在寻找免费的 Scala 分析器。从该语言的官方网站阅读后,我找到了 YourKit ,但该程序不是免费的。 谷歌搜索“scala profiler”没有给我任何
是否有一个程序可以让我获得有关脚本的详细信息:具体来说,我希望能够跟踪其内存占用情况并查看内存中有多少对象。 Firebug 有一个分析器,似乎可以提供计时信息,但我对内存管理更感兴趣。 最佳答案 G
Erlang 有没有好的代码分析器/分析器?我需要一些可以为我的代码构建调用图的东西。 最佳答案 对于静态代码分析,您有 Xref和 Dialyzer ,对于分析,您可以使用 cprof、fprof
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
什么是“self”和“total”列? “总计”列加起来不等于 100%(高得多),看起来像 self 一样。我怀疑 self 是非累积的,而 total 是。因此,如果 methodA 调用 met
在 Perl 中,有一个非常好的分析器,称为 NYTProf。 在其报告中包含 flame graph ,这样就很容易找到程序的瓶颈 是否有一个等效的 java profiler 可以生成相同的报告?
我想知道是否有办法在c++程序中查看特定部分的调用路径。我在开源代码中工作,其中包含许多库。我尝试按照最终在模板中的路径中的代码进行操作。那么,是否有这样的库或分析器来显示代码特定部分的调用路径? 谢
我正在寻找支持每个请求分析统计的分析器,最好是沿着程序流(而不是通常的线程调用堆栈)。所以基本上是每个请求的探查器调用堆栈 + 顺序调用 View ,如下所示: doGet
如何让 symfony profiler 在 phpstorm 中工作?它应该在状态栏中,但是当我打开那个窗口时,它总是说:“这里什么都没有”。缓存目录在配置中正确定义,symfony 插件本身工作正
人们在 Unix 中用来解析/分析日志文件的流行工具是什么?进行计数,查找唯一性,选择/复制具有特定模式的特定行。请提供一些工具或一些关键字。因为我相信以前肯定有类似的问题,但我对关键字一无所知。谢谢
我设置了一个过滤器来计算执行的查询数量,并在超过某个限制时将一些内容写入我的数据库。 它在我的开发环境中运行良好,但是当我在生产环境中测试它时,我的数据库不再返回分析器。我认为这是一个为开发环境启用数
你找到这样的工具并成功使用了吗? 最佳答案 我也在寻找 AS 的分析器,但我想要一个与 FlashDevelop 和 Flex SDK 配合使用的免费软件/开源解决方案。我没有找到。所以我写了一个简单
我需要扩展 SonarQube,以便我可以向其中添加新的分析器。我尝试使用 xpath 为 java 文件添加新规则。我想知道如何在 SonarQube 中添加新语言的代码分析器,例如对于 .meta
我可以在C#(嵌套)中使用elasticsearch 2.3.0版本 我想将分析与索引一起使用, 但是索引设置不会改变,我也不知道为什么。 这是我的代码: private void b
我有一个正在wireshark中查看的自定义协议(protocol)。我认为如果wireshark可以帮我剖析它,这样我就不必解码十六进制了,这会很有用。尽管我在程序日志中执行此操作,但wiresha
我正在考虑使用 Elasticsearch 来提供我们网站的搜索功能。 我一直在试验它,但无法启用 Porterstem 分析器(以便搜索战斗匹配战斗和战斗)。 这是我输入的摘要。 curl
我正在尝试运行一个基于java的java分析器来找出我的专用机器上的java应用程序的资源消耗情况。我尝试使用的分析器称为 Warmroast。 运行时出现以下错误。 java -jar warmro
我没有从我的分析器获得预期结果,并且想测试标记化过程。 此问题的答案:How to use a Lucene Analyzer to tokenize a String? List result =
我在 Lucene 中有特殊的分析需求,但我想继续使用 StandardAnalyzer 机制的部分内容。 特别是,我想要字符串 “-苹果--胡萝卜-番茄?” 被标记为: “-苹果-”2.“-胡萝卜-
有什么好的 JSF 分析器推荐吗? 我正在使用 Tomcat 6 JSF2、 hibernate 和 Spring 最佳答案 如果您使用的是 Eclipse 或 Netbeans 之类的 IDE,那么
我是一名优秀的程序员,十分优秀!