Articles of OSX

如何使“tar –exclude”在* nix环境中performance一致?

我正在写一个bash脚本来做一个部署tarball,这个脚本必须跨OSX和Linux。 我有一个目录结构,如下所示,在一个bash脚本中,我需要tar除./foo之外的内容,但包括./baz/foo $ find . . ./bar ./baz ./baz/foo ./foo 简单! 通常我会通过传递–exclude='./foo'到tar命令来做到这一点,但是我发现,在OSX和CentOS中,– –exclude=pattern的行为是不同的。 我的问题是,如何最好地克服这一点? 我如何使两个环境的行为相同或至less检测到所需的更改? 或者,任何人都可以证实他们的这种行为(OSX 10.11),以便我知道我没有一些奇怪的环境? CentOS按预期工作: $ tar zcfv ../test.tar.gz –exclude='./foo' . ./ ./bar/ ./baz/ ./baz/foo/ OSX的行为有所不同: $ tar zcfv ../test.tar.gz –exclude='./foo' . a . a ./bar a ./baz 经过几个小时的阅读文档,我发现没有什么可以解释这种不同的行为,但通过试验和错误,我发现使用脱字号来表示模式的开始在OSX上的作品。 修复OSX(使用脱字号): $ tar zcfv ../test.tar.gz –exclude='^./foo' . a . a ./bar a ./baz […]

汇编Linux系统调用与汇编OS x系统调用

我在我的Mac上运行汇编代码有问题。 我目前正在通过Jeff Duntemann的书Step by Step。 问题是它专注于为32位Linux系统编写程序集。 我正在使用一个64位的Mac OS X系统。 我仍然可以在使用nasm -f macho32的64位系统上运行32位程序集,但显然Duntemann书中的代码不起作用,因为在Linux和Mac OS x中的系统调用是不同的。 我将如何转换这个程序: ; Executable name : EATSYSCALL ; Version : 1.0 ; Created date : 1/7/2009 ; Last update : 2/18/2009 ; Author : Jeff Duntemann ; Description : A simple program in assembly for Linux, using NASM 2.05, ; demonstrating the […]

JavaFX应用程序包版本号

我正在使用JDK附带的Oracle工具为JavaFX 8应用程序创build一个可安装的包。 在Mac上创build.dmg文件,在Linux上使用.deb文件。 我从Gradle调用一个Ant脚本来创build这个包。 我遇到的问题是包中包含的版本号总是1.0,而不是我指定的版本。 Ant脚本的相关部分如下: <project name="VocabHunter Packaging" basedir="" xmlns:fx="javafx:com.sun.javafx.tools.ant"> <target name="jfxbundle" description="Build the application bundle"> <fx:deploy outdir="${basedir}/build" nativeBundles="${packageType}"> <fx:application refId="VocabHunterId" version="${version}"/> <fx:bundleArgument arg="mac.CFBundleVersion" value="${version}"/> … </fx:deploy> … </target> … </project> 你可以在这里看到完整的脚本。 在Mac上,右键单击应用程序图标并select“获取信息”,将显示1.0而不是正确的版本号,如下图所示: 同样,在Linux上,在安装.deb文件的过程中版本号显示为1.0: 有谁知道如何修复Ant脚本,以便正确的版本出现? 我在Mac和LInux上使用Oracle JDK 1.8.0_66。

系统调用中的printf返回格式错误的输出

我使用kext在OS X中logging系统调用,如下所示: int hook_read(struct proc *p, struct read_args *u, user_ssize_t *r) { /* get som params here… */ printf("[IDEN] SYS_read called, %s, %d, %d, %d.\n", params); return read(p, u, r); } 这将logging到system.log 。 现在的问题是,如果printf负载很高(调用了很多系统调用),则system.log的输出通常是不正确的:例如, ID]SYS_readEN] callparam, 123, ed 123, 123 。 该string是加扰的。 如果使用打印到串行端口的kprintf ,则不会出现格式错误的日志。 任何想法是什么导致这种行为非常感谢!

标识符“creal”未定义 – 在Mac上可见,但在Linux上不可见

题 下面的代码是错误的还是在Mac上的标题有问题? 这个错误并没有出现在Linux上,这导致我得出这样的结论:这不是错误的代码,虽然在Linux上编译成功并不是一个严格的ISO合规性testing。 源代码(MCVE) #include <stdio.h> #include <complex.h> void foo(const double *A, int *size){ for(int i=0;i < size[0]; ++i){ for(int j=0;j < size[1]; ++j){ printf("(%.2e,%.2e) ", creal(A[i + j * size[0]]), cimag(A[i + j * size[0]])); } } } 苹果电脑 系统信息 $ uname -a Darwin redacted 15.4.0 Darwin Kernel Version 15.4.0: Fri Feb 26 22:08:05 […]

从Xcode转换到CMake

我有一个C ++项目,最初是在我的Mac上使用Xcode开发的,我想用CMake设置相同的项目。 该项目使用一些外部库,包括特征和提升。 Xcode有一个相当长的生成设置列表,包括外部库的path,编译器版本的说明,额外的链接器标志,编译器优化级别等…我想知道所有这些信息在CMakeLists.txt文件。 我已经在这方面进行了广泛的search,但是find了宝贵的一点。 我是CMake的新手,从来没有写过make文件。 如果有一个实用程序可以将我的Xcode项目转换为CMake项目,那将是理想的。 但是我很乐意知道这个教程,或者有一些具体的指导。 任何帮助,将不胜感激。

Docker容器在Mac上将端口暴露给主机时遇到麻烦

我正试图公布从我的服务器运行到我的Mac主机的Docker容器的端口,以便我的主机上的浏览器可以访问它。 我可以使用run -it -p <port>:<port> …命令来公开一个端口。 这当然适用于Linux主机(我一直这样做,没有问题)。 但从来没有在我的Mac上工作。 通过“从来没有工作”,我的意思是没有从容器端口端口,即使docker ps命令确实显示了这样的映射0.0.0.0:32769->8080/tcp 。 但是什么都不能连接。 所以我想知道是否有任何额外的configuration,我必须做到这一点。 我正在使用macOS Sierra 10.12和Docker版本1.11.1,版本5604cbe。 任何input将不胜感激! 谢谢!

c数组分段错误

我试图在osx和linux ubuntu的terminal中运行这个代码: #include <pthread.h> #include <stdio.h> #include <unistd.h> int fact=1; //this data is shared by thread(s) int n; int x; int *arrayName; int main(int argc, char *argv[]) { if (argc != 3){ //check number of arguments printf("Must use: a.out <integer value>\n"); return -1; } int x = atoi(argv[1]); n = atoi(argv[2]); if (n < 0){ […]

OSX错误 – AMFI:“允许exception处理程序,因为进程不受限制”

由于我已经将我的Mac升级到Sierra,所以在控制台中看到大量的消息表示特定的进程不受限制。 什么可能导致这个错误? 这个过程是做什么的? 访问受保护的文件夹? 有没有其他的方法来启动这个过程来克服这个信息? 这是确切的消息 内核AMFI:允许“'(59273)的exception处理程序,因为进程不受限制。

/ usr / libexec / java_home命令

我是一个本地的Windows用户,从来没有使用Linux / Unix或任何其他操作系统,除了Windows。 最近我已经切换到Mac。 我安装了Java 8到我的Mac机。 我以某种方式设置我的JAVA_HOMEvariables。 我不得不努力找出它的存储位置。 在对互联网进行研究之后,我在terminal上使用了下面的命令来找出我的Java安装位置,并提供了正确的path。 /usr/libexec/java_home 我期待知道,这个命令是什么意思?