小编imk*_*dal的帖子

仅给出一次遍历时,查找二叉树的其他两个遍历

我知道你可以在给出它的顺序和前序遍历作为字符串时重建二叉树,但是只有在给定顺序遍历时才能找到后序和/或preoder遍历吗?

c++ binary-tree inorder postorder preorder

6
推荐指数
1
解决办法
581
查看次数

TCP端口访问和C++

如果程序在Linux机器上运行,那么该程序是否有办法扫描允许通过防火墙的端口?例如,如果程序员想要建立一个聊天系统,但程序需要知道哪些端口没有被用户防火墙拒绝访问传入连接,那么有没有办法在你的代码中检查这个?即使防火墙阻止来自传入连接的相同端口,程序也可能无法将套接字绑定到端口.有没有办法检查开放的防火墙端口?

旁注:这纯粹是出于教育目的而没有恶意,要明确我正在编写聊天系统,并且在测试期间,我无法连接台式机 - >笔记本电脑,直到我通过防火墙手动打开端口.这对我来说似乎有些不同,而且不像程序员的代码应该要求用户做的事情.更不用说我不想让少数人使用这个代码处于危险之中(如果永久打开一个端口就这样做).所以看起来我更适合找到一种方法来利用已经对传入TCP连接开放的端口.

旁注:所有客户都在运行fedora

c++ sockets port networking tcp

5
推荐指数
1
解决办法
1344
查看次数

派生类构造函数调用

如果我有一个基类:

class Base{
  ...
};
Run Code Online (Sandbox Code Playgroud)

和派生类

class Derived : public Base{
  ...
}
Run Code Online (Sandbox Code Playgroud)

这个派生类总是调用基类的默认构造函数吗?即不带参数的构造函数?例如,如果我为基类定义构造函数:

Base(int newValue);
Run Code Online (Sandbox Code Playgroud)

但我没有定义默认构造函数(无参数构造函数):

Base();
Run Code Online (Sandbox Code Playgroud)

(我知道这只是一个声明而不是定义)我得到一个错误,直到我定义了不带参数的默认构造函数.这是因为基类的默认构造函数是派生类调用的构造函数吗?

c++ inheritance constructor base-class derived-class

5
推荐指数
1
解决办法
2万
查看次数

编译器:如何解析函数调用和函数定义

在前面,我正在用 Python 制作一个解释器,而不是一个编译成机器码的实际编译器。我最近浏览了很多编译器构建指南,我了解为解析器生成标记和构建语法树来评估算术表达式的基础知识,但我不太明白如何解析包含函数调用的表达式,像

图(一)

1 + pow(1, 1)
Run Code Online (Sandbox Code Playgroud)

或者当用户定义这样的函数时如何解析行

图(b)

function newFunction( someArgs ){
   ... some magic ...
}
Run Code Online (Sandbox Code Playgroud)

在图(a)中,我应该如何标记这个表达式?阅读保留字“pow”后,我是否应该将所有内容都抓取到右括号并将其传递给解析器?或者我应该包含“pow”、“(”、“1”、“1”和“)”作为单独的标记并将它们添加到我的分析树中?

在斐波那契。(b) 在编译函数定义时,我什至不知道从哪里开始。任何让我朝着正确方向前进的信息将不胜感激。

编辑:我正在使用 Backus-Naur 形式语法:

S ::= 表达式

表达式 ::= 术语 | 术语 ([+-] 术语)+

术语 ::= 因子 | 因子 ([*/] 因子)+

因子 ::= 数字 | ( 表达 )

数字 ::= [0-9]+

python compiler-construction frontend parsing interpreter

5
推荐指数
1
解决办法
3019
查看次数

双向正斜杠直接IE使用特定的CSS吗?

我在开发网站时发现了一些非常奇怪的东西.在尝试将div元素显示在屏幕顶部时,我注意到除了旧版本的IE之外,我没有在任何浏览器中实现所需的结果.为了测试一些不同的代码,而不是删除错误的行,我使用'//'来评论它(我真的不确定它是否适用于css)但是发生了什么,兼容的浏览器使用了未注释的代码,而IE使用标记为'//'的代码.这是代码:

#ban-menu-div{
position:fixed;top:0;
//position:relative; //<-- IE keeps the banner with rel pos while the other
display:block;       //    browsers used fixed
margin:auto;
padding:0px;
width:100%;
text-align:center;
background:black;
}
Run Code Online (Sandbox Code Playgroud)

所以基本上,似乎//可以用来指示较新的浏览器忽略特定的代码行,并指示旧版本的IE使用它?如果这是常见的做法,请告诉我.它肯定会使旧版浏览器的开发变得更加容易

css browser compatibility internet-explorer comments

4
推荐指数
1
解决办法
2866
查看次数

C++程序控制终端窗口

当在终端中使用vim时,它基本上会消除终端的窗口,并为您提供一个新的窗口以开始编码,但是当您退出vim时,仍会列出终端的先前输出.如何清除终端以便它只输出程序的输出,但是一旦进程结束就返回到正常状态?(在linux中,fedora)

c++ linux vim terminal

4
推荐指数
1
解决办法
1369
查看次数

访问Fortran中字符串中特定索引处的字符

有没有办法在fortran中访问字符串中的字符?如果我想在字符变量中存储字符串"taco"的第一个字母,我该怎么做?

arrays string fortran character

4
推荐指数
1
解决办法
4763
查看次数

尝试通过示例了解时钟周期

我正在努力完全理解时钟周期是什么,所以我想出了一个测试示例,我希望有人确认或驱散并提供更好的理解.如果我有一个简单的代码行,一个while循环,在设备上运行

while(true)
{
  int x = 5;
}
Run Code Online (Sandbox Code Playgroud)

命令:int x = 5是否每个时钟周期执行一次?换句话说,时钟速度是指设备能够在每单位时间内读取和执行命令的速度吗?

embedded microcontroller clock microprocessors

4
推荐指数
2
解决办法
2605
查看次数

使用Flash Drive将已编译的二进制文件复制到另一台计算机

这可能是一个愚蠢的问题,但如果我在Linux的一个发行版上使用g ++编译共享库,然后将这些库作为目标文件通过闪存驱动器移动到具有完全相同的Linux发行版和g ++版本的另一台计算机,我仍然会能够在第二台机器上的源文件中链接这些库吗?

我问,因为我没有权限在第二台机器上编译之前安装必要的库,所以我更容易在我自己的计算机上编译它们并通过闪存驱动器上传编译的目标文件第二台机器

c++ linux flash g++ object-files

4
推荐指数
1
解决办法
2139
查看次数

C++ Linux命名管道挂在open()上,带有O_WRONLY

这是我的简单代码,它打开命名管道,将字符串写入其中,然后关闭管道.管道是在另一个功能中创建的,如下所述.

char * ipcnm = "./jobqueue";

std::cout << "opening job queue" << std::endl;

//ensure the jobqueue is opened
if ((jobq = open(ipcnm, O_WRONLY)) < 0) {
  perror("open");
  exit(-1);
}

std::cout << "queue opened" << std::endl;

// record the number of bytes written to the queue
size_t written = write(jobq, ptr, size*nmemb);

// close fifo
if (close(jobq) < 0) {
  perror("close");
  exit(-1);
}

// need to report to other agents the size of the job that was written
jobSizes.push_back(written);
Run Code Online (Sandbox Code Playgroud)

但是open()的调用挂起了.我确保在调用时没有其他进程使用fifo"jobqueue",并且一旦创建了队列的文件权限设置为prwxrwxr-x(我只是mkfifo(ipcnm, …

c++ linux ipc named-pipes mkfifo

4
推荐指数
1
解决办法
7663
查看次数