我编写了一个代码片段来为我的应用实现LCS算法。在这个算法中,我使用malloc实现了一个数组。但是,我不确定我做错了什么。我找不到任何显示原因的具体信息。我找不到出路。
注意:我有弧线
我的代码在下面给出
- (IBAction)buttonAction:(id)sender
{
[self getInlineDiffofFragment1:[NSArray arrayWithObjects:@"line1", @"line2", @"line3", @"line4", @"line5", nil] andFragment2:[NSArray arrayWithObjects:@"line1", @"line2", @"line4", @"line6", nil]];
}
- (void)getInlineDiffofFragment1:(NSArray*)fragment1 andFragment2:(NSArray*)fragment2
{
int row = fragment1.count + 1;
int col = fragment2.count + 1;
int *lcs = (int*)malloc(sizeof(int) * row * col); //2d array
NSString *str;
for (int i = 0; i <= fragment1.count; i++) {
lcs[i * row] = 0;
}
for (int j = 0; j <= fragment2.count; j++) {
lcs[0 + j] = 0;
}
for (int i = 1; i < row; i++) {
str = [NSString stringWithFormat:@""];
for (int j = 1; j < col; j++) {
int xy = i * row + j;
if ([[fragment1 objectAtIndex:i - 1] isEqualToString:[fragment2 objectAtIndex:j - 1]]) {
lcs[xy] = lcs[(i - 1) * row + (j - 1)] + 1;
} else {
lcs[xy] = MAX(lcs[(i - 1) * row + j], lcs[i * row + (j - 1)]);
}
str = [str stringByAppendingFormat:@"%d ", lcs[xy]];
}
NSLog(@"%@", str);
}
free(lcs);
NSLog(@"freed");
}
该功能可以完美地按预期打印结果并退出块。结果如下:
2012-09-26 16:14:18.727 TestDiff[56178:11303] 1 1 1 1
2012-09-26 16:14:18.733 TestDiff[56178:11303] 1 2 2 2
2012-09-26 16:14:18.734 TestDiff[56178:11303] 1 2 2 2
2012-09-26 16:14:18.735 TestDiff[56178:11303] 1 2 3 3
2012-09-26 16:14:18.736 TestDiff[56178:11303] 1 2 3 3
2012-09-26 16:14:18.736 TestDiff[56178:11303] freed
打印结果并退出程序段后,它会崩溃。崩溃报告如下
该程序适用于以下测试功能
#define WIDTH 4
#define HEIGHT 5
#define INDEXOF(x,y) ((y*WIDTH) + x)
- (void)testArray
{
NSString *str;
int *myArray = (int *) malloc(sizeof(int) * 5 * 4); // 4 * 5 array
for(int x=0; x<WIDTH; x++){
str = [NSString stringWithFormat:@""];
for(int y=0; y<HEIGHT; y++){
myArray[INDEXOF(x,y)] = y;
str = [str stringByAppendingFormat:@"%d ", myArray[INDEXOF(x, y)]];
}
NSLog(@"%@", str);
}
free(myArray);
}
感谢您的帮助
答案 0 :(得分:1)
转到构建设置并查找名为“Compile Source As”的项目。将其值更改为“Objective C ++”。
答案 1 :(得分:1)
您是否尝试在free(myArray);
的行上设置断点?它是否成功地达到了这一点,然后当你跨过它时崩溃了?
此外,如果您获得EXC_BAD_ACCESS,则应尝试turning zombies on并查看是否已发布某些内容。