• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EST 16:59
CET 22:59
KST 06:59
  • Home
  • Forum
  • Calendar
  • Streams
  • Liquipedia
  • Features
  • Store
  • EPT
  • TL+
  • StarCraft 2
  • Brood War
  • Smash
  • Heroes
  • Counter-Strike
  • Overwatch
  • Liquibet
  • Fantasy StarCraft
  • TLPD
  • StarCraft 2
  • Brood War
  • Blogs
Forum Sidebar
Events/Features
News
Featured News
RSL Revival - 2025 Season Finals Preview8RSL Season 3 - Playoffs Preview0RSL Season 3 - RO16 Groups C & D Preview0RSL Season 3 - RO16 Groups A & B Preview2TL.net Map Contest #21: Winners12
Community News
SC2 All-Star Invitational: Jan 17-1816Weekly Cups (Dec 22-28): Classic & MaxPax win, Percival surprises2Weekly Cups (Dec 15-21): Classic wins big, MaxPax & Clem take weeklies3ComeBackTV's documentary on Byun's Career !11Weekly Cups (Dec 8-14): MaxPax, Clem, Cure win4
StarCraft 2
General
SC2 All-Star Invitational: Jan 17-18 Weekly Cups (Dec 22-28): Classic & MaxPax win, Percival surprises Chinese SC2 server to reopen; live all-star event in Hangzhou Starcraft 2 Zerg Coach ComeBackTV's documentary on Byun's Career !
Tourneys
OSC Season 13 World Championship WardiTV Mondays $5,000+ WardiTV 2025 Championship $100 Prize Pool - Winter Warp Gate Masters Showdow Sparkling Tuna Cup - Weekly Open Tournament
Strategy
Custom Maps
Map Editor closed ?
External Content
Mutation # 506 Warp Zone Mutation # 505 Rise From Ashes Mutation # 504 Retribution Mutation # 503 Fowl Play
Brood War
General
I would like to say something about StarCraft A cwal.gg Extension - Easily keep track of anyone BGH Auto Balance -> http://bghmmr.eu/ (UMS) SWITCHEROO *New* /Destination Edit/ What monitor do you use for playing Remastered?
Tourneys
[Megathread] Daily Proleagues [BSL21] Grand Finals - Sunday 21:00 CET SLON Grand Finals – Season 2 [BSL21] LB SemiFinals - Saturday 21:00 CET
Strategy
Current Meta [G] How to get started on ladder as a new Z player Fighting Spirit mining rates Simple Questions, Simple Answers
Other Games
General Games
General RTS Discussion Thread Nintendo Switch Thread Awesome Games Done Quick 2026! Stormgate/Frost Giant Megathread Mechabellum
Dota 2
Official 'what is Dota anymore' discussion
League of Legends
Heroes of the Storm
Simple Questions, Simple Answers Heroes of the Storm 2.0
Hearthstone
Deck construction bug Heroes of StarCraft mini-set
TL Mafia
Vanilla Mini Mafia Mafia Game Mode Feedback/Ideas Survivor II: The Amazon Sengoku Mafia
Community
General
Russo-Ukrainian War Thread US Politics Mega-thread Canadian Politics Mega-thread The Games Industry And ATVI 12 Days of Starcraft
Fan Clubs
White-Ra Fan Club
Media & Entertainment
Anime Discussion Thread [Manga] One Piece
Sports
2024 - 2026 Football Thread Formula 1 Discussion
World Cup 2022
Tech Support
Computer Build, Upgrade & Buying Resource Thread
TL Community
Ghostwriting Services for Authors and Businesses The Automated Ban List TL+ Announced
Blogs
National Diversity: A Challe…
TrAiDoS
I decided to write a webnov…
DjKniteX
James Bond movies ranking - pa…
Topin
StarCraft improvement
iopq
Customize Sidebar...

Website Feedback

Closed Threads



Active: 1614 users

The Big Programming Thread - Page 841

Forum Index > General Forum
Post a Reply
Prev 1 839 840 841 842 843 1032 Next
Thread Rules
1. This is not a "do my homework for me" thread. If you have specific questions, ask, but don't post an assignment or homework problem and expect an exact solution.
2. No recruiting for your cockamamie projects (you won't replace facebook with 3 dudes you found on the internet and $20)
3. If you can't articulate why a language is bad, don't start slinging shit about it. Just remember that nothing is worse than making CSS IE6 compatible.
4. Use [code] tags to format code blocks.
Deleted User 101379
Profile Blog Joined August 2010
4849 Posts
February 10 2017 08:38 GMT
#16801
On February 10 2017 12:18 WarSame wrote:
What is an elegant way to set a bunch of div colours in SASS?

I would ideally like to do something like
$brown: #955436
$lightblue: #AAE0FA
$pink: #D93A96
$orange: #F7941D
$red: #ED1B24
$yellow: #FEF224
$green: #1FB25A
$darkblue: #0072BB

.block-(colorexample)
background-color:$colorexample


where I could have divs with classes like
block-brown
and have it automatically sub in the colour. Should I just not bother and make a block-colour for every single colour I have?


Please don't.

Name your CSS classes after what they represent, not after what they look like. Otherwise you'll either have to search and replace all the instances when your Boss tells you that all brown buttons should now be green, which negates all the advantages of CSS, or you have a class "brown" that is now green.
Artesimo
Profile Joined February 2015
Germany564 Posts
Last Edited: 2017-02-10 08:42:40
February 10 2017 08:38 GMT
#16802
Last questions:

About JOIN, if I got a ManyToMany Relationshipt between say, Students and lecturers:


ListL result em.createQuery("SELECT s, l FROM Studens s join s.lectures")
for(Iterator i = resultL.iterator(); i.hasNext();)
{
Object [] element = (Object[]) i.hasNext()//each Object[] containing a Student at [0] and a lecture at[1]
//using get-Methods to get Student/Lecture Name and printing it out


My Output would be equivalent to the joinedtable, where for every Student, all lectures get Listet:

_Student_ _Lecture_
Hans Lecture 1
Hans Lecture 2
Hans Lecture 3
Max Lecture 2
Max Lecture 3
Anna Lecture 3
. .
. .
. .
. .
Correct?

I could also acess the name of the Students directly, via using "SELECT s.name, l.name" instead.

An implicit join would also work like:

Select s, l,
FROM Student s, lesson l


Or to only get Name+all courses of one Students:

Select s, l,
FROM Student s, lesson l
WHERE s.name = "Hans"



Last question regarding general understanding:
All Querys in the end will be translated into SQL and send to the Database, this happens either after commiting an transaktion or calling flush() (which can be dangerous since it leaves the transaktionscope open, If the transaction fails afterwards, changes made before flush() are still in the database unless handled properly). However, how do you acess objekts then, that arent in the persitence context, but in the DB.

EntityManager em = emf.createEntityManager();//Session created
EntityTransaction tx = null;
try{
tx = em.getTransaction(); //transaction context created
tx.begin() //start transaciton();
// Customer001 previously not in persistence context/Cache
customer myCustomer = em.find(Customer.class, 001);//Now in persistence context
/*
Interaction with the object I pulled from the database - How can this work,
if the select-statement only get send after the commit?
Or get everything that you need for the tx get pulled from the DB before/em.find()
circumvents the commit? What about Entities pulled with JPQL-Querys?
*/
String name = myCustomer.getName()//
myCustomer.setName = "MC";

tx.commit();//End of transaction, transactions get send to DB
}catch (RuntimeException e){
if(tx != null) && tx.isActive()) tx.rollback();//Rollback transaction in case something went wrong, and tx got created
throw e;}
finally{em.close();} //closing the session
Manit0u
Profile Blog Joined August 2004
Poland17554 Posts
February 10 2017 09:49 GMT
#16803
Just fetch the objects you need before starting the transaction. You should really only use transactions for insert/update statements, not fetching.
Time is precious. Waste it wisely.
Artesimo
Profile Joined February 2015
Germany564 Posts
February 10 2017 09:59 GMT
#16804
On February 10 2017 18:49 Manit0u wrote:
Just fetch the objects you need before starting the transaction. You should really only use transactions for insert/update statements, not fetching.


So it doesn't work, or it is just really clunky? In case of it working, is my assumption correct, that fetching always happens immediately and only inserts/update/delete statements get hold back until .commit() is called?
Hanh
Profile Joined June 2016
146 Posts
February 10 2017 10:20 GMT
#16805
On February 10 2017 18:49 Manit0u wrote:
Just fetch the objects you need before starting the transaction. You should really only use transactions for insert/update statements, not fetching.


Not true if you care about isolation and atomicity. It can lead to serious issues specially in financial applications.
Manit0u
Profile Blog Joined August 2004
Poland17554 Posts
February 10 2017 10:57 GMT
#16806
On February 10 2017 19:20 Hanh wrote:
Show nested quote +
On February 10 2017 18:49 Manit0u wrote:
Just fetch the objects you need before starting the transaction. You should really only use transactions for insert/update statements, not fetching.


Not true if you care about isolation and atomicity. It can lead to serious issues specially in financial applications.


It really depends on what you need and what you're working with. Also, different SQL servers handle transactions differently (MS SQL for example will not allow for any other queries - even reads - until the transaction is commited and closed). Sure, if data integrity is critical, you want to wrap everything in transactions (and possibly add other mechanisms of ensuring that) but for the majority of use cases you won't need that level of paranoia.
Time is precious. Waste it wisely.
Hanh
Profile Joined June 2016
146 Posts
February 10 2017 11:09 GMT
#16807
This isn't paranoia. It is about a program behaving correctly or not. Saying that I don't need to do a transaction because I am only reading is the same as saying that I don't need to use a lock because I'm reading data (except that you won't crash because the database is always acquiring integrity locks). In some cases it is fine because there is an implicit transaction or auto commit in place. Yet if someone is learning about transactions, he should do the right thing.
Artesimo
Profile Joined February 2015
Germany564 Posts
Last Edited: 2017-02-10 11:34:36
February 10 2017 11:31 GMT
#16808
But I still struggle with the fact that the DB gets the data on commit, while I use fetches inside the transaction without having commited first. Does fetch always immediately get passed on to the DB and only write/delete/inserts/everything that manipulates data get send only on commit?
(In other words, persistence context stuff like adding/changing/removing data in/from it gets applied immediately, the Database only gets changed on commit. Fetching inside a transaction doesnt change anything on the DB but loads aditional entities in the persistence context? On commit, the persistence context will be synchronized with the DB)
Hanh
Profile Joined June 2016
146 Posts
February 10 2017 12:09 GMT
#16809
I don't know what the JPA (?) layer does but speaking from the database point of view, your transaction delimits a unit of execution that is Atomic and Isolated (A and I of ACID). Atomicity means that: Everything succeeds or everything fails. For instance, if you do 2 inserts and the 2nd one fails because of a constraint violation both inserts roll back. It doesn't mean that these inserts are sent at the end of the transaction. If you fetch something, then update it, and fetch again, your second fetch will return the updated value - even if the transaction isn't committed.
Isolation is more complicated but ideally, while your transaction is underway you don't see the actions of other transactions that are run concurrently. There are subtleties because isolation impacts performance and database implementations typically offer several options of isolation level.
WarSame
Profile Blog Joined February 2010
Canada1950 Posts
February 11 2017 03:36 GMT
#16810
On February 10 2017 17:38 Morfildur wrote:
Show nested quote +
On February 10 2017 12:18 WarSame wrote:
What is an elegant way to set a bunch of div colours in SASS?

I would ideally like to do something like
$brown: #955436
$lightblue: #AAE0FA
$pink: #D93A96
$orange: #F7941D
$red: #ED1B24
$yellow: #FEF224
$green: #1FB25A
$darkblue: #0072BB

.block-(colorexample)
background-color:$colorexample


where I could have divs with classes like
block-brown
and have it automatically sub in the colour. Should I just not bother and make a block-colour for every single colour I have?


Please don't.

Name your CSS classes after what they represent, not after what they look like. Otherwise you'll either have to search and replace all the instances when your Boss tells you that all brown buttons should now be green, which negates all the advantages of CSS, or you have a class "brown" that is now green.

In this case they are going to be blocks to build a monopoly board, though, so they need to be named by colour.
Can it be I stayed away too long? Did you miss these rhymes while I was gone?
berated-
Profile Blog Joined February 2007
United States1134 Posts
Last Edited: 2017-02-11 12:48:27
February 11 2017 12:46 GMT
#16811
On February 10 2017 20:31 Artesimo wrote:
But I still struggle with the fact that the DB gets the data on commit, while I use fetches inside the transaction without having commited first. Does fetch always immediately get passed on to the DB and only write/delete/inserts/everything that manipulates data get send only on commit?
(In other words, persistence context stuff like adding/changing/removing data in/from it gets applied immediately, the Database only gets changed on commit. Fetching inside a transaction doesnt change anything on the DB but loads aditional entities in the persistence context? On commit, the persistence context will be synchronized with the DB)


The DB definitely does not only get the data on commit. JPA is just built on top of JDBC, which gets a connection and starts a transaction if you are using your transaction manager. As others have tried to explain, and probably better than I will, you are actively participating in a database transaction at that time.

If you are trying to look at the database while your code has a transaction going on, you won't be able to see it -- that's the part of the isolation levels etc. It might feel like everything happens on commit, but, that's just when everything is actually committed, not when it is transferred.

If you are in the scope of a transaction, you can read the changes that you have made but others can't (most of the time).

Here is some reading on JDBC Transactions

Underneath the hood, when you start the transaction, it takes the connection that you have and turns off auto commit. Then every time you run something with JPA, it takes the jdbc connection and prepares a statement and then executes it -- all of that is done until you call commit.


Deleted User 3420
Profile Blog Joined May 2003
24492 Posts
February 11 2017 19:57 GMT
#16812
So, C question.

I want to create a program that takes in input of the total number of variables that will have to be put into an array

then create an array that has size based on that input

but im reading that arrays can't be created with a variable as the size
wtf is that about, that seems really annoying
Blitzkrieg0
Profile Blog Joined August 2010
United States13132 Posts
Last Edited: 2017-02-11 20:24:02
February 11 2017 20:20 GMT
#16813
On February 12 2017 04:57 travis wrote:
So, C question.

I want to create a program that takes in input of the total number of variables that will have to be put into an array

then create an array that has size based on that input

but im reading that arrays can't be created with a variable as the size
wtf is that about, that seems really annoying


Are you compiling C89 standard or C99 standard? The rules are different for each. The short answer is that the compiler wants to know exactly how much memory will be needed on the stack for your array.

The simple solution is to allocate on the heap using malloc, but that might not be what your class wants you to do.
I'll always be your shadow and veil your eyes from states of ain soph aur.
Deleted User 3420
Profile Blog Joined May 2003
24492 Posts
February 11 2017 20:29 GMT
#16814
I think they want me to just initialize each array to size 50, because they told us in specifications that they won't need to hold more than 50 elements

but I don't like the huge lack in knowledge that comes with that hehe

I am finding I am not a big fan of C.... too much stuff that takes too long to do
Nesserev
Profile Blog Joined January 2011
Belgium2760 Posts
Last Edited: 2017-02-11 21:41:13
February 11 2017 21:17 GMT
#16815
--- Nuked ---
Blitzkrieg0
Profile Blog Joined August 2010
United States13132 Posts
Last Edited: 2017-02-11 21:22:04
February 11 2017 21:18 GMT
#16816
On February 12 2017 05:29 travis wrote:
I think they want me to just initialize each array to size 50, because they told us in specifications that they won't need to hold more than 50 elements

but I don't like the huge lack in knowledge that comes with that hehe

I am finding I am not a big fan of C.... too much stuff that takes too long to do


If you know the max size will be 50 its as simple as:
const int MAX_SIZE = 50;


When you compile your code the compiler knows that the arrays size is 50. It knows exactly how much stack space to allocate and it is happy.

extern int MAX_SIZE;


Contrast with the above where you're getting the max size from somewhere else. The compiler doesn't know what the value will be and it won't let you compile.
I'll always be your shadow and veil your eyes from states of ain soph aur.
Biolunar
Profile Joined February 2012
Germany224 Posts
February 11 2017 21:41 GMT
#16817
If you do this:
const int MAX_SIZE = 50;
T arr[MAX_SIZE];

then arr is a VLA. Don't use VLAs.
What is best? To crush the Zerg, see them driven before you, and hear the lamentations of the Protoss.
Deleted User 3420
Profile Blog Joined May 2003
24492 Posts
February 11 2017 21:50 GMT
#16818
what about #define ARRAY_LENGTH 50 ?
Nesserev
Profile Blog Joined January 2011
Belgium2760 Posts
Last Edited: 2017-02-11 22:14:55
February 11 2017 22:03 GMT
#16819
--- Nuked ---
Blitzkrieg0
Profile Blog Joined August 2010
United States13132 Posts
February 11 2017 22:24 GMT
#16820
I was under the impression that a constant didn't change value, but when I wrote C89 was the worst months of my life so I'll just refrain from answering anymore about it since apparently I don't remember anything.
I'll always be your shadow and veil your eyes from states of ain soph aur.
Prev 1 839 840 841 842 843 1032 Next
Please log in or register to reply.
Live Events Refresh
Next event in 15h 1m
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
elazer 270
ProTech156
Nathanias 99
StarCraft: Brood War
Britney 17200
Shuttle 602
Jaedong 378
Sexy 14
910 13
Shine 7
Dota 2
XaKoH 327
League of Legends
C9.Mang0222
Counter-Strike
fl0m1581
minikerr41
Heroes of the Storm
Khaldor200
Other Games
Grubby5606
FrodaN2491
mouzStarbuck500
Pyrionflax438
B2W.Neo323
Liquid`Hasu237
NarutO 29
ViBE19
rubinoeu6
Organizations
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
sctven
[ Show 15 non-featured ]
StarCraft 2
• Hupsaiya 109
• StrangeGG 49
• musti20045 23
• AfreecaTV YouTube
• intothetv
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
Other Games
• imaqtpie3533
• Shiphtur283
Upcoming Events
OSC
15h 1m
Korean StarCraft League
1d 5h
OSC
1d 14h
IPSL
1d 16h
Dewalt vs Bonyth
OSC
1d 20h
OSC
2 days
uThermal 2v2 Circuit
2 days
Replay Cast
3 days
Patches Events
3 days
Liquipedia Results

Completed

C-Race Season 1
WardiTV 2025
META Madness #9

Ongoing

IPSL Winter 2025-26
BSL Season 21
Slon Tour Season 2
CSL Season 19: Qualifier 2
eXTREMESLAND 2025
SL Budapest Major 2025
ESL Impact League Season 8
BLAST Rivals Fall 2025
IEM Chengdu 2025
PGL Masters Bucharest 2025
Thunderpick World Champ.
CS Asia Championships 2025

Upcoming

Escore Tournament S1: W2
CSL 2025 WINTER (S19)
Escore Tournament S1: W3
BSL 21 Non-Korean Championship
Acropolis #4
IPSL Spring 2026
Bellum Gens Elite Stara Zagora 2026
HSC XXVIII
Thunderfire SC2 All-star 2025
Big Gabe Cup #3
OSC Championship Season 13
Nations Cup 2026
Underdog Cup #3
NA Kuram Kup
ESL Pro League Season 23
ESL Pro League Season 23
PGL Cluj-Napoca 2026
IEM Kraków 2026
BLAST Bounty Winter 2026
BLAST Bounty Winter Qual
TLPD

1. ByuN
2. TY
3. Dark
4. Solar
5. Stats
6. Nerchio
7. sOs
8. soO
9. INnoVation
10. Elazer
1. Rain
2. Flash
3. EffOrt
4. Last
5. Bisu
6. Soulkey
7. Mini
8. Sharp
Sidebar Settings...

Advertising | Privacy Policy | Terms Of Use | Contact Us

Original banner artwork: Jim Warren
The contents of this webpage are copyright © 2026 TLnet. All Rights Reserved.