从正则表达式匹配中仅排除拖尾空格字符(Exclude only tailing space character from regex match)
我试图从地址字符串中仅选择街道/单元号。
我的正则表达式是
/^[\d\s,\-\/]*/
目前我的正则表达式在任何字母字符之前匹配
digits
'/'
'-'
和space characters
字符。 但是我想排除拖尾space character
。我的正则表达式匹配
悉尼新南威尔士州悉尼路
61/2
号(注意'2'后的空间特征)代替
新南威尔士州曼利
61/2
悉尼路61/2
号
以下是一些示例地址字符串:
61/2 Sydney Road, Manly NSW
61-2 Sydney Road, Manly NSW
61/2 3 Sydney Road, Manly NSW
I am trying to select only the the street / unit number from an address string.
My regex pattern is
/^[\d\s,\-\/]*/
Currently my regex matches
digits
'/'
'-'
andspace characters
before any alphabetic characters. However I would like to exlude the tailingspace character
.My regex matches
61/2
Sydney Road, Manly NSW (note the space character after the '2')Instead of
61/2
Sydney Road, Manly NSW
Here are some sample addresses strings:
61/2 Sydney Road, Manly NSW
61-2 Sydney Road, Manly NSW
61/2 3 Sydney Road, Manly NSW
原文:https://stackoverflow.com/questions/48738116
最满意答案
当你这样做:
char * str = "aaa bbb ccc ddd qqq";
字符串文字
"aaa bbb ccc ddd qqq"
放在只读数据部分中,并使str
指向它。 在这一点上,改变str
指向的是未定义的行为,并希望提出一个段错误。如果您绝对想要使用指针,请尝试以下方法:
char * str = strdup("aaa bbb ccc ddd qqq");
这将在堆上创建一个可写的字符串文字的副本 。
一旦你完成了它,你需要
free(str);
释放记忆。When you do this:
char * str = "aaa bbb ccc ddd qqq";
The string literal
"aaa bbb ccc ddd qqq"
is placed in the read-only data section, andstr
is made to point to it. At this point changing whatstr
points to is undefined behavior and will hopefully raise a segfault.If you absolutely want to use a pointer, try this instead:
char * str = strdup("aaa bbb ccc ddd qqq");
This will make a copy of the string literal on the heap, which will be writable.
Once you're done with it though you'll need to
free(str);
to release the memory.
相关问答
更多-
TCP/IP模型是一个________。[2023-10-02]
a -
下列中不属于面向对象的编程语言的是?[2022-05-30]
a -
为什么MISRA C声明指针的副本可能导致内存异常?(Why does MISRA C state that a copy of pointers can cause a memory exception?)[2023-01-12]
根据标准,复制指针q = p; ,是未定义的行为。 阅读J.2未定义的行为状态: 使用了一个指向生命周期结束的对象的指针值(6.2.4)。 到那一章我们看到: 6.2.4对象的存储持续时间 对象的生命周期是程序执行的一部分,在此期间保证存储被保留。 一个对象存在,具有一个常量地址,33)并在其整个生命周期内保留其最后存储的值.34)如果一个对象在其生命周期之外被引用,行为是未定义的。 当指向(或刚刚过去)的对象达到其生命周期结束时,指针的值将变得不确定。 什么是不确定的 3.19.2 不确定值 :未指定值或 ... -
所以,char占用一个字节,是正确的? 是。 如果我理解正确,默认情况下char *占用一个字节的内存。 你的措辞有些含糊。 char占用一个字节的内存。 char *可以指向一个char ,即一个字节的内存,或一个字符数组 ,即多个字节的内存。 指针本身占用不止一个字节。 确切的值是实现定义的,通常是4个字节(32位)或8个字节(64位)。 你可以用printf( "%zd\n", sizeof char * )检查确切的值。 如果我们有一个char* str = "hello" ,那么假设它占用6个字节 ...
-
当你这样做: char * str = "aaa bbb ccc ddd qqq"; 字符串文字"aaa bbb ccc ddd qqq"放在只读数据部分中,并使str指向它。 在这一点上,改变str指向的是未定义的行为,并希望提出一个段错误。 如果您绝对想要使用指针,请尝试以下方法: char * str = strdup("aaa bbb ccc ddd qqq"); 这将在堆上创建一个可写的字符串文字的副本 。 一旦你完成了它,你需要free(str); 释放记忆。 When you do thi ...
-
Sean是对的,two.nxt永远不会初始化。 实际上,num.nxt永远不会为num的任何实例初始化。 如果类更健壮,则不需要成员nxt。 可以使用nxt指针代替: class num { private: long i; num *nxtnum; public: num (long value) : i (value), nxtnum (0) { } void check () { if (number % i != 0) { ...
-
编译器保留足够大的内存位置来存储文字并将其地址分配给指针。 此后,您可以像使用普通char *一样使用它char * 。 一个警告是,你不能修改它指向的内存。 char *str = "This is the end"; printf("%s\n", str); str[5] = 0; /* Illegal. */ 顺便说一句,这个C FAQ也讨论了这个问题。 The compiler reserves some memory location large enough to store the lit ...
-
C ++:指针本身如何处理内存管理?(C++: How are pointers themselves handled regarding memory management?)[2022-12-17]
不,别担心! 你可以将指针想象成像int s或double s一样管理(至少在内存方面)。 指针本身就像是一个int ,它恰好包含了一些其他对象或对象数组的地址。 指针从作用域中消失后,指针本身的内存将自动恢复。 如果你正在做类似int** p = new int*[1]那样的例外,即用new创建指针。 那么你会在某个时候需要delete p 。 如果你正在创建你的指针,像int* p = new int[size]; (这可能是你想要的),那么p本身就在堆栈上 ,这意味着你不需要关心内存释放,但是数组p指 ... -
所以我的问题是,在CreateList函数中,程序如何为temp分配内存? 这不是,这是一个问题。 它应该做这样的事情: temp = malloc(sizeof(Listhead)); 并且代码* hallocp = temp将temp LIST复制到hallocbuf数组中? 它将保存在temp的指针复制到hallocbuf的第一个元素中(假设hallocp在任何地方都没有改变,仍然具有已经初始化的值,指向hallocbuf[0] )。 通常,隐藏LIST和Node是typedefs背后的指针这个事实 ...
-
内存泄漏c ++指针(Memory leak c++ pointers)[2022-02-09]
第一个有内存泄漏,我理解,因为x是一个指向B对象的A对象。 不,如果A和B具有明确的继承关系,则不存在内存泄漏。 如: class A { public: virtual ~A() {} }; class B : public A { }; 为什么第二个函数没有内存泄漏? 因为x分配在堆栈上,不需要也不能调用delete 。 x将被自动销毁。 我们不需要删除x? 只有new创建的对象需要delete 。 编辑 对于A和B代码,第一种情况会导致内存泄漏,因为A (基类)的析构函数不是虚拟的 。 对 ...