- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一个“地址 0x4811 越界”的问题,我怀疑这是由 std::string
引起的传递给 const char*
.奇怪的是,这仅在数千次迭代后才会发生。我会尽量让事情更清楚。
我有一个函数可以“逐个字符”比较两个字符串,以获得字符串 vector 的字典顺序(代码基于 Dirk Jagdmann 的“Alphanum Algorithm”实现)
int compareChar(const char *l, const char *r) {
enum mode_t {
STRING, NUMBER
} mode;
mode = STRING;
while(*l && *r) {
if(mode == STRING) {
char l_char, r_char;
while((l_char=*l) && (r_char=*r)) {
// check if this are digit characters
const bool l_digit=isDigit(l_char), r_digit=isDigit(r_char);
// if both characters are digits, we continue in NUMBER mode
if(l_digit && r_digit) {
mode=NUMBER;
break;
}
// if only the left character is a digit
if(l_digit) return -1;
// if only the right character is a digit
if(r_digit) return +1;
// compute the difference of both characters
const int diff=l_char - r_char;
// if they differ we have a result
if(diff != 0) return diff;
// otherwise process the next characters
++l;
++r;
}
} else { // mode==NUMBER
// get the left number
char *end;
unsigned long l_int= strtoul(l, &end, 0);
l=end;
// get the right number
unsigned long r_int= strtoul(r, &end, 0);
r=end;
while(*l && isDigit(*l)) {
l_int=l_int*10 + *l-'0';
++l;
}
while(*r && isDigit(*r)) {
r_int=r_int*10 + *r-'0';
++r;
}
// if the difference is not equal to zero, we have a comparison result
const long diff=l_int-r_int;
if(diff != 0) return diff;
// otherwise we process the next substring in STRING mode
mode=STRING;
}
}
if(*r) return -1;
if(*l) return +1;
return 0;
}
此函数在读取生物数据并且必须通过名称或符号搜索和比较对象的应用程序中多次使用。名称和符号是 std::string
,因此一个用法示例是:
bool operator<(const Gene& g) const {
if( (compareChar(chrom.c_str(), g.chrom.c_str()) < 0 ) )
return true;
else
if( (compareChar(chrom.c_str(), g.chrom.c_str())) == 0 )
if(entrez_ID == g.getId()) return true;
else if(start_p < g.getStart()) return true;
else return false;
else return false;
}
具体来说,上面的代码片段是 operator<
的重载, 用于排序 Gene 对象。我在我的代码中将它与 std::sort
一起使用算法
for(genes_it=chrGenes.begin(); genes_it!=chrGenes.end(); ++genes_it)
if( ((*genes_it).getStart() > ((*conns_it).getF2Start()-const_value)) &&
((*genes_it).getStart() < (*conns_it).getF2Start()) )
bf_gene.push_back((*genes_it));
if(bf_gene.size() > 1) {
std::sort( bf_gene.begin(), bf_gene.end() );
bf_gene.erase( std::unique(bf_gene.begin(), bf_gene.end()), bf_gene.end() );
}
好吧,它通常像一个魅力一样工作,因为昨天我午餐时进行了更长的模拟,并且在运行 30 分钟后应用程序因段错误而停止。使用 gdb 检查,这是响应:
(anonymous namespace)::compareChar (l=0x4811 <Address 0x4811 out of bounds>, r=0x9b9ec8 "chr17") at common.hpp:193
193 while(*l && *r) {
#0 (anonymous namespace)::compareChar (l=0x4811 <Address 0x4811 out of bounds>, r=0x9b9ec8 "chr17") at common.hpp:193
#1 0x0000000000410883 in Gene::operator< (this=0x8b4575b0, g=...) at Gene.hpp:222
#2 0x00000000004150a7 in std::__unguarded_partition<__gnu_cxx::__normal_iterator<Gene*, std::vector<Gene, std::allocator<Gene> > >, Gene> (__first=<value optimized out>,
__last=<value optimized out>, __pivot=...) at /usr/lib/gcc/x86_64-redhat-linux/4.4.7/../../../../include/c++/4.4.7/bits/stl_algo.h:2209
#3 0x0000000000415242 in std::__introsort_loop<__gnu_cxx::__normal_iterator<Gene*, std::vector<Gene, std::allocator<Gene> > >, long> (__first=..., __last=..., __depth_limit=7)
at /usr/lib/gcc/x86_64-redhat-linux/4.4.7/../../../../include/c++/4.4.7/bits/stl_algo.h:2268
#4 0x000000000040e4e7 in sort<__gnu_cxx::__normal_iterator<Gene*, std::vector<Gene, std::allocator<Gene> > > > (this=0x620ee0, id=<value optimized out>, sc_limit=3)
at /usr/lib/gcc/x86_64-redhat-linux/4.4.7/../../../../include/c++/4.4.7/bits/stl_algo.h:5220
#5 Gene::findConnections (this=0x620ee0, id=<value optimized out>, sc_limit=3) at Gene.cpp:1135
#6 0x000000000041a36b in main (argc=<value optimized out>, argv=<value optimized out>) at testth.cpp:30
好吧,问题很明显,但我无法弄清楚为什么在执行 30 分钟后会发生这种情况。此外,它总是以相同的 *l
发生。内容(我可以从应用程序的日志文件中查看)。我不明白在这一点上它怎么会是一个“越界”错误,只要它在数千次使用中都能正常工作。
想知道它是否可以由 std::sort
引起算法。
我会感谢所有可能的提示和建议
最佳答案
显示的代码似乎不足以解释这种行为。但是,我可以看到它仍然存在一些需要修复的问题。
最引人注目的问题是 operator<
provided 没有定义 strict weak ordering relation :
x < x
是真的;x < y
和 y < x
是真的。 std::sort
需要严格的弱排序关系才能正常运行。
关于分配给 const char* 的 c++ 字符串导致地址在第 n 次迭代时越界,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24161807/
SQLite、Content provider 和 Shared Preference 之间的所有已知区别。 但我想知道什么时候需要根据情况使用 SQLite 或 Content Provider 或
警告:我正在使用一个我无法完全控制的后端,所以我正在努力解决 Backbone 中的一些注意事项,这些注意事项可能在其他地方更好地解决......不幸的是,我别无选择,只能在这里处理它们! 所以,我的
我一整天都在挣扎。我的预输入搜索表达式与远程 json 数据完美配合。但是当我尝试使用相同的 json 数据作为预取数据时,建议为空。点击第一个标志后,我收到预定义消息“无法找到任何内容...”,结果
我正在制作一个模拟 NHL 选秀彩票的程序,其中屏幕右侧应该有一个 JTextField,并且在左侧绘制弹跳的选秀球。我创建了一个名为 Ball 的类,它实现了 Runnable,并在我的主 Draf
这个问题已经有答案了: How can I calculate a time span in Java and format the output? (18 个回答) 已关闭 9 年前。 这是我的代码
我有一个 ASP.NET Web API 应用程序在我的本地 IIS 实例上运行。 Web 应用程序配置有 CORS。我调用的 Web API 方法类似于: [POST("/API/{foo}/{ba
我将用户输入的时间和日期作为: DatePicker dp = (DatePicker) findViewById(R.id.datePicker); TimePicker tp = (TimePic
放宽“邻居”的标准是否足够,或者是否有其他标准行动可以采取? 最佳答案 如果所有相邻解决方案都是 Tabu,则听起来您的 Tabu 列表的大小太长或您的释放策略太严格。一个好的 Tabu 列表长度是
我正在阅读来自 cppreference 的代码示例: #include #include #include #include template void print_queue(T& q)
我快疯了,我试图理解工具提示的行为,但没有成功。 1. 第一个问题是当我尝试通过插件(按钮 1)在点击事件中使用它时 -> 如果您转到 Fiddle,您会在“内容”内看到该函数' 每次点击都会调用该属
我在功能组件中有以下代码: const [ folder, setFolder ] = useState([]); const folderData = useContext(FolderContex
我在使用预签名网址和 AFNetworking 3.0 从 S3 获取图像时遇到问题。我可以使用 NSMutableURLRequest 和 NSURLSession 获取图像,但是当我使用 AFHT
我正在使用 Oracle ojdbc 12 和 Java 8 处理 Oracle UCP 管理器的问题。当 UCP 池启动失败时,我希望关闭它创建的连接。 当池初始化期间遇到 ORA-02391:超过
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve
引用这个plunker: https://plnkr.co/edit/GWsbdDWVvBYNMqyxzlLY?p=preview 我在 styles.css 文件和 src/app.ts 文件中指定
为什么我的条形这么细?我尝试将宽度设置为 1,它们变得非常厚。我不知道还能尝试什么。默认厚度为 0.8,这是应该的样子吗? import matplotlib.pyplot as plt import
当我编写时,查询按预期执行: SELECT id, day2.count - day1.count AS diff FROM day1 NATURAL JOIN day2; 但我真正想要的是右连接。当
我有以下时间数据: 0 08/01/16 13:07:46,335437 1 18/02/16 08:40:40,565575 2 14/01/16 22:2
一些背景知识 -我的 NodeJS 服务器在端口 3001 上运行,我的 React 应用程序在端口 3000 上运行。我在 React 应用程序 package.json 中设置了一个代理来代理对端
我面临着一个愚蠢的问题。我试图在我的 Angular 应用程序中延迟加载我的图像,我已经尝试过这个2: 但是他们都设置了 src attr 而不是 data-src,我在这里遗漏了什么吗?保留 d
我是一名优秀的程序员,十分优秀!