抱歉,如果这很简单,但是我正在学习python,则此行代码将出现此错误: cv2.line(output, point1, point2, (0,0,255),5)
我没看到问题...
我在我有一个的情况下uint64_t*,一个char*(6个字节长),以及uint16_t*该点到地址x,x+2和x分别.因此,如果char*指向"This i",那么uint16_t*应该指向值0dec,并且uint64_t*应该指向值115, 588, 096, 157, 780dec.
但是当我看到这些值时,我得到0分,因为uint64_t我不明白为什么会这样.有人能解释一下吗
编辑(添加代码):
FILE *file = fopen("/Users/Justin/Desktop/test.txt", "rb");
uint64_t *window = malloc(8);
char *buffer = (char*)(window+2);
uint16_t *data = (uint16_t*)window;
uint16_t *read = (uint16_t*)(window+6);
fread(buffer, 6, 1, file);
printf("%p\n", window);
printf("%p\n", buffer);
printf("%p\n", data);
printf("%p\n", read);
printf("%s\n", buffer);
printf("%llu\n", *window);
Run Code Online (Sandbox Code Playgroud)
输出是:
0x100105440
0x100105450
0x100105440
0x100105470
This i
0
Run Code Online (Sandbox Code Playgroud) 我在for循环中创建了几个线程,如下所示:
for (int i = 0; i<5; i++) {
new Thread() {
//do stuff
}
}
Run Code Online (Sandbox Code Playgroud)
但我需要确保这些线程一个接一个地执行,而不是同时执行.
做这个的最好方式是什么?
java concurrency multithreading executorservice java.util.concurrent
我试图将一些Java代码转换为python等价物,以便我可以在两者之间进行接口.所以在Java中我有一些像这样的代码:
public int[] toArray(boolean order) {
return toArray(order, this.length());
}
public int[] toArray(boolean order, int length) {
...
}
Run Code Online (Sandbox Code Playgroud)
并且python中的逻辑等效项可能如下所示:
def to_array(self, order):
return self.to_array(order, self.length())
def to_array(self, order, length):
...
Run Code Online (Sandbox Code Playgroud)
除了... python不允许函数重载,相反它允许默认参数,所以,再次,你想要做这样的事情似乎合乎逻辑:
def to_array(self, order, length = self.length()):
...
Run Code Online (Sandbox Code Playgroud)
但是...这在python中也是不允许的,可能因为self直到函数体内才真正"存在".
那么在python中执行此操作的正确方法是什么?或者它是不可能的?
编辑:我意识到我在我的java代码中使用了void函数,它应该返回一个值,所以现在它们返回 int[]