草庐IT

null-terminated

全部标签

c++ - std::multiset::iterator = NULL 不再有效?

我有一些代码正在使用gcc4.7(从3.1)更新到C++11我有一个multiset定义为一个类的私有(private)成员:multisetobjects_;代码中有一段看起来像这样(p_q是一对多集迭代器,对那句讨厌的行感到抱歉,迫不及待地想用auto替换它,哈哈):voidTerrain::removeObject(Object*obj){pair::iterator,multiset::iterator>p_q;multiset::iteratorp,q;q=NULL;p_q=objects_.equal_range(obj);for(p=p_q.first;p!=p_q.se

C++ WINAPI : How to kill child processes when the calling (parent) process is forcefully terminated?

谁能告诉我如何在调用(父)进程被强制终止时终止子进程?顺便说一句,我无法更改子应用程序的源代码。我检查了StackOverflow中的现有线程,JobObject似乎是正确的方法。但是当我测试它时(使用控制台应用程序调用notepad.exe),我发现当控制台应用程序退出时,记事本没有。我使用CreateProcess生成新进程。我也看到有人说在父进程和子进程之间建立一个管道就可以了,但我还没有尝试过。如果有人能给我一些提示,我将不胜感激。更新:如果没有,WINAPIAssignProcessToJobObject将无法工作|在CreatProcess中创建CREATE_BREAKAW

c++ - abort() 和 terminate() "live"在哪里?

关于终止处理程序,据我了解,当代码中出现错误时,例如当我们没有捕获到异常时,terminate()被调用,后者又调用abort()set_terminate(my_function)允许我们获取terminate()以调用用户指定的函数my_terminate。我的问题是:这些函数“存在”在哪里,它们似乎不是语言的一部分,但就像它们存在于每个单独的cpp文件中一样工作,而无需包含任何头文件。 最佳答案 如果terminate和abort的默认处理函数不是您自己安装的,则它们必须位于编译器提供的运行时库中。通常,每个程序都链接到运行时

返回null dayofyear函数 - Spark SQL

我是Databricks&火花/Scala。我目前正在研究机器学习以进行销售预测。我使用Dayfyear功能创建功能。唯一的问题是返回我的零值。我尝试使用此CSV,因为我正在使用另一个CSV,我认为这可能来自此。但是显然,我错了。我阅读了有关此功能的文档,但描述确实很短。我尝试了dayofmonth或neekefyear,结果相同。您能解释一下我如何解决这个问题吗?我究竟做错了什么?valpath="dbfs:/databricks-datasets/asa/planes/plane-data.csv"valdf=sqlContext.read.format("csv").option

c++ - "cout<<(char*)NULL"在这里做 "close(1)"吗?

这个问题在这里已经有了答案:Whydoesstd::coutoutputdisappearcompletelyafterNULLissenttoit(3个答案)关闭8年前。在下面的代码中我使用了cout在这一行之后,我的程序没有在输出屏幕上打印任何内容。这是否意味着我已经完成了close(1)与cout这里?这里到底发生了什么?这是一个错误吗?请分享您的想法。#includeusingnamespacestd;voidf(){cout我在gcc和DevCpp编译器上都试过了,观察到相同的行为。

c++ - 线程: Termination of infinite loop thread in c++

我试图编写一个线程,该线程将在我的主程序的后台运行并监视某事。在某个时候,主程序应该向线程发出信号以使其安全退出。这是一个最小示例,该示例以固定的时间间隔将本地时间写入命令行。#include#include#include#include#includeintfunc(bool&on){while(on){autot=std::chrono::system_clock::to_time_t(std::chrono::system_clock::now());std::coutfi=std::async(std::launch::async,func,on);std::this_thr

c++ - 为什么 char 数组必须以空字符结尾?

为什么chararray必须以空字符结尾?有什么理由我必须将空字符添加到每个char数组吗?他们似乎得到了同样的待遇。 最佳答案 char数组不必以null结尾(不依赖于此的标准库函数包括memcpy、memmove、strncpy--错误地命名了这个最新的--,printf具有正确的格式字符串)。根据定义,NUL终止字符串(NTCS)需要以NUL终止。它是C标准库的字符串处理实用程序所期望的格式,也是大多数C程序使用的约定(在C++中,通常使用std::string) 关于c++-为什

c++ - 与 C++ 中的 Null 比较

好的,请仔细检查我下面的代码,它只是函数的一部分voidRepeatWord(){system("cls");stringword=NULL;stringnewword=NULL;intrepeats=0;while(true){if(word==NULL){cout>word;}....好吧,我一直在使用其他编程语言,并且我总是与NULL值进行比较,但是在C++中……这似乎是一种不同的情况。错误说..error:nomatchfor'operator=='in'word==0'好吧,我想知道我只是在与NULL进行比较,我真的不知道为什么这是错误的。将值与NULL与C++进行比较是否不

c++ - 为什么 ostringstream 会去掉 NULL?

我有一个字符串,其最后一部分(后缀)需要更改多次,并且我需要生成新的字符串。我正在尝试使用ostringstream来执行此操作,因为我认为使用流比字符串连接更快。但是当前面的后缀大于后面的后缀时,它就会变得困惑。流也剥离空字符。#include#includeusingnamespacestd;intmain(){ostringstreamos;streampospos;os输出HelloUniverseHelloWorldrse但我想要HelloWorld。我该怎么做呢?有没有其他方法可以更快地做到这一点?编辑:附加std::ends有效。但是想知道它在内部是如何工作的。还想知道是

c++ - 标准文本文件是否以 NULL 结尾?

我正在编写一个C++程序,它读取一个文件,然后将它作为字符数组发送到另一个类。因为字符数组只通过指针传递,所以所有大小都丢失了。它将读取的文件将是一个文本文件。文本文件是否终止?我最好不想使用Vector,因为我真的不需要它的任何功能,只需要数组的大小。 最佳答案 没有。文件的长度已知,因此不需要任何终止字节。 关于c++-标准文本文件是否以NULL结尾?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co