问题描述
||
我需要在iPhone手臂组件中编写简单的例程(在xcode 4下)
(正常的32位不是拇指)并且有问题
(独立的asm例程不与
内联我遇到了args和generall错误的麻烦)
我需要组装一个像
void clear_alpha(unsigned char*bits,int width,int height)
{ for(int j=0; j<height; j++)
for(int i=0; i<width; i++)
{
bits[j][i][4] = 0;
}
}
大概有人可以帮忙吗,tnx
解决方法
如果此代码很慢,为什么不尝试重写它
void clear_alpha(unsigned char*bits,int width,int height)
{
for(int j=0; j<height; j++)
for(int i=0; i<width; i++)
{
bits[j][i][4] = 0; // this should be [3]
}
}
不知道优化程序做了什么,但是索引在增加。您可以相当轻松地在循环中替换3个乘法
void clear_alpha(unsigned char*bits,int height)
{
char *bits_ptr = bits + 3;
char *bits_end = bits + height * width * 4;
for(; bits_ptr < bits_end; bits_ptr += 4) {
*bits_ptr = 0;
}
}
我没有执行此操作-检查我的工作以确保您不会超标。现在,您有了一个加数,而不是三个乘法。我假设您的第三个维度是5(编辑:基于注释固定),但是如果我错了,则必须修复。
, 请参阅我对这个ARM asm问题的回答,它显示了仅当在设备上运行并针对ARM模式而不是Thumb进行编译时,才有条件地编译ARM asm。答案还显示了一个将C参数传递到ARM asm语句中的小例子。您应该使用上述简化的for循环,然后将指令转换为ARM asm。
ARM asm示例
请注意,此示例的编译器生成代码可能与您编写的任何ASM一样快。但是,当您遇到更复杂的情况时,好的ASM编码器将比编译器做得更好,这主要是因为gcc不太善于使用条件ARM asm语句。
, memset(bits,sizeof(unsigned char)*width*height);
怎么样